2023-05-23 16:13:17 +08:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Collections;
|
|
|
|
|
using System.Data;
|
|
|
|
|
using System.Data.OleDb;
|
|
|
|
|
using System.IO;
|
|
|
|
|
using System.Security.Cryptography;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using System.Diagnostics;
|
|
|
|
|
using System.Reflection;
|
|
|
|
|
using System.Web;
|
|
|
|
|
using System.Net;
|
|
|
|
|
using DeiNiu.wms.win;
|
|
|
|
|
using System.Runtime.Serialization.Json;
|
|
|
|
|
|
|
|
|
|
namespace DeiNiu.Utils
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
// public enum op_flag { add = 1, update, delete, getObj, queryAll, queryExample,queryActived,getPk, getCount};
|
|
|
|
|
// public enum ProjectStatus { <20><><EFBFBD><EFBFBD>δ<EFBFBD>ύ, <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ԥ<EFBFBD><D4A4>, <20><><EFBFBD><EFBFBD>Ԥ<EFBFBD><D4A4>ͨ<EFBFBD><CDA8>, <20><><EFBFBD><EFBFBD>Ԥ<EFBFBD><D4A4>δͨ<CEB4><CDA8>, <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><CDA8>, <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>δͨ<CEB4><CDA8>, <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><CDA8>, <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>δͨ<CEB4><CDA8>,ɾ<><C9BE>δ<EFBFBD>ύ,ɾ<><C9BE><EFBFBD><EFBFBD>Ԥ<EFBFBD><D4A4>,ɾ<><C9BE>Ԥ<EFBFBD><D4A4>ͨ<EFBFBD><CDA8>,ɾ<><C9BE>Ԥ<EFBFBD><D4A4>δͨ<CEB4><CDA8>,ɾ<><C9BE><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><CDA8>,ɾ<><C9BE><EFBFBD><EFBFBD><EFBFBD><EFBFBD>δͨ<CEB4><CDA8>,ɾ<><C9BE><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><CDA8>,ɾ<><C9BE><EFBFBD><EFBFBD><EFBFBD><EFBFBD>δͨ<CEB4><CDA8>,<2C><>Ŀ<EFBFBD><C4BF><EFBFBD><EFBFBD> };
|
|
|
|
|
public enum FileType {Project,ProjectDetail,<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ܽ<EFBFBD>,<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ܽ<EFBFBD>,<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȼƻ<EFBFBD>,<EFBFBD><EFBFBD><EFBFBD>ȼƻ<EFBFBD> };
|
|
|
|
|
public struct ProjectDetailStatus
|
|
|
|
|
{
|
|
|
|
|
public static string <EFBFBD><EFBFBD><EFBFBD><EFBFBD>δͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><><EFBFBD><EFBFBD>δͨ<CEB4><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static string <EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><><EFBFBD><EFBFBD>ͨ<EFBFBD><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string <EFBFBD><EFBFBD><EFBFBD><EFBFBD>δͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><><EFBFBD><EFBFBD>δͨ<CEB4><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static string <EFBFBD>¶<EFBFBD>δ<EFBFBD>ύ
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22>¶<EFBFBD>δ<EFBFBD>ύ";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static string <EFBFBD>¶<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ύ
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22>¶<EFBFBD><C2B6><EFBFBD><EFBFBD>ύ";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string <EFBFBD><EFBFBD>Ԥ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><>Ԥ<EFBFBD><D4A4>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string Ԥ<EFBFBD><EFBFBD>ͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "Ԥ<><D4A4>ͨ<EFBFBD><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string Ԥ<EFBFBD><EFBFBD>δͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "Ԥ<><D4A4>δͨ<CEB4><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string <EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><><EFBFBD><EFBFBD>ͨ<EFBFBD><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public struct ApproveRoles
|
|
|
|
|
{
|
|
|
|
|
public static string YuShen
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><>ĿԤ<C4BF><D4A4>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string ShenHe
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><>Ŀ<EFBFBD><C4BF><EFBFBD><EFBFBD>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string KaoHe
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><>Ŀ<EFBFBD><C4BF><EFBFBD><EFBFBD>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string <EFBFBD><EFBFBD>Ŀά<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><>Ŀά<C4BF><CEAC>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public struct ProjectStatus
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
public static string <EFBFBD><EFBFBD>Ŀ<EFBFBD>ѷ<EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><>Ŀ<EFBFBD>ѷ<EFBFBD><D1B7><EFBFBD>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string <EFBFBD><EFBFBD>Ŀδ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><>Ŀδ<C4BF><CEB4><EFBFBD><EFBFBD>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static string <EFBFBD><EFBFBD><EFBFBD><EFBFBD>δ<EFBFBD>ύ
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><><EFBFBD><EFBFBD>δ<EFBFBD>ύ";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static string <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ύ
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ύ";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static string <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string <EFBFBD><EFBFBD>Ŀ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><>Ŀ<EFBFBD><C4BF><EFBFBD><EFBFBD>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string <EFBFBD><EFBFBD>Ŀ<EFBFBD>ⶳ
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><>Ŀ<EFBFBD>ⶳ";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>δͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>δͨ<CEB4><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string <EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ԥ<EFBFBD><EFBFBD>δͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><><EFBFBD><EFBFBD>Ԥ<EFBFBD><D4A4>δͨ<CEB4><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string <EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ԥ<EFBFBD><EFBFBD>ͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><><EFBFBD><EFBFBD>Ԥ<EFBFBD><D4A4>ͨ<EFBFBD><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static string ɾ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>δͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "ɾ<><C9BE><EFBFBD><EFBFBD><EFBFBD><EFBFBD>δͨ<CEB4><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static string ɾ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "ɾ<><C9BE><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string ɾ<EFBFBD><EFBFBD>Ԥ<EFBFBD><EFBFBD>δͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "ɾ<><C9BE>Ԥ<EFBFBD><D4A4>δͨ<CEB4><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string ɾ<EFBFBD><EFBFBD>Ԥ<EFBFBD><EFBFBD>ͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "ɾ<><C9BE>Ԥ<EFBFBD><D4A4>ͨ<EFBFBD><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static string ɾ<EFBFBD><EFBFBD>δ<EFBFBD>ύ
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "ɾ<><C9BE>δ<EFBFBD>ύ";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string ɾ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ύ
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "ɾ<><C9BE><EFBFBD><EFBFBD><EFBFBD>ύ";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>δͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>δͨ<CEB4><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string <EFBFBD><EFBFBD>Ŀ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><>Ŀ<EFBFBD><C4BF><EFBFBD><EFBFBD>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string <EFBFBD><EFBFBD>Ŀδ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "<22><>Ŀδ<C4BF><CEB4><EFBFBD><EFBFBD>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string ɾ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>δͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "ɾ<><C9BE><EFBFBD><EFBFBD><EFBFBD><EFBFBD>δͨ<CEB4><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static string ɾ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "ɾ<><C9BE><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><CDA8>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
<EFBFBD><EFBFBD> public struct appScope
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// used for storing logic object in session
|
|
|
|
|
/// when page changes in server side, logic object in session
|
|
|
|
|
/// will be replaced by new one.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public static string PagelevelObj
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return "PageLevelObj";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public class MyTracer
|
|
|
|
|
{
|
|
|
|
|
private static TraceSwitch appSwitch = new TraceSwitch("TraceSwitch", "Switch in config file");
|
|
|
|
|
|
|
|
|
|
private static string render(object clz, string msg)
|
|
|
|
|
{
|
|
|
|
|
//time
|
|
|
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
|
DateTime dt = DateTime.Now;
|
|
|
|
|
sb.Append(dt.ToLongDateString()).Append(" ").Append(dt.ToLongTimeString()).Append(" - ");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
StackTrace stackTrace = new StackTrace();
|
|
|
|
|
StackFrame stackFrame = stackTrace.GetFrame(2);
|
|
|
|
|
|
|
|
|
|
//class name
|
|
|
|
|
sb.Append(clz.GetType().FullName).Append(" [");
|
|
|
|
|
|
|
|
|
|
//method name
|
|
|
|
|
MethodBase methodBase = stackFrame.GetMethod();
|
|
|
|
|
|
|
|
|
|
sb.Append(methodBase.Name).Append("] ");
|
|
|
|
|
|
|
|
|
|
//the msg
|
|
|
|
|
sb.Append(msg);
|
|
|
|
|
|
|
|
|
|
return sb.ToString();
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
public static void Error(object clz, string msg)
|
|
|
|
|
{
|
|
|
|
|
Trace.WriteLineIf(appSwitch.TraceError, render(clz, "[ERROR] " + msg));
|
|
|
|
|
}
|
|
|
|
|
public static void Warning(object clz, string msg)
|
|
|
|
|
{
|
|
|
|
|
Trace.WriteLineIf(appSwitch.TraceWarning, render(clz, "[WARNING] " + msg));
|
|
|
|
|
}
|
|
|
|
|
public static void Info(object clz, string msg)
|
|
|
|
|
{
|
|
|
|
|
Trace.WriteLineIf(appSwitch.TraceInfo, render(clz, "[INFO] " + msg));
|
|
|
|
|
}
|
|
|
|
|
public static void Verbose(object clz, string msg)
|
|
|
|
|
{
|
|
|
|
|
Trace.WriteLineIf(appSwitch.TraceVerbose, render(clz, "[VERBOSE] " + msg));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public class Util
|
|
|
|
|
{
|
|
|
|
|
public static string Encrypt(string password)//<2F><><EFBFBD>ܺ<EFBFBD><DCBA><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
Byte[] clearBytes = new UnicodeEncoding().GetBytes(password);
|
|
|
|
|
Byte[] hashedBytes = ((HashAlgorithm)CryptoConfig.CreateFromName("MD5")).ComputeHash(clearBytes);
|
|
|
|
|
return BitConverter.ToString(hashedBytes);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// <20><><EFBFBD><EFBFBD>in sql,return like " 1,2,3"
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="al"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
public static string buildWhereIntIn(ArrayList al)
|
|
|
|
|
{
|
|
|
|
|
string whereString = string.Empty;
|
|
|
|
|
|
|
|
|
|
for (int i = 0; i < al.Count; i++)
|
|
|
|
|
{
|
|
|
|
|
whereString += "'"+ al[i] + "',";
|
|
|
|
|
}
|
|
|
|
|
if (whereString.EndsWith(","))
|
|
|
|
|
{
|
|
|
|
|
whereString = whereString.Substring(0, whereString.Length - 1);
|
|
|
|
|
}
|
|
|
|
|
return whereString;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static DataSet Excel2DataSet(string filepath)
|
|
|
|
|
{
|
|
|
|
|
DataSet ds = new DataSet();
|
|
|
|
|
ArrayList SheeNames = ExcelSheetName(filepath);
|
|
|
|
|
for(int i=0;i<SheeNames.Count;i++)
|
|
|
|
|
{
|
|
|
|
|
DataTable dt = (ExcelDataSource(filepath, SheeNames[i].ToString())).Tables[0].Copy();
|
|
|
|
|
dt.TableName = SheeNames[i].ToString();
|
|
|
|
|
dt.TableName = dt.TableName.Substring(0, dt.TableName.IndexOf("$"));
|
|
|
|
|
ds.Tables.Add(dt);
|
|
|
|
|
}
|
|
|
|
|
return ds;
|
|
|
|
|
}
|
|
|
|
|
//<2F>÷<EFBFBD><C3B7><EFBFBD>ʵ<EFBFBD>ִ<EFBFBD>Excel<65>е<EFBFBD><D0B5><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ݵ<EFBFBD>DataSet<65>У<EFBFBD><D0A3><EFBFBD><EFBFBD><EFBFBD>filepathΪExcel<65>ļ<EFBFBD><C4BC>ľ<EFBFBD><C4BE><EFBFBD>·<EFBFBD><C2B7><EFBFBD><EFBFBD> sheetnameΪexcel<65>ļ<EFBFBD><C4BC>еı<D0B5><C4B1><EFBFBD>
|
|
|
|
|
public static DataSet ExcelDataSource(string filepath, string sheetname)
|
|
|
|
|
{
|
|
|
|
|
string strConn;
|
|
|
|
|
strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filepath + ";Extended Properties=Excel 8.0;";
|
|
|
|
|
OleDbConnection conn = new OleDbConnection(strConn);
|
|
|
|
|
OleDbDataAdapter oada = new OleDbDataAdapter("select * from [" + sheetname + "]", strConn);
|
|
|
|
|
DataSet ds = new DataSet();
|
|
|
|
|
oada.Fill(ds);
|
|
|
|
|
conn.Close();
|
|
|
|
|
return ds;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//<2F><><EFBFBD><EFBFBD>Excel<65>е<EFBFBD><D0B5><EFBFBD><EFBFBD><EFBFBD>sheetname<6D><65>
|
|
|
|
|
public static ArrayList ExcelSheetName(string filepath)
|
|
|
|
|
{
|
|
|
|
|
ArrayList al = new ArrayList();
|
|
|
|
|
string strConn;
|
|
|
|
|
strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filepath + ";Extended Properties=Excel 8.0;";
|
|
|
|
|
OleDbConnection conn = new OleDbConnection(strConn);
|
|
|
|
|
conn.Open();
|
|
|
|
|
DataTable sheetNames = conn.GetOleDbSchemaTable
|
|
|
|
|
(System.Data.OleDb.OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });
|
|
|
|
|
conn.Close();
|
|
|
|
|
foreach (DataRow dr in sheetNames.Rows)
|
|
|
|
|
{
|
|
|
|
|
al.Add(dr[2]);
|
|
|
|
|
}
|
|
|
|
|
return al;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public<EFBFBD><EFBFBD>static<EFBFBD><EFBFBD>DataView<EFBFBD><EFBFBD>GetTopDataViewRows(DataView<EFBFBD><EFBFBD>dv,<EFBFBD><EFBFBD>int<EFBFBD><EFBFBD>n)
|
|
|
|
|
<EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>{
|
|
|
|
|
<EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>DataTable<EFBFBD><EFBFBD>dt<EFBFBD><EFBFBD>=<EFBFBD><EFBFBD>dv.Table.Clone();
|
|
|
|
|
<EFBFBD><EFBFBD> <EFBFBD><EFBFBD>
|
|
|
|
|
<EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>for<EFBFBD><EFBFBD>(int<EFBFBD><EFBFBD>i<EFBFBD><EFBFBD>=<EFBFBD><EFBFBD>0;<EFBFBD><EFBFBD>i<EFBFBD><EFBFBD><<EFBFBD><EFBFBD>n<EFBFBD><EFBFBD>-<EFBFBD><EFBFBD>1;<EFBFBD><EFBFBD>i++)
|
|
|
|
|
<EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>{
|
|
|
|
|
<EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>if<EFBFBD><EFBFBD>(i<EFBFBD><EFBFBD>>=<EFBFBD><EFBFBD>dv.Count)
|
|
|
|
|
<EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>{
|
|
|
|
|
<EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>break;
|
|
|
|
|
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>}
|
|
|
|
|
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>dt.ImportRow(dv[i].Row);
|
|
|
|
|
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> }
|
|
|
|
|
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>return<EFBFBD><EFBFBD>new<EFBFBD><EFBFBD>DataView(dt,<EFBFBD><EFBFBD>dv.RowFilter,<EFBFBD><EFBFBD>dv.Sort,<EFBFBD><EFBFBD> dv.RowStateFilter);
|
|
|
|
|
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// <20><>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>ij<EFBFBD><C4B3><EFBFBD><EFBFBD>ֵ
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="key">appSettings<67><73>key</param>
|
|
|
|
|
/// <returns>appSettings<67><73>Value</returns>
|
|
|
|
|
//public static string GetConfig(string key)
|
|
|
|
|
//{
|
|
|
|
|
//string _value = string.Empty;
|
|
|
|
|
//System.Configuration.ConfigurationManager config = System.Configuration.ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);
|
|
|
|
|
//if (config.AppSettings.Settings[key] != null)
|
|
|
|
|
//{
|
|
|
|
|
// _value = config.AppSettings.Settings[key].Value;
|
|
|
|
|
//}
|
|
|
|
|
//return _value;
|
|
|
|
|
//}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ת<EFBFBD><D7AA>
|
|
|
|
|
public static string getCode128(string codeIn)
|
|
|
|
|
{
|
|
|
|
|
//string str ="";
|
|
|
|
|
string result;
|
|
|
|
|
int checksum = 104;
|
|
|
|
|
for (int i = 0; i < codeIn.Length; i++)
|
|
|
|
|
{
|
|
|
|
|
if (codeIn[i] >= 32)
|
|
|
|
|
{
|
|
|
|
|
checksum += (codeIn[i] - 32) * (i + 1);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
checksum += (codeIn[i] + 64) * (i + 1);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
checksum = checksum % 103;
|
|
|
|
|
if (checksum < 95)
|
|
|
|
|
{
|
|
|
|
|
checksum += 32;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
checksum += 100;
|
|
|
|
|
}
|
|
|
|
|
result = Convert.ToChar(204) + codeIn +
|
|
|
|
|
Convert.ToChar(checksum) + Convert.ToChar(206);
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static string getOrderNo(enumCreateOrderType orderType,int seq)
|
|
|
|
|
{
|
|
|
|
|
string prefix = "UN";
|
|
|
|
|
switch (orderType)
|
|
|
|
|
{
|
|
|
|
|
case enumCreateOrderType.repOrderIn:
|
|
|
|
|
prefix = "RPI";
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return string.Format("{0}{1:D2}{2:D10}",prefix,DateTime.Now.Month,seq);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
public static string getLightKey(int color,int labelId, int address)
|
|
|
|
|
{
|
|
|
|
|
return string.Format("{0}-{1}-{2}", color, labelId, address);
|
|
|
|
|
}*/
|
|
|
|
|
|
|
|
|
|
public static string getLightKey(int order, int color, int labelId, int address)
|
|
|
|
|
{
|
|
|
|
|
return string.Format("{0}-{1}-{2}-{3}", order, color, labelId, address);
|
|
|
|
|
}
|
|
|
|
|
public static Dictionary<int,string> convertEnumToDic(Type enumType){
|
|
|
|
|
|
|
|
|
|
Dictionary<int, string> dic = new Dictionary<int, string>();
|
|
|
|
|
foreach (int myCode in Enum.GetValues(enumType))
|
|
|
|
|
{
|
|
|
|
|
string strName = Enum.GetName(enumType, myCode);//<2F><>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD>
|
|
|
|
|
string strVaule = myCode.ToString();//<2F><>ȡֵ
|
|
|
|
|
dic[myCode] = strName;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return dic;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// <20><>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ip<69><70>ַ
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="netType">"InterNetwork":ipv4<76><34>ַ<EFBFBD><D6B7>"InterNetworkV6":ipv6<76><36>ַ</param>
|
|
|
|
|
/// <returns>ip<69><70>ַ<EFBFBD><D6B7><EFBFBD><EFBFBD></returns>
|
|
|
|
|
public static List<string> GetLocalIpAddress(string netType)
|
|
|
|
|
{
|
|
|
|
|
string hostName = Dns.GetHostName(); //<2F><>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
IPAddress[] addresses = Dns.GetHostAddresses(hostName); //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>IP<49><50>ַ
|
|
|
|
|
|
|
|
|
|
List<string> IPList = new List<string>();
|
|
|
|
|
if (netType == string.Empty)
|
|
|
|
|
{
|
|
|
|
|
for (int i = 0; i < addresses.Length; i++)
|
|
|
|
|
{
|
|
|
|
|
IPList.Add(addresses[i].ToString());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
//AddressFamily.InterNetwork<72><6B>ʾ<EFBFBD><CABE>IPΪIPv4,
|
|
|
|
|
//AddressFamily.InterNetworkV6<56><36>ʾ<EFBFBD>˵<EFBFBD>ַΪIPv6<76><36><EFBFBD><EFBFBD>
|
|
|
|
|
for (int i = 0; i < addresses.Length; i++)
|
|
|
|
|
{
|
|
|
|
|
if (addresses[i].AddressFamily.ToString() == netType)
|
|
|
|
|
{
|
|
|
|
|
IPList.Add(addresses[i].ToString());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return IPList;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static string getLbJson(ELabel label)
|
|
|
|
|
{
|
|
|
|
|
string json = "";
|
|
|
|
|
/* if (label.port == 0) //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϣ
|
|
|
|
|
{
|
|
|
|
|
json = String.Format("\"labelId\":{0},\"num1\":{1},\"num2\":{2},\"color\":{3},\"orderNo\":{4}"
|
|
|
|
|
, label.labelId, label.num1, label.num2 , label.color, label.orderNo);
|
|
|
|
|
|
|
|
|
|
}else //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϣ
|
|
|
|
|
*/
|
2023-09-04 22:41:19 +08:00
|
|
|
|
DataContractJsonSerializer jsonSerializer
|
2023-05-23 16:13:17 +08:00
|
|
|
|
= new DataContractJsonSerializer(typeof(ELabel));
|
|
|
|
|
var stream = new MemoryStream();
|
|
|
|
|
jsonSerializer.WriteObject(stream, label);
|
|
|
|
|
|
|
|
|
|
byte[] dataBytes = new byte[stream.Length];
|
|
|
|
|
|
|
|
|
|
stream.Position = 0;
|
|
|
|
|
|
|
|
|
|
stream.Read(dataBytes, 0, (int)stream.Length);
|
|
|
|
|
|
|
|
|
|
string dataString = Encoding.UTF8.GetString(dataBytes);
|
|
|
|
|
|
|
|
|
|
if (dataString.Length > 0) return dataString;
|
|
|
|
|
|
|
|
|
|
json = String.Format("\"labelId\":{0},\"num1\":{1},\"num2\":{2},\"num3\":{3},\"color\":{4},\"port\":{5} , \"rowId\":{6}", label.labelId, label.num1, label.num2, label.num3, label.color, label.port, label.rowId);
|
|
|
|
|
// Console.Write("get the lable: " + json);
|
|
|
|
|
//
|
|
|
|
|
json = stream.ToString();
|
|
|
|
|
|
|
|
|
|
return "{" + json + "}";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|