在碰到一个登录加密的一个js
function encryptByAES(a, b) {
var c = CryptoJS.SHA1(b);
c = CryptoJS.SHA1(c).toString().substring(0, 32);
var d = CryptoJS.enc.Hex.parse(c)
, e = CryptoJS.AES.encrypt(a, d, {
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7
});
return e.ciphertext.toString()
}
a 是需要加密的密码,b 是key
直接用 execjs 去执行这个js 报错(execjs._exceptions.ProgramError: TypeError: 'CryptoJS' 未定义)
这个错误很明显缺少参数 那我们直接把这个参数的源码放到这个js 里
然后在把缺少的东西放到这个js里在执行这个js 就可以执行这个代码了。。
代码如下
import execjs
# 执行本地的js
with open('5.js', encoding='utf-8') as f:
jsdata_1 = f.read()
js_1 = execjs.compile(jsdata_1)
jschl_answer = js_1.call('encryptByAES','123456', "*****************") # 调用函数
print(jschl_answer)
最后得出结果
官网的加密结果
和我执行的js 一样 如果需要js 可以联系我。。