U9系统admin用户账号密码生成Do方法

一直以为有一个不好的习惯,手上的问题不解决的话,项目便没有了进度。U9的密码生成的方法苦苦追寻了一个月,夜不能寐。回顾一下,屡屡都是这样,一个问题解决时,柳暗花明一般,各种解决方案层出不穷出来了!

总结一下,有以下3种方案。

1、第三方组件,ChilkatDotNet (这个组件是要收费的)。

private string GetUserPassword(string strUserPassword,string strSalt)

{

Chilkat.Crypt2 crypt = new Chilkat.Crypt2();

crypt.HashAlgorithm = "md5";

crypt.EncodingMode = "base64";

crypt.Charset = "Unicode";

//U9C加密方式:md5 + base64 + Unicode

string strMd5Password = crypt.HashStringENC(strUserPassword);

// MD5加盐加密 加密为32位MD5大写

if (string.IsNullOrEmpty(strMd5Password))

{

Common.MessageDxUtil.ShowTips("密码序列化处理返回为null,失败了...");

}

return MD5Util.GetMD5_32(strMd5Password + strSalt).ToUpper();

}

2、纯SQL脚本的实现

1、先对明文密码进行MD5加密(之前的加密方式);

2、增加二次加密验证:需要使用sql二次校验 var sql = string.Format("select id,name from Base_User where code ='{0}' and password=upper(substring(sys.fn_VarBinToHexStr(hashbytes('MD5', CAST('{1}' as varchar(50)) + convert(char(36),base_user.salt))),3,32))", code, password);//password为md5加密后的密码。

3、U9 BP接口的实现

引用 UFIDA.U9.Base.BaseBP.Agent.dll

public string GetU9PassWord(string PassWord)

{

if (PassWord == null)

throw new Exception("请求参数不能为空");

using (BPForEngine bp = new BPForEngine())

{

ContextDTO cdto = new ContextDTO();//用友自定义的DTO类

cdto.EntCode = "100";

cdto.OrgCode = "100";

cdto.UserCode = "admin";

cdto.CultureName = "zh-CN";

cdto.WriteToContext();//重写u9的上下文

EncryptBPProxy encryptBPProxy = new EncryptBPProxy();

encryptBPProxy.Source = PassWord;

string strPWD = encryptBPProxy.Do();//zgv9FQWbaNZ2iIhNej0+jA==

string strSalt = "627C40BC-43E8-4EC2-B02F-26662114FB80";

strPWD=GetMD5_32(strPWD + strSalt).ToUpper();

return strPWD;

}

}

相关推荐
张忠琳3 分钟前
【Go 1.26.4】Golang Map 深度解析
开发语言·后端·golang
Vertira3 分钟前
如何对QT开发的软件进行打包[已解决]
开发语言·qt
AI人工智能+电脑小能手5 分钟前
【大白话说Java面试题 第110题】【并发篇】第10题:CAS 存在哪些问题?
java·开发语言·面试
石一峰69913 分钟前
C 语言函数设计模式实战经验
c语言·开发语言·设计模式
sitellla20 分钟前
Pydub:用 Python 处理音频,不写废话
开发语言·python·其他·音视频
xingyuzhisuan28 分钟前
缓存命中率提升方案:从 30% 优化至 82% 全流程优化记录
java·开发语言·缓存·ai
郑洁文33 分钟前
基于Python的恶意流量监测系统的设计与实现
开发语言·python
AI玫瑰助手36 分钟前
Python流程控制:for循环与range函数的搭配使用
开发语言·python·信息可视化
anew___38 分钟前
2026年Python爬虫技术完全指南:从入门到实战
开发语言·爬虫·python
Penfy_Z40 分钟前
【Python LLM 调用踩坑】Connection error 终极解决方案!npm 代理导致阿里云通义千问接口连接失败
开发语言·python·npm