namespace BLL
{
    using Model;
    using Quartz;
    using RestSharp;
    using System;
    using System.Collections.Generic;
    using System.Data;
    using System.Globalization;
    using System.Linq;
    using System.Net;
    using System.Reflection;
    using System.Text;
    /// 
    /// 通用方法类。
    /// 
    public static class Funs
    {
        /// 
        /// 维护一个DB集合
        /// 
        private static Dictionary dataBaseLinkList = new System.Collections.Generic.Dictionary();
        /// 
        /// 维护一个DB集合
        /// 
        public static System.Collections.Generic.Dictionary DBList
        {
            get
            {
                return dataBaseLinkList;
            }
        }
        public static IScheduler ScheduledTasks
        {
            get;
            set;
        }
        public static DictionaryWebEditList= new Dictionary();
        /// 
        /// 数据库连接字符串
        /// 
        private static string connString;
        
        /// 
        /// 数据库连结字符串。
        /// 
        public static string ConnString
        {
            get
            {
                if (connString == null)
                {
                    throw new NotSupportedException("请设置连接字符串!");
                }
                return connString;
            }
            set
            {
                if (connString != null)
                {
                    throw new NotSupportedException("连接已设置!");
                }
                connString = value;
            }
        }
        /// 
        /// 系统名称
        /// 
        public static string SystemName
        {
            get;
            set;
        }
        /// 
        /// 服务器路径
        /// 
        public static string RootPath
        {
            get;
            set;
        }
        /// 
        /// 集团服务器路径
        /// 
        public static string CNCECPath
        {
            get;
            set;
        }
        public static string SGGLUrl
        {
            get;
            set;
        }
        /// 
        /// 实名制地址
        /// 
        public static string RealNameApiUrl
        {
            get;
            set;
        }
        /// 
        /// 费控软件地址
        /// 
        public static string ControlApiUrl
        {
            get;
            set;
        }
        /// 
        /// 软件版本
        /// 
        public static string SystemVersion
        {
            get;
            set;
        }
        /// 
        /// 每页数量
        /// 
        public static int PageSize
        {
            get;
            set;
        } = 15;
        ///// 
        ///// 数据库上下文。
        ///// 
        //public static SGGLDB DB
        //{
        //    get
        //    {
        //        if (!DBList.ContainsKey(System.Threading.Thread.CurrentThread.ManagedThreadId))
        //        {
        //            DBList.Add(System.Threading.Thread.CurrentThread.ManagedThreadId, new SGGLDB(connString));
        //        }
        //        // DBList[System.Threading.Thread.CurrentThread.ManagedThreadId].CommandTimeout = 1200;
        //        return DBList[System.Threading.Thread.CurrentThread.ManagedThreadId];
        //    }
        //}
        private static object locker = new object();
        /// 
        /// 数据库上下文。
        /// 
        public static SGGLDB DB
        {
            get
            {
                lock (locker)
                {
                    try
                    {
                        if (!DBList.ContainsKey(System.Threading.Thread.CurrentThread.ManagedThreadId))
                        {
                            DBList.Add(System.Threading.Thread.CurrentThread.ManagedThreadId, new SGGLDB(connString));
                        }
                        // DBList[System.Threading.Thread.CurrentThread.ManagedThreadId].CommandTimeout = 1200;
                        return DBList[System.Threading.Thread.CurrentThread.ManagedThreadId];
                    }
                    catch
                    {
                        var db = new SGGLDB(connString);
                        if (DBList.ContainsKey(System.Threading.Thread.CurrentThread.ManagedThreadId))
                        {
                            DBList[System.Threading.Thread.CurrentThread.ManagedThreadId] = db;
                        }
                        else
                        {
                            DBList.Add(System.Threading.Thread.CurrentThread.ManagedThreadId, db);
                        }
                        return db;
                    }
                }
            }
        }
        /// 
        /// 加密密码
        /// 
        /// 加密前的密码
        /// 加密后的密码
        public static string EncryptionPassword(string password)
        {
            System.Security.Cryptography.MD5 md5 = System.Security.Cryptography.MD5.Create();
            return BitConverter.ToString(md5.ComputeHash(Encoding.UTF8.GetBytes(password))).Replace("-", null);
            //return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(password, "MD5");
        }
        #region 获取用户初始密码
        /// 
        /// 获取用户初始密码
        /// 
        /// 
        /// 
        public static string getInitialPassword(string unitId, string idCard)
        {
            string prefixValue = "CWCEC";
            string suffixValue = "1234";
            //var getUnit = UnitService.GetUnitByUnitId(unitId);
            //if (getUnit != null)
            //{
            //    if (!string.IsNullOrEmpty(getUnit.UnitCode))
            //    {
            //        if (getUnit.UnitCode.Length > 10)
            //        {
            //            prefixValue = getUnit.UnitCode.Substring(getUnit.UnitCode.Length - 10);
            //        }
            //        else
            //        {
            //            prefixValue = getUnit.UnitCode;
            //        }
            //    }
            //}
            if (!string.IsNullOrEmpty(idCard))
            {
                if (idCard.Length > 4)
                {
                    suffixValue = idCard.Substring(idCard.Length - 4);
                }
                else
                {
                    suffixValue = idCard;
                }
            }
            return prefixValue + "." + suffixValue;
        }
        #endregion
        #region 验证密码
        /// 
        /// 
        /// 
        /// 
        /// 
        public static bool IsLetter(char c)
        {
            return (c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z');
        }
        public static bool IsDigit(char c)
        {
            return c >= '0' && c <= '9';
        }
        static bool IsSymbol(char c)
        {
            return c > 32 && c < 127 && !IsDigit(c) && !IsLetter(c);
        }
        public static bool IsValIDPassword(string password)
        {
            return
               password.Any(c => IsLetter(c)) &&
               password.Any(c => IsDigit(c)) &&
               password.Any(c => IsSymbol(c));
        }
        #endregion
        /// 
        /// 为目标下拉框加上 "请选择" 项
        /// 
        /// 目标下拉框
        public static void PleaseSelect(System.Web.UI.WebControls.DropDownList DDL)
        {
            DDL.Items.Insert(0, new System.Web.UI.WebControls.ListItem("- 请选择 -", "0"));
            return;
        }
        /// 
        /// 为目标下拉框加上 "请选择" 项
        /// 
        /// 目标下拉框
        public static void FineUIPleaseSelect(FineUIPro.DropDownList DDL)
        {
            DDL.Items.Insert(0, new FineUIPro.ListItem("- 请选择 -", BLL.Const._Null));
            return;
        }
              
        /// 
        /// 为目标下拉框加上选择内容
        /// 
        /// 目标下拉框
        public static void FineUIPleaseSelect(FineUIPro.DropDownList DDL, string text)
        {
            DDL.Items.Insert(0, new FineUIPro.ListItem(text, BLL.Const._Null));
            return;
        }
        /// 
        /// 为目标下拉框加上 "重新编制" 项
        /// 
        /// 目标下拉框
        public static void ReCompileSelect(System.Web.UI.WebControls.DropDownList DDL)
        {
            DDL.Items.Insert(0, new System.Web.UI.WebControls.ListItem("重新编制", "0"));
            return;
        }
        /// 
        /// 页码下拉框
        /// 
        /// 目标下拉框
        public static void DropDownPageSize(FineUIPro.DropDownList DDL)
        {
            DDL.Items.Insert(0, new FineUIPro.ListItem("10", "10"));
            DDL.Items.Insert(1, new FineUIPro.ListItem("20", "20", true));
            DDL.Items.Insert(2, new FineUIPro.ListItem("30", "30"));
            DDL.Items.Insert(3, new FineUIPro.ListItem("50", "50"));
            DDL.Items.Insert(4, new FineUIPro.ListItem("所有行", "1000000"));
            return;
        }
        /// 
        /// 字符串是否为浮点数
        /// 
        /// 要检查的字符串
        /// 返回是或否
        public static bool IsDecimal(string decimalStr)
        {
            if (String.IsNullOrEmpty(decimalStr))
            {
                return false;
            }
            try
            {
                Convert.ToDecimal(decimalStr, NumberFormatInfo.InvariantInfo);
                return true;
            }
            catch (Exception ex)
            {
                ErrLogInfo.WriteLog(string.Empty, ex);
                return false;
            }
        }
        /// 
        /// 判断一个字符串是否是整数
        /// 
        /// 要检查的字符串
        /// 返回是或否
        public static bool IsInteger(string integerStr)
        {
            if (String.IsNullOrEmpty(integerStr))
            {
                return false;
            }
            try
            {
                Convert.ToInt32(integerStr, NumberFormatInfo.InvariantInfo);
                return true;
            }
            catch (Exception ex)
            {
                ErrLogInfo.WriteLog(string.Empty, ex);
                return false;
            }
        }
        /// 
        /// 获取新的数字
        /// 
        /// 要转换的数字
        /// 新的数字
        public static string InterceptDecimal(object number)
        {
            if (number == null)
            {
                return null;
            }
            decimal newNumber = 0;
            string newNumberStr = "";
            int an = -1;
            string numberStr = number.ToString();
            int n = numberStr.IndexOf(".");
            if (n == -1)
            {
                return numberStr;
            }
            for (int i = n + 1; i < numberStr.Length; i++)
            {
                string str = numberStr.Substring(i, 1);
                if (str == "0")
                {
                    if (GetStr(numberStr, i))
                    {
                        an = i;
                        break;
                    }
                }
            }
            if (an == -1)
            {
                newNumber = Convert.ToDecimal(numberStr);
            }
            else if (an == n + 1)
            {
                newNumberStr = numberStr.Substring(0, an - 1);
                newNumber = Convert.ToDecimal(newNumberStr);
            }
            else
            {
                newNumberStr = numberStr.Substring(0, an);
                newNumber = Convert.ToDecimal(newNumberStr);
            }
            return newNumber.ToString();
        }
        /// 
        /// 判断字符串从第n位开始以后是否都为0
        /// 
        /// 要判断的字符串
        /// 开始的位数
        /// false不都为0,true都为0
        public static bool GetStr(string number, int n)
        {
            for (int i = n; i < number.Length; i++)
            {
                if (number.Substring(i, 1) != "0")
                {
                    return false;
                }
            }
            return true;
        }
        /// 
        /// 截取字符串长度
        /// 
        /// 要截取的字符串
        /// 长度
        /// 截取后字符串
        public static string GetSubStr(object str, object n)
        {
            if (str != null)
            {
                if (str.ToString().Length > Convert.ToInt32(n))
                {
                    return str.ToString().Substring(0, Convert.ToInt32(n)) + "....";
                }
                else
                {
                    return str.ToString();
                }
            }
            return "";
        }
        /// 
        /// 根据标识返回字符串list
        /// 
        /// 
        /// 
        /// 
        public static List GetStrListByStr(string str, char n)
        {
            List strList = new List();
            if (!string.IsNullOrEmpty(str))
            {
                strList.AddRange(str.Split(n));
            }
            return strList;
        }
        #region 数字转换
        /// 
        /// 输入文本转换数字类型
        /// 
        /// 
        public static decimal GetNewDecimalOrZero(string value)
        {
            decimal revalue = 0;
            if (!String.IsNullOrEmpty(value))
            {
                try
                {
                    revalue = decimal.Parse(value);
                }
                catch (Exception ex)
                {
                    ErrLogInfo.WriteLog(string.Empty, ex);
                }
            }
            return revalue;
        }
        /// 
        /// 输入文本转换数字类型
        /// 
        /// 
        public static decimal? GetNewDecimal(string value)
        {
            decimal? revalue = null;
            if (!String.IsNullOrEmpty(value))
            {
                try
                {
                    revalue = decimal.Parse(value);
                }
                catch (Exception ex)
                {
                    ErrLogInfo.WriteLog(string.Empty, ex);
                }
            }
            return revalue;
        }
        /// 
        /// 输入文本转换数字类型
        /// 
        /// 
        public static int? GetNewInt(string value)
        {
            if (!String.IsNullOrEmpty(value))
            {
                try
                {
                    return Int32.Parse(value);
                }
                catch (Exception ex)
                {
                    ErrLogInfo.WriteLog(string.Empty, ex);
                    return null;
                }
            }
            else
            {
                return null;
            }
        }
        /// 
        /// 输入文本转换数字类型
        /// 
        /// 
        public static long? GetNewlong(string value)
        {
            if (!String.IsNullOrEmpty(value))
            {
                try
                {
                    return long.Parse(value);
                }
                catch (Exception ex)
                {
                    ErrLogInfo.WriteLog(string.Empty, ex);
                    return null;
                }
            }
            else
            {
                return null;
            }
        }
        /// 
        /// 输入文本转换数字类型
        /// 
        /// 
        public static int GetNewIntOrZero(string value)
        {
            int revalue = 0;
            if (!String.IsNullOrEmpty(value))
            {
                try
                {
                    revalue = Int32.Parse(value);
                }
                catch (Exception ex)
                {
                    ErrLogInfo.WriteLog(string.Empty, ex);
                }
            }
            return revalue;
        }
        #endregion
        /// 
        /// 指定上传文件的名称
        /// 
        /// 
        public static string GetNewFileName()
        {
            Random rm = new Random(Environment.TickCount);
            return DateTime.Now.ToString("yyyyMMddhhmmss") + rm.Next(1000, 9999).ToString();
        }
        /// 
        /// 指定上传文件的名称
        /// 
        /// 
        public static string GetNewFileName(DateTime? dateTime)
        {
            string str = string.Empty;
            Random rm = new Random(System.Environment.TickCount);
            if (dateTime.HasValue)
            {
                str= dateTime.Value.ToString("yyyyMMddhhmmss") + rm.Next(1000, 9999).ToString();
            }
            return str;
        }
        #region 时间转换
        /// 
        /// 输入文本转换时间类型
        /// 
        /// 
        public static DateTime? GetNewDateTime(string time)
        {
            try
            {
                if (!String.IsNullOrEmpty(time))
                {
                    DateTime dateTime = DateTime.Parse(time);                     
                    if (dateTime.Year > 1753 && dateTime.Year < 9999)
                    {
                        return dateTime;
                    }
                    else
                    {
                        return null;
                    }
                }
                else
                {
                    return null;
                }
            }
            catch (Exception ex)
            {
                ErrLogInfo.WriteLog(string.Empty, ex);
                return null;
            }
        }
        /// 
        /// 输入文本转换时间类型(空时:默认当前时间)
        /// 
        /// 
        public static DateTime GetNewDateTimeOrNow(string time)
        {
            try
            {
                if (!String.IsNullOrEmpty(time))
                {
                    DateTime dateTime = DateTime.Parse(time);
                    if (dateTime.Year > 1753 && dateTime.Year < 9999)
                    {
                        return dateTime;
                    }
                    else
                    {
                        return DateTime.Now;
                    }
                }
                else
                {
                    return DateTime.Now;
                }
            }
            catch (Exception ex)
            {
                ErrLogInfo.WriteLog(string.Empty, ex);
                return System.DateTime.Now;
            }
        }
        /// 
        /// 根据时间获取是哪个季度
        /// 
        /// 
        public static string GetQuarterlyByTime(DateTime time)
        {
            string quarterly = string.Empty;
            string yearName = time.Year.ToString();
            int month = time.Month;
            string name = string.Empty;
            if (month >= 1 && month <= 3)
            {
                name = "第一季度";
            }
            else if (month >= 4 && month <= 6)
            {
                name = "第二季度";
            }
            else if (month >= 7 && month <= 9)
            {
                name = "第三季度";
            }
            else if (month >= 10 && month <= 12)
            {
                name = "第四季度";
            }
            quarterly = yearName + "年" + name;
            return quarterly;
        }
        /// 
        /// 根据时间获取是哪个季度
        /// 
        /// 
        public static int GetNowQuarterlyByTime(DateTime time)
        {
            int quarterly = 0;
            int month = time.Month;
            if (month >= 1 && month <= 3)
            {
                quarterly = 1;
            }
            else if (month >= 4 && month <= 6)
            {
                quarterly = 2;
            }
            else if (month >= 7 && month <= 9)
            {
                quarterly = 3;
            }
            else if (month >= 10 && month <= 12)
            {
                quarterly = 4;
            }
            return quarterly;
        }
        /// 
        /// 根据月获取是哪个季度
        /// 
        /// 
        public static int GetNowQuarterlyByMonth(int month)
        {
            int quarterly = 0;
            if (month >= 1 && month <= 3)
            {
                quarterly = 1;
            }
            else if (month >= 4 && month <= 6)
            {
                quarterly = 2;
            }
            else if (month >= 7 && month <= 9)
            {
                quarterly = 3;
            }
            else if (month >= 10 && month <= 12)
            {
                quarterly = 4;
            }
            return quarterly;
        }
        /// 
        /// 根据时间获取是哪个季度
        /// 
        /// 
        public static string GetQuarterlyNameByMonth(int month)
        {
            string name = string.Empty;
            if (month >= 1 && month <= 3)
            {
                name = "第一季度";
            }
            else if (month >= 4 && month <= 6)
            {
                name = "第二季度";
            }
            else if (month >= 7 && month <= 9)
            {
                name = "第三季度";
            }
            else if (month >= 10 && month <= 12)
            {
                name = "第四季度";
            }
            return name;
        }
        /// 
        /// 根据时间获取是上、下半年
        /// 
        /// 
        public static int GetNowHalfYearByTime(DateTime time)
        {
            int quarterly = 1;
            int month = time.Month;
            if (month >= 1 && month <= 6)
            {
                quarterly = 1;
            }
            else
            {
                quarterly = 2;
            }
            return quarterly;
        }
        /// 
        /// 根据时间获取是上、下半年
        /// 
        /// 
        public static int GetNowHalfYearByMonth(int month)
        {
            int halfYear = 1;
            if (month >= 1 && month <= 6)
            {
                halfYear = 1;
            }
            else
            {
                halfYear = 2;
            }
            return halfYear;
        }
        /// 
        /// 根据时间获取是上、下半年
        /// 
        /// 
        public static string GetNowHalfYearNameByTime(DateTime time)
        {
            string quarterly = "上半年";
            int month = time.Month;
            if (month >= 1 && month <= 6)
            {
                quarterly = "上半年";
            }
            else
            {
                quarterly = "下半年";
            }
            return quarterly;
        }
        public static DateTime ConvertToDateTime(Int32 d)
        {
            DateTime startTime = new DateTime(1970, 1, 1, 0, 0, 0);
            startTime = startTime.AddSeconds(d).ToLocalTime();
            return startTime;
        }
        public static Int32 ConvertDateTimeToInt32(DateTime dtime)
        {
            string dt = string.Format("{0:yyyy-MM-dd HH:mm:ss}", dtime);
            DateTime dt1 = new DateTime(1970, 1, 1, 8, 0, 0);
            DateTime dt2 = Convert.ToDateTime(dt);
            return Convert.ToInt32((dt2 - dt1).TotalSeconds);
        }
        #endregion
        /// 
        /// 相差月份
        /// 
        /// 
        /// 
        /// 
        public static int CompareMonths(DateTime datetime1, DateTime datetime2)
        {
            DateTime dt = datetime1;
            DateTime dt2 = datetime2;
            if (DateTime.Compare(dt, dt2) < 0)
            {
                dt2 = dt;
                dt = datetime2;
            }
            int year = dt.Year - dt2.Year;
            int month = dt.Month - dt2.Month;
            month = year * 12 + month;
            if (dt.Day - dt2.Day < -15)
            {
                month--;
            }
            else if (dt.Day - dt2.Day > 14)
            {
                month++;
            }
            return month;
        }
        public static DateTime GetQuarterlyMonths(string year, string quarterly)
        {
            string startMonth = string.Empty;
            if (quarterly == "1")
            {
                startMonth = "1";
            }
            else if (quarterly == "2")
            {
                startMonth = "4";
            }
            else if (quarterly == "3")
            {
                startMonth = "7";
            }
            else if (quarterly == "4")
            {
                startMonth = "10";
            }
            return Funs.GetNewDateTimeOrNow(year + "-" + startMonth + "-01");
        }
        /// 
        /// 获取单位工程类型
        /// 
        /// 
        /// 
        public static string GetUnitWorkType(string projectType)
        {
            string type = string.Empty;
            if (projectType == "1")
            {
                type = "建筑";
            }
            if (projectType == "2")
            {
                type = "安装";
            }
            return type;
        }
        #region  获取大写金额事件
            public static string NumericCapitalization(decimal num)
        {
            string str1 = "零壹贰叁肆伍陆柒捌玖";            //0-9所对应的汉字 
            string str2 = "万仟佰拾亿仟佰拾万仟佰拾元角分"; //数字位所对应的汉字 
            string str3 = "";    //从原num值中取出的值 
            string str4 = "";    //数字的字符串形式 
            string str5 = "";  //人民币大写金额形式 
            int i;    //循环变量 
            int j;    //num的值乘以100的字符串长度 
            string ch1 = "";    //数字的汉语读法 
            string ch2 = "";    //数字位的汉字读法 
            int nzero = 0;  //用来计算连续的零值是几个 
            int temp;            //从原num值中取出的值 
            num = Math.Round(Math.Abs(num), 2);    //将num取绝对值并四舍五入取2位小数 
            str4 = ((long)(num * 100)).ToString();        //将num乘100并转换成字符串形式 
            j = str4.Length;      //找出最高位 
            if (j > 15) { return "溢出"; }
            str2 = str2.Substring(15 - j);   //取出对应位数的str2的值。如:200.55,j为5所以tr2=佰拾元角分 
            //循环取出每一位需要转换的值 
            for (i = 0; i < j; i++)
            {
                str3 = str4.Substring(i, 1);          //取出需转换的某一位的值 
                temp = Convert.ToInt32(str3);      //转换为数字 
                if (i != (j - 3) && i != (j - 7) && i != (j - 11) && i != (j - 15))
                {
                    //当所取位数不为元、万、亿、万亿上的数字时 
                    if (str3 == "0")
                    {
                        ch1 = "";
                        ch2 = "";
                        nzero = nzero + 1;
                    }
                    else
                    {
                        if (str3 != "0" && nzero != 0)
                        {
                            ch1 = "零" + str1.Substring(temp * 1, 1);
                            ch2 = str2.Substring(i, 1);
                            nzero = 0;
                        }
                        else
                        {
                            ch1 = str1.Substring(temp * 1, 1);
                            ch2 = str2.Substring(i, 1);
                            nzero = 0;
                        }
                    }
                }
                else
                {
                    //该位是万亿,亿,万,元位等关键位 
                    if (str3 != "0" && nzero != 0)
                    {
                        ch1 = "零" + str1.Substring(temp * 1, 1);
                        ch2 = str2.Substring(i, 1);
                        nzero = 0;
                    }
                    else
                    {
                        if (str3 != "0" && nzero == 0)
                        {
                            ch1 = str1.Substring(temp * 1, 1);
                            ch2 = str2.Substring(i, 1);
                            nzero = 0;
                        }
                        else
                        {
                            if (str3 == "0" && nzero >= 3)
                            {
                                ch1 = "";
                                ch2 = "";
                                nzero = nzero + 1;
                            }
                            else
                            {
                                if (j >= 11)
                                {
                                    ch1 = "";
                                    nzero = nzero + 1;
                                }
                                else
                                {
                                    ch1 = "";
                                    ch2 = str2.Substring(i, 1);
                                    nzero = nzero + 1;
                                }
                            }
                        }
                    }
                }
                if (i == (j - 11) || i == (j - 3))
                {
                    //如果该位是亿位或元位,则必须写上 
                    ch2 = str2.Substring(i, 1);
                }
                str5 = str5 + ch1 + ch2;
                if (i == j - 1 && str3 == "0")
                {
                    //最后一位(分)为0时,加上“整” 
                    str5 = str5 + '整';
                }
            }
            if (num == 0)
            {
                str5 = "零元整";
            }
            return str5;
        }
        #endregion
        /// 
        ///  去除选择框多选项中请选择
        /// 
        /// 
        /// 
        public static string[] RemoveDropDownListNull(string[] selectedValueArray)
        {
            List str = new List();
            foreach (var item in selectedValueArray)
            {
                if (item != BLL.Const._Null)
                {
                    str.Add(item);
                }
            }
            return str.ToArray();
        }
        public static string  GetStringByArray(string[] array)
        {
            string str = string.Empty;
            foreach (var item in array)
            {
                if (item != BLL.Const._Null)
                {
                    str += item + ",";
                }
            }
            if (!string.IsNullOrEmpty(str))
            {
                str = str.Substring(0, str.LastIndexOf(","));
            }
            return str;
        }
        /// 
        /// 将IEnumerable类型的集合转换为DataTable类型
        /// 
        /// 
        /// 
        /// 
        public static DataTable LINQToDataTable(IEnumerable varlist)
        {
            //定义要返回的DataTable对象
            DataTable dtReturn = new DataTable();
            // 保存列集合的属性信息数组
            PropertyInfo[] oProps = null;
            if (varlist == null) return dtReturn;//安全性检查
                                                 //循环遍历集合,使用反射获取类型的属性信息
            foreach (T rec in varlist)
            {
                //使用反射获取T类型的属性信息,返回一个PropertyInfo类型的集合
                if (oProps == null)
                {
                    oProps = ((Type)rec.GetType()).GetProperties();
                    //循环PropertyInfo数组
                    foreach (PropertyInfo pi in oProps)
                    {
                        Type colType = pi.PropertyType;//得到属性的类型
                                                       //如果属性为泛型类型
                        if ((colType.IsGenericType) && (colType.GetGenericTypeDefinition()
                        == typeof(Nullable<>)))
                        {   //获取泛型类型的参数
                            colType = colType.GetGenericArguments()[0];
                        }
                        //将类型的属性名称与属性类型作为DataTable的列数据
                        dtReturn.Columns.Add(new DataColumn(pi.Name, colType));
                    }
                }
                //新建一个用于添加到DataTable中的DataRow对象
                DataRow dr = dtReturn.NewRow();
                //循环遍历属性集合
                foreach (PropertyInfo pi in oProps)
                {   //为DataRow中的指定列赋值
                    dr[pi.Name] = pi.GetValue(rec, null) == null ?
                        DBNull.Value : pi.GetValue(rec, null);
                }
                //将具有结果值的DataRow添加到DataTable集合中
                dtReturn.Rows.Add(dr);
            }
            return dtReturn;//返回DataTable对象
        }
        /// 
        /// 在设定的数值内产生随机数的数量
        /// 
        /// 随机数的数量
        /// 随机数的最小值
        /// 随机数的最大值
        /// 
        public static int[] GetRandomNum(int num, int minValue, int maxValue)
        {
            if ((maxValue + 1 - minValue - num < 0))
                maxValue += num - (maxValue + 1 - minValue);
            Random ra = new Random(unchecked((int)DateTime.Now.Ticks));
            int[] arrNum = new int[num];
            int tmp = 0;
            StringBuilder sb = new StringBuilder(num * maxValue.ToString().Trim().Length);
            for (int i = 0; i <= num - 1; i++)
            {
                tmp = ra.Next(minValue, maxValue);
                while (sb.ToString().Contains("#" + tmp.ToString().Trim() + "#"))
                    tmp = ra.Next(minValue, maxValue + 1);
                arrNum[i] = tmp;
                sb.Append("#" + tmp.ToString().Trim() + "#");
            }
            return arrNum;
        }
        /// 
        /// 根据第一页和第二页行数及总记录数,确定需要打印几页
        /// 
        /// 第一页行数
        /// 第二页行数
        /// 总记录数
        /// 
        public static int GetPagesCountByPageSize(int pageSize1, int pageSize2, int count)
        {
            int pagesCount = 0;
            if (pageSize1 >= count)    //总记录数小于等于第一页行数
            {
                pagesCount = 1;
            }
            else if (count > pageSize1 && count <= (pageSize1 + pageSize2))   //总记录数大于第一页行数且小于等于第一页加第二页总行数
            {
                pagesCount = 2;
            }
            else    //总记录数大于第一页加第二页总行数
            {
                int lastCount = count - pageSize1;
                decimal c = Convert.ToDecimal(Math.Round(Convert.ToDecimal(lastCount) / Convert.ToDecimal(pageSize2), 2));
                if (c.ToString().IndexOf(".") > 0 && c.ToString().Substring(c.ToString().IndexOf("."), c.ToString().Length - c.ToString().IndexOf(".")) != ".00")
                {
                    string c1 = c.ToString().Substring(0, c.ToString().IndexOf("."));
                    pagesCount = Convert.ToInt32(c1) + 1;
                }
                else
                {
                    pagesCount = Convert.ToInt32(c);
                }
                pagesCount = pagesCount + 1;
            }
            return pagesCount;
        }
        /// 
        ///  根据分数判断是否合格
        /// 
        /// 
        public static string ReturnEvaluationResultByScore(decimal? score)
        {
            string value = string.Empty;
            if (score.HasValue)
            {
                if (score >= 80)
                {
                    value = "合格";
                }
                else if (score >= 71 && score <= 79)
                {
                    value = "基本合格";
                }
                else if (score <= 70)
                {
                    value = "不合格";
                }
            }
            return value;
        }
        /// 
        /// 时间戳转日期
        /// 
        /// 
        /// 
        public static DateTime IntToDateTime(long timestamp)
        {
            var date = TimeZone.CurrentTimeZone.ToLocalTime(new DateTime(1970, 1, 1));
            date = date.AddMilliseconds(timestamp);
            return date;
            //return TimeZone.CurrentTimeZone.ToLocalTime(new DateTime(1970, 1, 1)).AddSeconds(timestamp);
        }
        public static string RequestGet(string Baseurl, string Token)
        {
            ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;
            var client = new RestClient(Baseurl);
            client.Timeout = -1;
            var request = new RestRequest(Method.GET);
            request.AddHeader("token", Token);
            request.AddHeader("ClientId", SysConstSetService.ClientId);
            request.AddHeader("OperationCode", Baseurl.Substring(Baseurl.LastIndexOf("/", StringComparison.Ordinal) + 1));
            IRestResponse response = client.Execute(request);
            Console.WriteLine(response.Content);
            return response.Content;
        }
        public static string RequestPost(string Baseurl, string Token, string JsonBody)
        {
            ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;
            var client = new RestClient(Baseurl);
            client.Timeout = -1;
            var request = new RestRequest(Method.POST);
            request.AddHeader("token", Token);
            request.AddHeader("ClientId", SysConstSetService.ClientId);
            request.AddHeader("OperationCode", Baseurl.Substring(Baseurl.LastIndexOf("/", StringComparison.Ordinal) + 1));
            if (!string.IsNullOrEmpty(JsonBody))
            {
                request.AddJsonBody(JsonBody);
            }
            IRestResponse response = client.Execute(request);
            return response.Content;
        }
    }
}