You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
192 lines
7.3 KiB
192 lines
7.3 KiB
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Security.Cryptography;
|
|
using System.Text;
|
|
|
|
namespace ICSSoft.FromERP
|
|
{
|
|
|
|
public class SRMUser
|
|
{
|
|
static string conStr = ICSHelper.GetConnectString();
|
|
public static void User()
|
|
{
|
|
string sqlUser = "";
|
|
string NewGuid = GuId();
|
|
sqlUser = @"INSERT INTO dbo.Sys_SRM_User
|
|
( F_Id ,F_Account ,F_RealName ,F_NickName ,
|
|
F_RoleId ,F_IsAdministrator , F_EnabledMark ,
|
|
F_CreatorTime ,F_CreatorUserId ,F_Location ,
|
|
F_VenCode)
|
|
SELECT NEWID(),a.VenCode,a.VenName,a.VenName,
|
|
'2691AB91-3010-465F-8D92-60A97425A45E',0,1,
|
|
GETDATE(),'9f2ec079-7d0f-4fe2-90ab-8b09a8302aba','6000',''
|
|
FROM dbo.ICSVendor a
|
|
Left join Sys_SRM_User b on a.VenCode=b.F_Account
|
|
where a.VenCode is null
|
|
";
|
|
try
|
|
{
|
|
ICSHelper.ExecuteDate(conStr,sqlUser);
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Exception(ex.Message);
|
|
}
|
|
string UserSecretkey = Md5.md5(CreateNo(), 16).ToLower();
|
|
string pwd = Md5.md5(DESEncrypt.Encrypt(Md5.md5("123456", 32).ToLower(), UserSecretkey).ToLower(), 32).ToLower();
|
|
sqlUser = @"INSERT INTO dbo.Sys_SRM_UserLogOn
|
|
( F_Id ,F_UserId ,F_UserPassword ,F_UserSecretkey )
|
|
SELECT a.F_Id,a.F_Id,'" + pwd + "','" + UserSecretkey + "'from Sys_SRM_User a left join Sys_SRM_UserLogOn b on a.F_Id=b.F_Id where a.F_Id is null ";
|
|
|
|
|
|
try
|
|
{
|
|
ICSHelper.ExecuteDate(conStr, sqlUser);
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Exception(ex.Message);
|
|
}
|
|
}
|
|
#region 自动生成编号
|
|
/// <summary>
|
|
/// 表示全局唯一标识符 (GUID)。
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public static string GuId()
|
|
{
|
|
return Guid.NewGuid().ToString();
|
|
}
|
|
#endregion
|
|
/// <summary>
|
|
/// 自动生成编号 201008251145409865
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public static string CreateNo()
|
|
{
|
|
Random random = new Random();
|
|
string strRandom = random.Next(1000, 10000).ToString(); //生成编号
|
|
string code = DateTime.Now.ToString("yyyyMMddHHmmss") + strRandom;//形如
|
|
return code;
|
|
}
|
|
|
|
/// <summary>
|
|
/// MD5加密
|
|
/// </summary>
|
|
public class Md5
|
|
{
|
|
/// <summary>
|
|
/// MD5加密
|
|
/// </summary>
|
|
/// <param name="str">加密字符</param>
|
|
/// <param name="code">加密位数16/32</param>
|
|
/// <returns></returns>
|
|
public static string md5(string str, int code)
|
|
{
|
|
string strEncrypt = string.Empty;
|
|
if (code == 16)
|
|
{
|
|
strEncrypt = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(str, "MD5").Substring(8, 16);
|
|
}
|
|
|
|
if (code == 32)
|
|
{
|
|
strEncrypt = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(str, "MD5");
|
|
}
|
|
|
|
return strEncrypt;
|
|
}
|
|
}
|
|
public class DESEncrypt
|
|
{
|
|
private static string DESKey = "nfine_desencrypt_2016";
|
|
|
|
#region ========加密========
|
|
/// <summary>
|
|
/// 加密
|
|
/// </summary>
|
|
/// <param name="Text"></param>
|
|
/// <returns></returns>
|
|
public static string Encrypt(string Text)
|
|
{
|
|
return Encrypt(Text, DESKey);
|
|
}
|
|
/// <summary>
|
|
/// 加密数据
|
|
/// </summary>
|
|
/// <param name="Text"></param>
|
|
/// <param name="sKey"></param>
|
|
/// <returns></returns>
|
|
public static string Encrypt(string Text, string sKey)
|
|
{
|
|
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
|
|
byte[] inputByteArray;
|
|
inputByteArray = Encoding.Default.GetBytes(Text);
|
|
des.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8));
|
|
des.IV = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8));
|
|
System.IO.MemoryStream ms = new System.IO.MemoryStream();
|
|
CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);
|
|
cs.Write(inputByteArray, 0, inputByteArray.Length);
|
|
cs.FlushFinalBlock();
|
|
StringBuilder ret = new StringBuilder();
|
|
foreach (byte b in ms.ToArray())
|
|
{
|
|
ret.AppendFormat("{0:X2}", b);
|
|
}
|
|
return ret.ToString();
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region ========解密========
|
|
/// <summary>
|
|
/// 解密
|
|
/// </summary>
|
|
/// <param name="Text"></param>
|
|
/// <returns></returns>
|
|
public static string Decrypt(string Text)
|
|
{
|
|
if (!string.IsNullOrEmpty(Text))
|
|
{
|
|
return Decrypt(Text, DESKey);
|
|
}
|
|
else
|
|
{
|
|
return "";
|
|
}
|
|
}
|
|
/// <summary>
|
|
/// 解密数据
|
|
/// </summary>
|
|
/// <param name="Text"></param>
|
|
/// <param name="sKey"></param>
|
|
/// <returns></returns>
|
|
public static string Decrypt(string Text, string sKey)
|
|
{
|
|
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
|
|
int len;
|
|
len = Text.Length / 2;
|
|
byte[] inputByteArray = new byte[len];
|
|
int x, i;
|
|
for (x = 0; x < len; x++)
|
|
{
|
|
i = Convert.ToInt32(Text.Substring(x * 2, 2), 16);
|
|
inputByteArray[x] = (byte)i;
|
|
}
|
|
des.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8));
|
|
des.IV = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8));
|
|
System.IO.MemoryStream ms = new System.IO.MemoryStream();
|
|
CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);
|
|
cs.Write(inputByteArray, 0, inputByteArray.Length);
|
|
cs.FlushFinalBlock();
|
|
return Encoding.Default.GetString(ms.ToArray());
|
|
}
|
|
|
|
#endregion
|
|
}
|
|
|
|
}
|
|
|
|
}
|