在PHP 7.1 中使用openssl 取代mcrypt
從PHP 7.0升級到PHP 7.1廢棄了一個在過去普遍應用的擴展(mcrypt),但是微信官方提供的消息加密解密算法中的核心部分中確實使用mcrypt的,Prpcrypt
class的加密方法(encrypt
)和解密方法(decrypt
) ,怎麼改成openssl的函數呢?
/**
* 对明文进行加密
* @param string $text 需要加密的明文
* @return string 加密后的密文
*/
public function encrypt($text, $appid)
{
try {
/**
*原来代码
*/
$iv = substr($this->key, 0, 16);
$encrypted = openssl_encrypt($text,'AES-256-CBC',$this->key,OPENSSL_ZERO_PADDING,$iv);
return array(ErrorCode::$OK, $encrypted);
} catch (Exception $e) {
//print $e;
return array(ErrorCode::$EncryptAESError, null);
}
}
/**
* 对密文进行解密
* @param string $encrypted 需要解密的密文
* @return string 解密得到的明文
*/
public function decrypt($encrypted, $appid)
{
try {
$iv = substr($this->key, 0, 16);
$decrypted = openssl_decrypt($encrypted,'AES-256-CBC',$this->key,OPENSSL_ZERO_PADDING,$iv);
} catch (Exception $e) {
return array(ErrorCode::$DecryptAESError, null);
}
/**
*原来代码
*/
}
小程序的解密也會有同樣問題,相應代碼也需要改進一下!