首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在浏览器中使用节点与CryptoJS之间的AES加密时的问题

在浏览器中使用节点与CryptoJS之间的AES加密时的问题
EN

Stack Overflow用户
提问于 2015-11-26 10:23:34
回答 1查看 3.2K关注 0票数 0

我希望用Node加密字符串,并在浏览器中用CryptoJS解密字符串。

加密:

代码语言:javascript
复制
var crypto = require('crypto');

function encrypt(txt, cryptkey) {
    var cipher = crypto.createCipher('aes-256-cbc', cryptkey);
    var crypted = cipher.update(txt, 'utf8', 'hex');
    crypted += cipher.final('hex');
    return crypted;
}

encrypt('1', 'key'); // 83684beb6c8cf063caf45cb7fad04a50

包括:

代码语言:javascript
复制
<script src="http://crypto-js.googlecode.com/svn/tags/3.1.2/build/rollups/aes.js"></script>

解密:

代码语言:javascript
复制
var decrypted = CryptoJS.AES.decrypt('83684beb6c8cf063caf45cb7fad04a50', 'key');
console.log(decrypted.toString(CryptoJS.enc.Utf8)); // empty string

实际结果是空字符串。

从节点解密数据的正确方法是什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-11-26 15:54:10

CryptoJS支持与node.js中的密码模块相同的基于密码的加密模式,该模式的实现与EVP_BytesToKey等效。默认情况下,CryptoJS生成随机盐,但node.js不生成并且使用空盐。空盐不好,不应该用。此外,使用此方法从密码派生密钥也是不安全的。需要使用PBKDF2 (由CryptoJS和node.js支持)或类似的方法,包括大量迭代和随机盐。

代码语言:javascript
复制
var ctHex = '83684beb6c8cf063caf45cb7fad04a50';
var ct = CryptoJS.enc.Hex.parse(ctHex);
var salt = CryptoJS.lib.WordArray.create(0); // empty array
var decrypted = CryptoJS.AES.decrypt({ciphertext: ct, salt: salt}, 'key');

document.querySelector("#dec").innerHTML = decrypted.toString(CryptoJS.enc.Utf8);
代码语言:javascript
复制
<script src="https://cdn.rawgit.com/CryptoStore/crypto-js/3.1.2/build/rollups/aes.js"></script>
Expected: "1"<br/>Got: "<span id="dec"></span>"

您说过这将通过HTTP完成。

如果您想在不需要用户干预的情况下使用传输安全,那么这是完全不安全的,因为密钥需要与密文一起传输,这样做充其量就是混淆。

如果用户和服务器在通信之前都知道密码,那么这仍然是不够的,因为CryptoJS和node.js提供的密钥派生是不够的,必须使用类似PBKDF2的内容。MD5很容易被强暴.

您需要使用非对称加密来保护此通信免受被动攻击者的攻击(不能将任意数据包注入服务器和客户端之间的流)。我建议您生成一个RSA密钥对,并将公钥发送给客户端,以便客户端可以将消息加密到服务器。为此您可以使用锻造

加密将如下所示:

代码语言:javascript
复制
var salt = CryptoJS.lib.WordArray.create(0); // empty array
var params = CryptoJS.kdf.OpenSSL.execute('key', 256/32, 128/32, salt);
var pt = '1';
var encrypted = CryptoJS.AES.encrypt(pt, params.key, {iv: params.iv});

document.querySelector("#enc").innerHTML = encrypted.ciphertext.toString();
代码语言:javascript
复制
<script src="https://cdn.rawgit.com/CryptoStore/crypto-js/3.1.2/build/rollups/aes.js"></script>
Expected: "83684beb6c8cf063caf45cb7fad04a50"<br/>Got: "<span id="enc"></span>"

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33936092

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档