標(biāo)準(zhǔn)PHP的AES加密算法類
分享一個(gè)標(biāo)準(zhǔn)PHP的AES加密算法類,其中mcrypt_get_block_size('rijndael-128', 'ecb');,如果在不明白原理的情況下比較容易搞錯(cuò),可以通過mcrypt_list_algorithms函數(shù)查看你需要的加密算法標(biāo)識(shí)。
<?php
/**
?* AES128加解密類
?* @author dy
?*
?*/
defined('InEjbuy') or exit('Access Invalid!');
class Aes{
??? //密鑰
??? private $_secrect_key;
??? public function __construct(){
??????? $this->_secrect_key = 'MYgGnQE2jDFADSFFDSEWsdD';
??? }
??? /**
???? * 加密方法
???? * @param string $str
???? * @return string
???? */
??? public function encrypt($str){
??????? //AES, 128 ECB模式加密數(shù)據(jù)
??????? $screct_key = $this->_secrect_key;
??????? $screct_key = base64_decode($screct_key);
??????? $str = trim($str);
??????? $str = $this->addPKCS7Padding($str);
??????? $iv = mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128,MCRYPT_MODE_ECB),MCRYPT_RAND);
??????? $encrypt_str =? mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $screct_key, $str, MCRYPT_MODE_ECB, $iv);
??????? return base64_encode($encrypt_str);
??? }
??? /**
???? * 解密方法
???? * @param string $str
???? * @return string
???? */
??? public function decrypt($str){
??????? //AES, 128 ECB模式加密數(shù)據(jù)
??????? $screct_key = $this->_secrect_key;
??????? $str = base64_decode($str);
??????? $screct_key = base64_decode($screct_key);
??????? $iv = mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128,MCRYPT_MODE_ECB),MCRYPT_RAND);
??????? $encrypt_str =? mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $screct_key, $str, MCRYPT_MODE_ECB, $iv);
??????? $encrypt_str = trim($encrypt_str);
??????? $encrypt_str = $this->stripPKSC7Padding($encrypt_str);
??????? return $encrypt_str;
??? }
??? /**
???? * 填充算法
???? * @param string $source
???? * @return string
???? */
??? function addPKCS7Padding($source){
??????? $source = trim($source);
??????? $block = mcrypt_get_block_size('rijndael-128', 'ecb');
??????? $pad = $block - (strlen($source) % $block);
??????? if ($pad <= $block) {
??????????? $char = chr($pad);
??????????? $source .= str_repeat($char, $pad);
??????? }
??????? return $source;
??? }
??? /**
???? * 移去填充算法
???? * @param string $source
???? * @return string
???? */
??? function stripPKSC7Padding($source){
??????? $source = trim($source);
??????? $char = substr($source, -1);
??????? $num = ord($char);
??????? if($num==62)return $source;
??????? $source = substr($source,0,-$num);
??????? return $source;
??? }
}PHP AES算法的通用函數(shù)
function aesEncrypt($data, $key, $iv) {
$cipher = "aes-256-cbc";
$padding = OPENSSL_PKCS1_PADDING;
$encrypted = openssl_encrypt($data, $cipher, $key, $padding, $iv);
return base64_encode($encrypted);
}
function aesDecrypt($data, $key, $iv) {
$cipher = "aes-256-cbc";
$padding = OPENSSL_PKCS1_PADDING;
$decrypted = openssl_decrypt(base64_decode($data), $cipher, $key, $padding, $iv);
return $decrypted;
}該函數(shù)使用AES-256-CBC加密算法和PKCS1填充模式。它需要三個(gè)參數(shù):要加密/解密的數(shù)據(jù),密鑰和初始化向量(IV)。在加密時(shí),數(shù)據(jù)將被加密并返回Base64編碼的字符串。在解密時(shí),Base64編碼的字符串將被解碼并返回原始數(shù)據(jù)。
以上就是本文所述的全部?jī)?nèi)容了,希望對(duì)大家學(xué)習(xí)php的AES加密算法類有所幫助。
- PHP的AES加密算法完整實(shí)例
- PHP實(shí)現(xiàn)AES256加密算法實(shí)例
- PHP對(duì)稱加密算法(DES/AES)類的實(shí)現(xiàn)代碼
- php中AES加密解密的例子小結(jié)
- PHP實(shí)現(xiàn)的AES雙向加密解密功能示例【128位】
- PHP7.1實(shí)現(xiàn)的AES與RSA加密操作示例
- PHP7實(shí)現(xiàn)和CryptoJS的AES加密方式互通示例【AES-128-ECB加密】
- php實(shí)現(xiàn)的AES加密類定義與用法示例
- PHP擴(kuò)展mcrypt實(shí)現(xiàn)的AES加密功能示例
- PHP實(shí)現(xiàn)的AES 128位加密算法示例
相關(guān)文章
使用PHP實(shí)現(xiàn)生成HTML靜態(tài)頁面
在PHP網(wǎng)站開發(fā)中為了網(wǎng)站推廣和SEO等需要,需要對(duì)網(wǎng)站進(jìn)行全站或局部靜態(tài)化處理,PHP生成靜態(tài)HTML頁面有多種方法,比如利用PHP模板、緩存等實(shí)現(xiàn)頁面靜態(tài)化,今天就以PHP實(shí)例教程形式討論P(yáng)HP生成靜態(tài)頁面的方法。2015-11-11
詳解如何用PHP?實(shí)現(xiàn)多進(jìn)程
這篇文章主要為大家介紹了如何用PHP?實(shí)現(xiàn)多進(jìn)程實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
修改了一個(gè)很不錯(cuò)的php驗(yàn)證碼(支持中文)
很早前在PHP喜悅國(guó)際村看到的一個(gè)驗(yàn)證碼類,寫的很強(qiáng)。但有些邏輯方面感覺處理的不好,然后我不喜歡完全用session來處理驗(yàn)證碼。這在大型系統(tǒng)中是很不好的2007-02-02

