Prpcrypt.php 1.12 KB
<?php

namespace app\api\helpers\wxencrypt;

use yii\base\Exception;
use function mcrypt_module_open;
use function mcrypt_generic_init;
use function mdecrypt_generic;
use function mcrypt_generic_deinit;
use function mcrypt_module_close;

/**
 * Prpcrypt class
 *
 * 
 */
class Prpcrypt
{
	/**
	 * 对密文进行解密
	 * @param string $aesKey 解密的秘钥
	 * @param string $aesCipher 需要解密的密文
     * @param string $aesIV 解密的初始向量
	 * @return string 解密得到的明文
	 */
	public static function decrypt($aesKey, $aesCipher, $aesIV )
	{

		try {
			
			$module = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, '');
			
			mcrypt_generic_init($module, $aesKey, $aesIV);

			//解密
			$decrypted = mdecrypt_generic($module, $aesCipher);
			mcrypt_generic_deinit($module);
			mcrypt_module_close($module);
		} catch (Exception $e) {
			return array(ErrorCode::$IllegalBuffer, null);
		}


		try {
			//去除补位字符
			$result = PKCS7Encoder::decode($decrypted);
		} catch (Exception $e) {
			//print $e;
			return array(ErrorCode::$IllegalBuffer, null);
		}
		return array(0, $result);
	}
}