日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > php >内容正文

php

php mcrypt取消,php – Mcrypt弃用后如何解密?

發(fā)布時(shí)間:2025/3/15 php 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php mcrypt取消,php – Mcrypt弃用后如何解密? 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

我已將我的php版本更新為7.1.

我有使用mcrypt加密數(shù)據(jù)的功能.

現(xiàn)在不推薦使用此功能.

無論如何我都可以通過回到舊版本的php來解密數(shù)據(jù).

這是我使用的代碼:

public function encrypt($plaintext) {

$ivSize = mcrypt_get_iv_size(self::CIPHER, self::MODE);

$iv = mcrypt_create_iv($ivSize, MCRYPT_DEV_URANDOM);

$ciphertext = mcrypt_encrypt(self::CIPHER, $this->key, $plaintext, self::MODE, $iv);

return base64_encode($iv.$ciphertext);

}

public function decrypt($ciphertext) {

$ciphertext = base64_decode($ciphertext);

$ivSize = mcrypt_get_iv_size(self::CIPHER, self::MODE);

if (strlen($ciphertext) < $ivSize) {

throw new Exception('Missing initialization vector');

}

$iv = substr($ciphertext, 0, $ivSize);

$ciphertext = substr($ciphertext, $ivSize);

$plaintext = mcrypt_decrypt(self::CIPHER, $this->key, $ciphertext, self::MODE, $iv);

return rtrim($plaintext, "\0");

}

使用常量:

const CIPHER = MCRYPT_RIJNDAEL_128; // Rijndael-128 is AES

const MODE = MCRYPT_MODE_CBC;

我看到建議使用OpenSSL.這是我將從現(xiàn)在開始使用的.但是如何使用此方法解密舊數(shù)據(jù)?

謝謝

編輯:

我知道我可以使用OpenSSL作為替代方案.

這就是我從現(xiàn)在開始為內(nèi)容做的事情.

但是我需要從舊內(nèi)容中解密我的加密代碼.

*編輯請求@symcbean

嘗試用OpenSSL解密如下:

public function decrypt($ciphertext) {

$ciphertext = base64_decode($ciphertext);

if (!function_exists("openssl_decrypt")) {

throw new Exception("aesDecrypt needs openssl php module.");

}

$key = $this->key;

$method = 'AES-256-CBC';

$ivSize = openssl_cipher_iv_length($method);

$iv = substr($ciphertext,0,$ivSize);

$data = substr($ciphertext,$ivSize);

$clear = openssl_decrypt ($data, $method, $key, 'OPENSSL_RAW_DATA'|'OPENSSL_ZERO_PADDING', $iv);

return $clear;

}

最佳答案 需要注意的重要一點(diǎn)是,如果它不是塊大小的倍數(shù),則

mcrypt_encrypt零填充輸入數(shù)據(jù).如果數(shù)據(jù)本身具有尾隨零,則會(huì)導(dǎo)致模糊結(jié)果.

openssl_decrypt不會(huì)自動(dòng)刪除零填充,因此您只能留下修剪尾隨空值的可能性.

這是一個(gè)簡單的例子:

$data = "Lorem ipsum";

$key = "1234567890abcdef";

$iv = "1234567890abcdef";

$encrypted = mcrypt_encrypt(

MCRYPT_RIJNDAEL_128, $key, $data, MCRYPT_MODE_CBC, $iv);

echo bin2hex($encrypted) . "\n";

$decrypted = openssl_decrypt(

$encrypted, "AES-128-CBC", $key,

OPENSSL_RAW_DATA | OPENSSL_ZERO_PADDING, $iv);

echo var_export($decrypted, true) . "\n";

$result = rtrim($decrypted, "\0");

echo var_export($result, true) . "\n";

輸出:

70168f2d5751b3d3bf36b7e6b8ec5843

'Lorem ipsum' . "\0" . '' . "\0" . '' . "\0" . '' . "\0" . '' . "\0" . ''

'Lorem ipsum'

總結(jié)

以上是生活随笔為你收集整理的php mcrypt取消,php – Mcrypt弃用后如何解密?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。