加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

标准PHP的AES加密算法类

发布时间:2020-12-13 02:27:57 所属栏目:PHP教程 来源:网络整理
导读:《标准PHP的AES加密算法类》要点: 本文介绍了标准PHP的AES加密算法类,希望对您有用。如果有疑问,可以联系我们。 分享一个标准PHP的AES加密算法类,其中mcrypt_get_block_size('rijndael-128','ecb');,如果在不明白原理的情况下比较容易搞错,可以通过mcrypt

《标准PHP的AES加密算法类》要点:
本文介绍了标准PHP的AES加密算法类,希望对您有用。如果有疑问,可以联系我们。

分享一个标准PHP的AES加密算法类,其中mcrypt_get_block_size('rijndael-128','ecb');,如果在不明白原理的情况下比较容易搞错,可以通过mcrypt_list_algorithms函数查看你需要的加密算法标识.PHP实战

代码如下:

<?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模式加密数据
??????? $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模式加密数据
??????? $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_RAND);
??????? $encrypt_str =? mcrypt_decrypt(MCRYPT_RIJNDAEL_128,$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,-$num);
??????? return $source;
??? }
}

以上就是本文所述的全部内容了,希望对大家学习php的AES加密算法类有所帮助.PHP实战

欢迎参与《标准PHP的AES加密算法类》讨论,分享您的想法,编程之家 52php.cn为您提供专业教程。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读