在php中咱們使用openssl_encrypt來實現加密和使用openssl_decrypt實現解密
一:openssl_encrypt方法詳解:php
openssl_encrypt($data, $method, $key, $options = 0, $iv = "", &$tag = NULL, $aad = "", $tag_length = 16)
參數:
1.$data:加密明文
2.$method:加密方法: 能夠經過openssl_get_cipher_methods()獲取有哪些加密方式
3.$passwd:加密密鑰[密碼]
4.$options:數據格式選項(可選)【選項有:】:0,OPENSSL_RAW_DATA=1,OPENSSL_ZERO_PADDING=2,OPENSSL_NO_PADDING=3
5.$iv:密初始化向量(可選),須要注意:若是method爲DES−ECB,則iv無需填寫
6.$tag:使用 AEAD 密碼模式(GCM 或 CCM)時傳引用的驗證標籤(可選)
7.$aad:附加的驗證數據。(可選)
8.$tag_length:驗證 tag 的長度。GCM 模式時,它的範圍是 4 到 16(可選)
二:openssl_decrypt方法詳解加密
openssl_decrypt($data, $method, $password, $options = 1, $iv = "", $tag = "", $aad = "")
參數:
1.$data:要解密的加密消息。
2.$method:解密方法:能夠經過openssl_get_cipher_methods()獲取有哪些解密方式
3.$passwd:解密密鑰[密碼]
4.$options:數據格式選項(可選)【選項有:】:0,OPENSSL_RAW_DATA=1,OPENSSL_ZERO_PADDING=2,OPENSSL_NO_PADDING=3
5.$iv:密初始化向量(可選),須要注意:若是method爲DES−ECB,則iv無需填寫
6.$tag:AEAD密碼模式下的身份驗證標籤(可選)
7.$aad:附加的驗證數據。(可選)
三:實現AES的加密解密
1:AES加密code
// 要加密的字符串 $data = 'test'; // 密鑰 $key = '123456'; // 加密數據 'AES-128-ECB' 能夠經過openssl_get_cipher_methods()獲取 $encrypt = openssl_encrypt($data, 'AES-128-ECB', $key, 0); echo (($encrypt));
2:AES解密ip
//解密字符串 $encrypt = '***'; //密鑰 $key = '123456'; // 解密數據 $decrypt = openssl_decrypt($encrypt, 'AES-128-ECB', $key, 0); echo $decrypt;
根據如上就能夠實現AES的加密解密功能
返回ssl