今天来了一个需求 需要进行aes-ecb-128加密 ok这个简单,但是。。。↓↓
平台向接入方分配的AppSecret(32位长的十六进制字符串)作为密钥。采用128位模式。使用前需把AppSecret转换为16位长的二进制字节数组。
1.32位长十六进制字符串 转换为 16位长的二进制字节数组 //有点懵,网上查不到。其实就是16进制字符串数据转2进制 , 使用hex2bin()函数即可 O(∩_∩)O~~
2.下一步aes加密解密,上代码:
class AES_CW{
private $_iv = '';
private $_secret = '';
public function __construct($iv,$secret){
$this->_iv = substr($iv.'0000000000000000', 0,16);//可以忽略这一步,只要你保证iv长度是16
$this->_secret =$secret;
}
public function decodeECB128($secretData){
return openssl_decrypt($secretData,'aes-128-ecb',$this->_secret,OPENSSL_RAW_DATA);
}
public function encodeECB128($data){
//这里需要配置options参数OPENSSL_RAW_DATA裸数据,否则默认是base64_encode格式化过得数据
$data = openssl_encrypt($data,'aes-128-ecb',$this->_secret,OPENSSL_RAW_DATA);
return $data;
}
}
$secret = hex2bin("ABCD51171779997B98888AF51079752B");//获取16位二进制数组数据
$aes = new AES_CW("",$secret);//实例化aes对象
$enc = $aes->encodeECB128('RawData');//加密 这是data返回的数据是二进制数据,再把它转化为16进制的数据,使用bin2hex()函数即可 O(∩_∩)O~~ 完成~
$dec = $aes->decodeECB128($enc);//解密