苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper万能框架(V2.3-含.netcore) HttpHelper官方出品,无敌框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 最牛的爬虫类,没有爬不到只有想不到 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 700|回复: 2

[咨询站长] JS中的AES加密疑惑

[复制链接]
发表于 2019-8-4 03:10:55 | 显示全部楼层 |阅读模式
微信图片_20190804030314.png

调试JS,AES加密出来的值是:YYTpUInr2hxOghRzcrT/og==

我用C#模拟出来的值却是:6A3B212823087993CBB0736798C97B3A

网站上的AES加密文件的加密段落是这样的
[JavaScript] 纯文本查看 复制代码
/**
 * AES加密
 */
 
function encryptAES(src,aesEncryptsKey){

	src=src.replace(/\%/g,'*DBBFH*');
	//AES加密
    var key = CryptoJS.enc.Utf8.parse("1234567890123456");   
    var iv = CryptoJS.enc.Utf8.parse("1234567890123456");
	if(aesEncryptsKey!=null&&aesEncryptsKey!=undefined&&aesEncryptsKey.length==16){
		key = CryptoJS.enc.Utf8.parse(aesEncryptsKey);
	}
    var encrypted = CryptoJS.AES.encrypt(src, key, {iv:iv,mode:CryptoJS.mode.CBC,padding: CryptoJS.pad.Pkcs7}); 
//encrypted出来的值就已经是YYTpUInr2hxOghRzcrT/og==
    var maccval=encrypted.toString();
    return escape(maccval).replace(/\+/g, '%2B');
}




而我通过了网上说的“CryptoJS与C#AES加解密互转 ”这个文章去模拟,确实另外一种格式?

到底哪里有问题呢?对了,上面的文章是32位的KEY,

[C#] 纯文本查看 复制代码
 byte[] keyBytes = Encoding.UTF8.GetBytes(key.Substring(0, 32));

我改成了16位的
[C#] 纯文本查看 复制代码
 byte[] keyBytes = Encoding.UTF8.GetBytes(key.Substring(0, 16));


因为网站key传进去JS的AES加密是16位的KEY。。。




找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
发表于 2019-8-4 10:16:46 | 显示全部楼层
找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
发表于 2019-8-5 09:05:15 | 显示全部楼层
找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备17001017号-1)

GMT+8, 2020-1-18 21:05

© 2017-2018

快速回复 返回顶部 返回列表