我正在使用API进行一些加密,并且在CryptoJS
中使用openssl_decrypt
和PHP
进行AES加密时遇到了一些问题。
JS
var key = "B-LOGIN",
iv = "c5b8cfc6992807e2c78a8cda6193bca1",
json = JSON.stringify({email : "example@example.com", password: "123456", "domainUrl" : "http://www.example.com/"}),
enc = CryptoJS.AES.encrypt(
JSON.stringify({email : "example@example.com", password: "123456", "domainUrl" : "http://www.example.com/"}),
CryptoJS.enc.Utf8.parse(key),
{ iv: CryptoJS.enc.Utf8.parse(iv.substring(0, 16)) }
);
console.log( enc.ciphertext.toString() ); // b53284ed65e1810b7250e2760d10f3be2b31e188f356dd36da5e906c59bea877b2cd322cfb1228035c4a06920e2504657beaa2440c94f5ff7dd6485be7b7bbd82d5e91f22d64c98322a47b0413d4b724b0e2cbf2314472b6f72b4e19a5e44052
PHP
对于在php中解密,我具有以下代码,并且在$rawText
中给了我一个错误。
$iv = "c5b8cfc6992807e2";
$str = "b53284ed65e1810b7250e2760d10f3be2b31e188f356dd36da5e906c59bea877b2cd322cfb1228035c4a06920e2504657beaa2440c94f5ff7dd6485be7b7bbd82d5e91f22d64c98322a47b0413d4b724b0e2cbf2314472b6f72b4e19a5e44052";
$rawText = openssl_decrypt( $str,'aes-128-cbc' , 'B-LOGIN', 0, (strlen($iv) > 16 ? substr($iv, 0 ,16) : $iv) ); // close
我认为CryptoJS
以十六进制格式给出响应。
谢谢。