【原创】C# IKVM加密解密机AES对称加密模式AES-128-ECB,补码方式 PKCS5Padding


  【原创】C# IKVM加密解密机AES对称加密模式AES-128-ECB,补码方式 PKCS5Padding
最近对接Haier海尔集团某子系统,对方后台接口基于JAVA语言开发的,部署在Apache服务器,而我们对接的客户系统是基于C#语言开发的,WebApi接口的数字签名采用AES对称加密算法,对比提供的JAVA源码,C#的AES加密算法差异巨大,加解密结果不一致!

搞了1天!!!

百度找到对应JAVA语言的AES算法-IKVM包。在NuGet,搜索 IKVM ,安装BuGet包。

贴图图片-ikvm



C# Code:


/// <summary>
/// AES加密
/// </summary>
/// <param name="content">明文</param>
/// <param name="sKey">密钥</param>
/// <param name="urlEncode">加密结果是否需要UrlEncoded</param>
/// <returns></returns>
public static string AES_Encrypt(string content, string sKey, bool urlEncode = false)
{
   KeyGenerator kgen = KeyGenerator.getInstance("AES");
   SecureRandom random = SecureRandom.getInstance("SHA1PRNG");
   random.setSeed(Encoding.UTF8.GetBytes(sKey));
   //random.setSeed(Encoding.ASCII.GetBytes(sKey));
   
   kgen.init(128, random);
   SecretKey secretKey = kgen.generateKey();
   byte[] enCodeFormat = secretKey.getEncoded();
   SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES");
   Cipher cipher = Cipher.getInstance("AES");// 创建密码器
   byte[] byteContent = Encoding.UTF8.GetBytes(content);
   cipher.init(Cipher.ENCRYPT_MODE, key);// 初始化
   
   byte[] encryptResult = cipher.doFinal(byteContent); //加密后接口
   
   //string result = Convert.ToBase64String(encryptResult, 0, encryptResult.Length);
   string result = Convert.ToBase64String(encryptResult);
   if (urlEncode)
   return java.net.URLEncoder.encode(java.net.URLEncoder.encode(result, "utf-8"), "utf-8");//进行url编码防止http传输过程出现异常
   else
   return result;
}

//来源:C/S框架网(www.csframework.com) QQ:23404761



C# Code:


/// <summary>
/// AES解密
/// </summary>
/// <param name="content">AES加密的文本</param>
/// <param name="sKey">密钥</param>
/// <param name="isUrlEncoded">AES加密的文本是否UrlEncoded</param>
/// <returns></returns>
public static string AES_Decrypt(string content, string sKey, bool isUrlEncoded = false)
{
   if (isUrlEncoded)
   content = java.net.URLDecoder.decode(java.net.URLDecoder.decode(content, "utf-8"), "utf-8");//进行url解码
   
   byte[] contentByte = Convert.FromBase64String(content);// 先用base64解密
   KeyGenerator kgen = KeyGenerator.getInstance("AES");
   SecureRandom random = SecureRandom.getInstance("SHA1PRNG");
   random.setSeed(Encoding.UTF8.GetBytes(sKey));
   
   kgen.init(128, random);
   SecretKey secretKey = kgen.generateKey();
   byte[] enCodeFormat = secretKey.getEncoded();
   SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES");
   Cipher cipher = Cipher.getInstance("AES");// 创建密码器
   cipher.init(Cipher.DECRYPT_MODE, key);// 初始化
   byte[] result = cipher.doFinal(contentByte);
   return System.Text.Encoding.UTF8.GetString(result);
}

//来源:C/S框架网(www.csframework.com) QQ:23404761



部署客户端依赖5个dll文件:

IKVM.OpenJDK.Core.dll
IKVM.OpenJDK.Security.dll
IKVM.OpenJDK.Tools.dll
IKVM.OpenJDK.Util.dll
IKVM.Runtime.dll



我们对接的后台采用WebApi架构:

.NET WebApi开发框架|MVC框架|后端框架|服务端框架


.NET WebApi开发框架|MVC框架|后端框架|服务端框架-标准版V1.0



版权声明:本文为开发框架文库发布内容,转载请附上原文出处连接
C/S框架网
上一篇:WebApi开发框架应用电商微信小程序成功案例
下一篇:WebApi后端框架服务端框架开发微信小程序订阅消息接口
评论列表

发表评论

评论内容
昵称:
关联文章

C# IKVM加密解密AES对称加密模式AES-128-ECB,补码方式 PKCS5Padding
KeyProvider.KeyProviderRijndael对称加密算法使用|开发框架加密工具
CSFrameworkV5.DemoTester测试加密解密工具
加密解密tb_DataSet/tb_MyUser表的密码|C/S框架网
关于C/S快速开发框架采用的文本加密解密策略|C/S框架网
C# Rijndael Encrypt加密/Decrypt解密算法
如何修改C/S框架默认的对称加密(Rijndael)密码?
登录账号的密码加密方式和数据库的加密一样的吗?
C#.NET史上最全字符串加密/解密/数字签名工具(CryptoHelper.cs)
WebApi接口使用HttpGet方式实现接受实体类参数()
CS系统三层架构扩展支持WCF及策略模式应用()
StrUtils类:字符串处理/加密解密函数库
C# MD5字符串文本加密
C#.Net B/S简单框架结构示例[]
C#.Net局域网版本自动升级解决方案()
基于标准三层逻辑扩展的C/S架构Winform开发平台()
C#框架推荐-C/S框架网快速开发平台系列产品
[]无线监控系统之二-------C#实现(续)
C/S架构开源软件 - C#.NET+Winform+Dev+SQL快速开发框架
MES系统框架及MES开源框架 | C/S框架网

热门标签
.NET5 .NET6 .NET7 APP Auth-软件授权注册系统 Axios B/S B/S开发框架 Bug Bug记录 C#加密解密 C#源码 C/S CHATGPT CMS系统 CodeGenerator CSFramework.DB CSFramework.EF CSFrameworkV1学习版 CSFrameworkV2标准版 CSFrameworkV3高级版 CSFrameworkV4企业版 CSFrameworkV5旗舰版 CSFrameworkV6.0 DAL数据访问层 Database datalock DbFramework Demo教学 Demo下载 DevExpress教程 DOM EF框架 Element-UI EntityFramework ERP ES6 Excel FastReport GIT HR IDatabase IIS JavaScript LINQ MES MiniFramework MIS NavBarControl Node.JS NPM OMS ORM PaaS POS Promise API Redis SAP SEO SQL SQLConnector TMS系统 Token令牌 VS2022 VSCode VUE WCF WebApi WebApi NETCore WebApi框架 WEB开发框架 Windows服务 Winform 开发框架 Winform 开发平台 WinFramework Workflow工作流 Workflow流程引擎 版本区别 报表 踩坑日记 操作手册 代码生成器 迭代开发记录 基础资料窗体 架构设计 角色权限 开发sce 开发技巧 开发教程 开发框架 开发平台 开发指南 客户案例 快速搭站系统 快速开发平台 秘钥 密钥 权限设计 软件报价 软件测试报告 软件简介 软件开发框架 软件开发平台 软件开发文档 软件体系架构 软件下载 软著证书 三层架构 设计模式 生成代码 实用小技巧 收钱音箱 数据锁 数据同步 微信小程序 未解决问题 文档下载 喜鹊ERP 喜鹊软件 系统对接 详细设计说明书 行政区域数据库 需求分析 疑难杂症 蝇量级框架 蝇量框架 用户管理 用户开发手册 用户控件 在线支付 纸箱ERP 智能语音收款机 自定义窗体 自定义组件 自动升级程序