aes.php类文件
<?php class Aes { /** * var string $method 加解密方法,可通过openssl_get_cipher_methods()获得 */ protected $method; /** * var string $secret_key 加解密的密钥 */ protected $secret_key; /** * var string $iv 加解密的向量,有些方法需要设置比如CBC */ protected $iv; /** * var string $options (不知道怎么解释,目前设置为0没什么问题) */ protected $options; /** * 构造函数 * * @param string $key 密钥 * @param string $method 加密方式 * @param string $iv iv向量 * @param mixed $options 还不是很清楚 * */ public function __construct($key, $method = 'AES-128-ECB', $iv = '', $options = 0) { // key是必须要设置的 $this->secret_key = isset($key) ? $key : 'morefun'; $this->method = $method; $this->iv = $iv; $this->options = $options; } /** * 加密方法,对数据进行加密,返回加密后的数据 * * @param string $data 要加密的数据 * * @return string * */ public function encrypt($data) { return openssl_encrypt($data, $this->method, $this->secret_key, $this->options, $this->iv); } /** * 解密方法,对数据进行解密,返回解密后的数据 * * @param string $data 要解密的数据 * * @return string * */ public function decrypt($data) { return openssl_decrypt($data, $this->method, $this->secret_key, $this->options, $this->iv); } }
aes2.php 测试使用加密类 我这里不用命名空间、转码
<?php //namespace Aes; include_once('aes.php'); //$char = array("ASCII",'UTF-8','GB2312','GBK', 'BIG5', 'EUC-CN'); $aes = new Aes('12345678'); $text = 'bbm是一家很傻逼的公司'; //$param_char = mb_detect_encoding($text, $char); //if($param_char != 'UTF-8') //{ // $text = iconv("$param_char//IGNORE", "UTF-8",$text); //} $encrypted = $aes->encrypt($text); echo $encrypted. '<hr>'; $decrypted = $aes->decrypt($encrypted); //$param_char = mb_detect_encoding($decrypted, $char); //if($param_char != 'GB2312') //{ // $decrypted = iconv("$param_char//IGNORE", "GB2312",$decrypted); //} echo $decrypted; ?>