亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

使用 Crypto.JS 加密并使用 PHP 7.3 解密

使用 Crypto.JS 加密并使用 PHP 7.3 解密

PHP
慕桂英3389331 2023-06-18 17:13:55
我正在將我的代碼從 PHP 5.6 升級到 7.3,這是我的 Ionic 應用程序的 Woocommerce 插件。與此同時,我注意到 mcrypt_decrypt 在 PHP 7 中已被棄用。我試圖弄清楚如何更改我的代碼,但它仍然沒有返回相同的字符串。這是我在應用程序中的加密代碼:var password = this.password;if (this.appConfig.App_Secret != '') {  var key = CryptoJS.enc.Utf8.parse(CryptoJS.MD5(this.appConfig.App_Secret).toString());  var iv = CryptoJS.enc.Utf8.parse(CryptoJS.MD5(this.appConfig.App_Secret).toString().substr(0, 16));  password = CryptoJS.AES.encrypt(password, key, { iv: iv }).toString();}這是我在 PHP 中的舊解密代碼:$iv=substr(md5(get_option('sow_rest_api_secret')),0,16);$key = md5(get_option('sow_rest_api_secret'));$data = base64_decode($decrypt_str);$result = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, $data, MCRYPT_MODE_CBC, $iv);return rtrim($result,"\0");我使用 $result 變量更改行$result = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, $data, MCRYPT_MODE_CBC, $iv);到$result = openssl_decrypt($data, 'aes-128-gcm', $key, $options=OPENSSL_RAW_DATA, $iv);你能給予支持嗎?
查看完整描述

1 回答

?
藍山帝景

TA貢獻1843條經驗 獲得超7個贊


此外,MCRYPT_RIJNDAEL_256 不是 AES-256,它是 Rijndael 塊密碼的不同變體。如果你想在 mcrypt 中使用 AES-256,你必須使用帶有 32 字節密鑰的 MCRYPT_RIJNDAEL_128。OpenSSL 使您使用的模式更加明顯(即“aes-128-cbc”與“aes-256-ctr”)。

這意味著您之前一直在使用 AES-256,而不是 AES-128。

此外,正如@Topaco 正確指出的那樣,CryptoJS 默認使用 CBC 模式。

把這個放在一起:

$result?=?openssl_decrypt($data,?'aes-256-cbc',?$key,?$options=OPENSSL_RAW_DATA,?$iv);

應該給出與您之前的解決方案相同的結果mcrypt_decrypt。


查看完整回答
反對 回復 2023-06-18
  • 1 回答
  • 0 關注
  • 280 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號