您的位置:

cryptojs参数的简单介绍

cryptojs参数的简单介绍

更新:

本文目录一览:

为什么 CryptoJS DES 加密的结果和 Java DES 不一样

最近需要对数据进行加密/解密, 因此选用了CryptoJS库, 对数据做DES算法的加密/解密

首选查看官方示例, 将密文进行Base64编码, 掉进一个大坑

script src="htt p:/ /crypto-js.googlecod e.c om/svn/tags/3.1.2/build/rollups/tripledes.js"/script

script

var encrypted = CryptoJS.DES.encrypt("Message", "Secret Passphrase");

// ciphertext changed every time you run it

// 加密的结果不应该每次都是一样的吗?

console.log(encrypted.toString(), encrypted.ciphertext.toString(CryptoJS.enc.Base64));

var decrypted = CryptoJS.DES.decrypt(encrypted, "Secret Passphrase");

console.log(decrypted.toString(CryptoJS.enc.Utf8));

/script

对这些加密算法不了解, 只能求助Google

des encrypion: js encrypted value does not match the java encrypted value

In cryptoJS you have to convert the key to hex and useit as word just like above (otherwise it will be considered as passphrase)

For the key, when you pass a string, it's treated as a passphrase and used to derive an actual key and IV. Or you can pass a WordArray that represents the actual key.

原来是我指定key的方式不对, 直接将字符串做为参数, 想当然的以为这就是key, 其实不然, CryptoJS会根据这个字符串算出真正的key和IV(各种新鲜名词不解释, 问我也没用, 我也不懂 -_-")

那么我们只需要将key和iv对应的字符串转成CryptoJS的WordArray类型, 在DES加密时做为参数传入即可, 这样对Message这个字符串加密, 每次得到的密文都是YOa3le0I+dI=

var keyHex = CryptoJS.enc.Utf8.parse('abcd1234');

var ivHex = CryptoJS.enc.Utf8.parse('inputvec');

var encrypted = CryptoJS.DES.encrypt('Message', keyHex, { iv: ivHex });

这样是不是就万事OK了? 哪有, 谁知道这坑是一个接一个啊.

我们再试试Java这边的DES加密是不是和这个结果一样, 具体实现请参考Simple Java Class to DES Encrypt Strings

果真掉坑里了, Java通过DES加密Message这个字符串得到的结果是8dKft9vkZ4I=和CryptoJS算出来的不一样啊...亲

继续求助Google

C# and Java DES Encryption value are not identical

SunJCE provider uses ECB as the default mode, and PKCS5Padding as the default padding scheme for DES.(JCA Doc)

This means that in the case of the SunJCE provider,

Cipher c1 = Cipher.getInstance("DES/ECB/PKCS5Padding");

and

Cipher c1 = Cipher.getInstance("DES");

are equivalent statements.

原来是CryptoJS进行DES加密时, 默认的模式和padding方式和Java默认的不一样造成的, 必须使用ECB mode和PKCS5Padding, 但是CryptoJS中只有Pkcs7, 不管了, 试试看...

script src="htt p:/ /crypto-js.googleco de.c om/svn/tags/3.1.2/build/rollups/tripledes.js"/script

script src="ht tp:/ /crypto-js.googleco de.c om/svn/tags/3.1.2/build/components/mode-ecb.js"/script

script

var keyHex = CryptoJS.enc.Utf8.parse('abcd1234');

var encrypted = CryptoJS.DES.encrypt('Message', keyHex, {

mode: CryptoJS.mode.ECB,

padding: CryptoJS.pad.Pkcs7

});

console.log(encrypted.toString(), encrypted.ciphertext.toString(CryptoJS.enc.Base64));

/script

咦...使用Pkcs7能得到和Java DES一样的结果了, 哇塞...好神奇

那我们试试统一Java也改成Cipher.getInstance("DES/ECB/PKCS7Padding")试试, 结果得到一个大大的错误

Error:java.security.NoSuchAlgorithmException: Cannot find any provider supporting DES/ECB/PKCS7Padding

没办法, 继续Google

java.security.NoSuchAlgorithmException: Cannot find any provider supporting AES/ECB/PKCS7PADDING

I will point out that PKCS#5 and PKCS#7 actually specify exactly the same type of padding (they are the same!), but it's called #5 when used in this context. :)

这位大侠给出的解释是: PKCS#5和PKCS#7是一样的padding方式, 对加密算法一知半解, 我也只能暂且认可这个解释了.

忙完了DES的加密, 接下来就是使用CryptoJS来解密了. 我们需要直接解密DES加密后的base64密文字符串. CryptoJS好像没有提供直接解密DES密文字符串的方法啊, 他的整个加密/解密过程都是内部自己在玩, 解密时需要用到加密的结果对象, 这不是坑我吗?

只好研究下CryptoJS DES加密后返回的对象, 发现有一个属性ciphertext, 就是密文的WordArray, 那么解密的时候, 我们是不是只要提供这个就行了呢?

var keyHex = CryptoJS.enc.Utf8.parse('abcd1234');

// direct decrypt ciphertext

var decrypted = CryptoJS.DES.decrypt({

ciphertext: CryptoJS.enc.Base64.parse('8dKft9vkZ4I=')

}, keyHex, {

mode: CryptoJS.mode.ECB,

padding: CryptoJS.pad.Pkcs7

});

console.log(decrypted.toString(CryptoJS.enc.Utf8));

果不其然, 到此为止, 问题全部解决, 豁然开朗...

完整代码请参考CryptoJS-DES.html

Use CryptoJS encrypt message by DES and direct decrypt ciphertext, compatible with Java Cipher.getInstance("DES")

怎么把mysql数据库中现有的数据进行des加密,加密后的结果和java中des加密的结果一样。

最近需要对数据进行加密/解密, 因此选用了CryptoJS库, 对数据做DES算法的加密/解密

首选查看官方示例, 将密文进行Base64编码, 掉进一个大坑

script src="htt p:/ /crypto-js.googlecod e.c om/svn/tags/3.1.2/build/rollups/tripledes.js"/script

script

var encrypted = CryptoJS.DES.encrypt("Message", "Secret Passphrase");

// ciphertext changed every time you run it

// 加密的结果不应该每次都是一样的吗?

console.log(encrypted.toString(), encrypted.ciphertext.toString(CryptoJS.enc.Base64));

var decrypted = CryptoJS.DES.decrypt(encrypted, "Secret Passphrase");

console.log(decrypted.toString(CryptoJS.enc.Utf8));

/script

对这些加密算法不了解, 只能求助Google

des encrypion: js encrypted value does not match the java encrypted value

In cryptoJS you have to convert the key to hex and useit as word just like above (otherwise it will be considered as passphrase)

For the key, when you pass a string, it's treated as a passphrase and used to derive an actual key and IV. Or you can pass a WordArray that represents the actual key.

原来是我指定key的方式不对, 直接将字符串做为参数, 想当然的以为这就是key, 其实不然, CryptoJS会根据这个字符串算出真正的key和IV(各种新鲜名词不解释, 问我也没用, 我也不懂 -_-")

那么我们只需要将key和iv对应的字符串转成CryptoJS的WordArray类型, 在DES加密时做为参数传入即可, 这样对Message这个字符串加密, 每次得到的密文都是YOa3le0I+dI=

var keyHex = CryptoJS.enc.Utf8.parse('abcd1234');

var ivHex = CryptoJS.enc.Utf8.parse('inputvec');

var encrypted = CryptoJS.DES.encrypt('Message', keyHex, { iv: ivHex });

这样是不是就万事OK了? 哪有, 谁知道这坑是一个接一个啊.

我们再试试Java这边的DES加密是不是和这个结果一样, 具体实现请参考Simple Java Class to DES Encrypt Strings

果真掉坑里了, Java通过DES加密Message这个字符串得到的结果是8dKft9vkZ4I=和CryptoJS算出来的不一样啊...亲

继续求助Google

C# and Java DES Encryption value are not identical

SunJCE provider uses ECB as the default mode, and PKCS5Padding as the default padding scheme for DES.(JCA Doc)

This means that in the case of the SunJCE provider,

Cipher c1 = Cipher.getInstance("DES/ECB/PKCS5Padding");

and

Cipher c1 = Cipher.getInstance("DES");

are equivalent statements.

原来是CryptoJS进行DES加密时, 默认的模式和padding方式和Java默认的不一样造成的, 必须使用ECB mode和PKCS5Padding, 但是CryptoJS中只有Pkcs7, 不管了, 试试看...

script src="htt p:/ /crypto-js.googleco de.c om/svn/tags/3.1.2/build/rollups/tripledes.js"/script

script src="ht tp:/ /crypto-js.googleco de.c om/svn/tags/3.1.2/build/components/mode-ecb.js"/script

script

var keyHex = CryptoJS.enc.Utf8.parse('abcd1234');

var encrypted = CryptoJS.DES.encrypt('Message', keyHex, {

mode: CryptoJS.mode.ECB,

padding: CryptoJS.pad.Pkcs7

});

console.log(encrypted.toString(), encrypted.ciphertext.toString(CryptoJS.enc.Base64));

/script

咦...使用Pkcs7能得到和Java DES一样的结果了, 哇塞...好神奇

那我们试试统一Java也改成Cipher.getInstance("DES/ECB/PKCS7Padding")试试, 结果得到一个大大的错误

Error:java.security.NoSuchAlgorithmException: Cannot find any provider supporting DES/ECB/PKCS7Padding

没办法, 继续Google

java.security.NoSuchAlgorithmException: Cannot find any provider supporting AES/ECB/PKCS7PADDING

I will point out that PKCS#5 and PKCS#7 actually specify exactly the same type of padding (they are the same!), but it's called #5 when used in this context. :)

这位大侠给出的解释是: PKCS#5和PKCS#7是一样的padding方式, 对加密算法一知半解, 我也只能暂且认可这个解释了.

忙完了DES的加密, 接下来就是使用CryptoJS来解密了. 我们需要直接解密DES加密后的base64密文字符串. CryptoJS好像没有提供直接解密DES密文字符串的方法啊, 他的整个加密/解密过程都是内部自己在玩, 解密时需要用到加密的结果对象, 这不是坑我吗?

只好研究下CryptoJS DES加密后返回的对象, 发现有一个属性ciphertext, 就是密文的WordArray, 那么解密的时候, 我们是不是只要提供这个就行了呢?

var keyHex = CryptoJS.enc.Utf8.parse('abcd1234');

// direct decrypt ciphertext

var decrypted = CryptoJS.DES.decrypt({

ciphertext: CryptoJS.enc.Base64.parse('8dKft9vkZ4I=')

}, keyHex, {

mode: CryptoJS.mode.ECB,

padding: CryptoJS.pad.Pkcs7

});

console.log(decrypted.toString(CryptoJS.enc.Utf8));

果不其然, 到此为止, 问题全部解决, 豁然开朗...

完整代码请参考CryptoJS-DES.html

Use CryptoJS encrypt message by DES and direct decrypt ciphertext, compatible with Java Cipher.getInstance("DES")

微信小程序怎样加密

1.下载一份Js版的aesUtil.js源码。【注:文章末尾会贴出所有的相关类文件】

2.下载一份Js版的md

5.js源码。

3.在pulic.js中进行加解密操作代码如下,其中秘钥和秘钥偏移量要与后台的一致。var CryptoJS = require('aesUtil.js'); //引用...

4.在网络请求帮助类中进行参数的加密和返回数据的解密操作。var aes = require...

关于腾讯云短信接口的sig字段,sha256加密问题,nodejs

按照我下面的写法哈:

const crypto = require('crypto');

function sig()

{

    var strMobile = "这里是我的手机"; //tel的mobile字段的内容

    var strAppKey = "这里是我的key"; //sdkappid对应的appkey,需要业务方高度保密

    var strRand = "7226249334"; //url中的random字段的值

    var strTime = "1457336869"; //unix时间戳

    var buf = "appkey="+strAppKey+"random="+strRand+"time="

            +strTime+"mobile="+strMobile;

    var sig = crypto.createHash('sha256').update(buf, 'utf-8').digest('hex');

    return sig;

}

console.log(sig());

输出结果如下:

7b1e97051886abdbd66c684530db2ba01644f828f31e06d624d88aff5469faa0

原因就是文档里面强调了编码要使用 utf-8,而 js 默认编码不是这个,所以需要强制指定下。

另外这个 sig 的计算结果是和你的输出参数有关的,并不是不变的。

还有就是你的 mobile 和 appkey 怎么传递的都是中文,官方给的貌似都是数字和字母呃。

cryptojs参数的简单介绍

本文目录一览: 1、为什么 CryptoJS DES 加密的结果和 Java DES 不一样 2、怎么把mysql数据库中现有的数据进行des加密,加密后的结果和java中des加密的结果一样。 3、

2023-12-08
cryptojs.aes.decrypt的简单介绍

本文目录一览: 1、有关使用CryptoJS的AES方法进行加密和解密,后台获取前端生成的公钥进行AES加密。前端js如何使用私钥解密 2、前端使用CryptoJS AES加密 ,后端php解密问题

2023-12-08
cryptojs和后台的简单介绍

本文目录一览: 1、前端使用CryptoJS AES加密 ,后端php解密问题 2、前端JS AES加密 后端PHP AES加解密 3、如何使用CryptoJS的AES方法进行加密和解密 4、有关使用

2023-12-08
cryptojsc的简单介绍

2022-11-25
cryptojs.pad的简单介绍

本文目录一览: 1、如何使用CryptoJS的AES方法进行加密和解密 2、前端JS AES加密 后端PHP AES加解密 3、为什么 CryptoJS DES 加密的结果和 Java DES 不一样

2023-12-08
cryptojspkcs5,CryptoJs

本文目录一览: 1、如何使用CryptoJS的AES方法进行加密和解密 2、CryptoJS的AES方法密钥安全问题 3、为什么 CryptoJS DES 加密的结果和 Java DES 不一样 4、

2023-12-08
crypto.js怎么用,cryptojs详解

2022-11-25
javascript入门笔记1的简单介绍

2022-11-18
python使用笔记23的简单介绍

2022-11-10
cryptojsvue解密(cryptojs详解)

本文目录一览: 1、为什么 CryptoJS DES 加密的结果和 Java DES 不一样 2、如何使用CryptoJS的AES方法进行加密和解密 3、【uniapp】Vue.js CryptoJs

2023-12-08
cryptojsv3.1.2,CryptoJS文档

本文目录一览: 1、怎么把mysql数据库中现有的数据进行des加密,加密后的结果和java中des加密的结果一样。 2、同样的字符串,通过MD5出来的结果怎么不一样 3、前端JS AES加密 后端P

2023-12-08
使用CryptoJS AES进行JavaScript数据加密

2023-05-17
8eh4njs的简单介绍

2023-01-09
javascript简要笔记,JavaScript读书笔记

2022-11-17
关于cryptojs加密长度的信息

本文目录一览: 1、怎么调用JS中的CryptoJS.HmacSHA256加密方法 2、crypto-js aes怎么用 3、有关使用CryptoJS的AES方法进行加密和解密,后台获取前端生成的公钥

2023-12-08
cryptojsvue的简单介绍

本文目录一览: 1、求大神指导,有没有前端学习视频,自己找了好多,感觉有点乱,觉得学的路线会错 2、vue+typescript如何使用crypto-js 3、vue.js 怎么设置md5加密? 4、

2023-12-08
phpencryptdecodeiv必须一致吗的简单介绍

2022-12-01
印象笔记记录java学习(Java成长笔记)

2022-11-12
htmljs编程笔记(html代码笔记)

本文目录一览: 1、html代码和JS代码有什么区别 2、如何在html中调用js函数 3、JavaScript学习笔记之数组基本操作示例 4、HTML5初学者笔记 5、《web前端笔记7》js字符—

2023-12-08
cryptojsaes解密,cryptojs aes加密

本文目录一览: 1、前端JS AES加密 后端PHP AES加解密 2、小程序AES加密、解密 3、crypto-js aes怎么用 4、CryptoJS 5、如何使用CryptoJS的AES方法进行

2023-12-08