首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Stanford Javascript Crypto Library (SJCL):如何构建sjcl.js并包含CBC模式

Stanford Javascript Crypto Library (SJCL):如何构建sjcl.js并包含CBC模式
EN

Stack Overflow用户
提问于 2014-10-30 04:55:31
回答 1查看 1.5K关注 0票数 0

我正在执行安装,但遇到了麻烦:

https://github.com/bitwiseshiftleft/sjcl/blob/version-0.8/README/INSTALL

代码语言:javascript
复制
npm install sjcl
pushd node_modules/sjcl; ./configure --without-all --with-aes --with-sha512 --with-cbc --with-codecHex && make; popd

这是上述配置和make命令的输出:

代码语言:javascript
复制
Enabled components:
  aes
  bitArray
  codecString
  codecHex
  sha512
  cbc

Compression: closure
cat core/sjcl.js core/aes.js core/bitArray.js core/codecString.js core/codecHex.js core/sha512.js core/cbc.js  > core.js
compress/compress_with_closure.sh core.js > core_closure.js
cp core_closure.js sjcl.js

看起来很完美,CBC也在名单里。此外,验证它是否包含在内:

代码语言:javascript
复制
egrep sjcl.mode.cbc node_modules/sjcl/sjcl.js 
...{sjcl.mode.cbc={name:"cbc",encrypt:...

太棒了。在我的代码中,我可以在sjcl中请求,但sjcl.mode.cbc是未定义的:

代码语言:javascript
复制
nodejs -e "sjcl=require('sjcl'); console.log(sjcl.mode);"
{}

这意味着模式变量没有附加任何内容。我希望看到cbc函数附加在那里,这样我就可以使用它了。如何引用和使用像encrypt这样的cbc函数

EN

回答 1

Stack Overflow用户

发布于 2014-11-01 23:31:11

必须在代码中手动启用cbc,方法是调用

代码语言:javascript
复制
sjcl.beware["CBC mode is dangerous because it doesn't protect message integrity."]()

https://github.com/bitwiseshiftleft/sjcl/issues/198#issuecomment-61111876

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

https://stackoverflow.com/questions/26640511

复制
相关文章

相似问题

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