php实现的AES加密类定义与用法示例


Posted in PHP onJanuary 29, 2018

本文实例讲述了php实现的AES加密类定义与用法。分享给大家供大家参考,具体如下:

CryptAES.class.php文件:

<?php
class CryptAES
{
 protected $cipher = MCRYPT_RIJNDAEL_128;
 protected $mode = MCRYPT_MODE_ECB;
 protected $pad_method = NULL;
 protected $secret_key = '';
 protected $iv = '';
 public function set_cipher($cipher)
 {
 $this->cipher = $cipher;
 }
 public function set_mode($mode)
 {
 $this->mode = $mode;
 }
 public function set_iv($iv)
 {
 $this->iv = $iv;
 }
 public function set_key($key)
 {
 $this->secret_key = $key;
 }
 public function require_pkcs5()
 {
 $this->pad_method = 'pkcs5';
 }
 protected function pad_or_unpad($str, $ext)
 {
 if ( is_null($this->pad_method) )
 {
  return $str;
 }
 else
 {
  $func_name = __CLASS__ . '::' . $this->pad_method . '_' . $ext . 'pad';
  if ( is_callable($func_name) )
  {
  $size = mcrypt_get_block_size($this->cipher, $this->mode);
  return call_user_func($func_name, $str, $size);
  }
 }
 return $str;
 }
 protected function pad($str)
 {
 return $this->pad_or_unpad($str, '');
 }
 protected function unpad($str)
 {
 return $this->pad_or_unpad($str, 'un');
 }
 public function encrypt($str)
 {
 $str = $this->pad($str);
 $td = mcrypt_module_open($this->cipher, '', $this->mode, '');
 if ( empty($this->iv) )
 {
  $iv = @mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
 }
 else
 {
  $iv = $this->iv;
 }
 mcrypt_generic_init($td, $this->secret_key, $iv);
 $cyper_text = mcrypt_generic($td, $str);
 //$rt=base64_encode($cyper_text);
 $rt = bin2hex($cyper_text);
 mcrypt_generic_deinit($td);
 mcrypt_module_close($td);
 return $rt;
 }
 public function decrypt($str){
 $td = mcrypt_module_open($this->cipher, '', $this->mode, '');
 if ( empty($this->iv) )
 {
  $iv = @mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
 }
 else
 {
  $iv = $this->iv;
 }
 mcrypt_generic_init($td, $this->secret_key, $iv);
 $decrypted_text = mdecrypt_generic($td, self::hex2bin($str));
 //$decrypted_text = mdecrypt_generic($td, base64_decode($str));
 $rt = $decrypted_text;
 mcrypt_generic_deinit($td);
 mcrypt_module_close($td);
 return $this->unpad($rt);
 }
 public static function hex2bin($hexdata) {
 $bindata = '';
 $length = strlen($hexdata);
 for ($i=0; $i < $length; $i += 2)
 {
  $bindata .= chr(hexdec(substr($hexdata, $i, 2)));
 }
 return $bindata;
 }
 public static function pkcs5_pad($text, $blocksize)
 {
 $pad = $blocksize - (strlen($text) % $blocksize);
 return $text . str_repeat(chr($pad), $pad);
 }
 public static function pkcs5_unpad($text)
 {
 $pad = ord($text{strlen($text) - 1});
 if ($pad > strlen($text)) return false;
 if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) return false;
 return substr($text, 0, -1 * $pad);
 }
}
?>

用法:

require_once("CryptAES.class.php");
$keyStr = 'ss4fs4skfhksk';
$aes = new CryptAES();
$keyStr = $aes->hex2bin($keyStr);
$aes->set_key($keyStr);
$aes->require_pkcs5();
$d = $aes->encrypt($data);

注:这里需要在php.ini中开启:extension=php_mcrypt.dll

PHP 相关文章推荐
PHP聊天室技术
Oct 09 PHP
第十节--抽象方法和抽象类
Nov 16 PHP
php 上一篇,下一篇文章实现代码与原理说明
May 09 PHP
php用户注册页面利用js进行表单验证具体实例
Oct 17 PHP
PHP判断一个字符串是否是回文字符串的方法
Mar 23 PHP
PHP版本如何选择?应该使用哪个版本?
May 13 PHP
php获取、检查类名、函数名、方法名的函数方法
Jun 25 PHP
利用php-cli和任务计划实现刷新token功能的方法
May 03 PHP
Laravel Intervention/image图片处理扩展包的安装、使用与可能遇到的坑详解
Nov 14 PHP
PHP函数按引用传递参数及函数可选参数用法示例
Jun 04 PHP
微信公众平台开发教程③ PHP实现微信公众号支付功能图文详解
Apr 10 PHP
PHP使用Http Post请求发送Json对象数据代码解析
Jul 16 PHP
php 判断IP为有效IP地址的方法
Jan 28 #PHP
Laravel中unique和exists验证规则的优化详解
Jan 28 #PHP
win10 apache配置虚拟主机后localhost无法使用的解决方法
Jan 27 #PHP
PHP设计模式之注册树模式分析
Jan 26 #PHP
PHP微信开发之微信录音临时转永久存储
Jan 26 #PHP
PHP CURL与java http使用方法详解
Jan 26 #PHP
php实现mysql连接池效果实现代码
Jan 25 #PHP
You might like
PHP下通过系统信号量加锁方式获取递增序列ID
2009/09/25 PHP
开启CURL扩展,让服务器支持PHP curl函数(远程采集)
2011/03/19 PHP
深入php-fpm的两种进程管理模式详解
2013/06/03 PHP
PHP截取IE浏览器并缩小原图的方法
2016/03/04 PHP
php文件上传 你真的掌握了吗
2016/11/28 PHP
JQuery学习笔记 nt-child的使用
2011/01/17 Javascript
jQuery支持添加事件的日历特效代码分享(3种样式)
2015/08/24 Javascript
jQuery绑定事件监听bind和移除事件监听unbind用法实例详解
2016/01/19 Javascript
原生JS实现旋转木马式图片轮播插件
2016/04/25 Javascript
jQuery实现可拖拽的许愿墙效果【附demo源码下载】
2016/09/14 Javascript
JS新包管理工具yarn和npm的对比与使用入门
2016/12/09 Javascript
原生js实现图片放大缩小计时器效果
2017/01/20 Javascript
jQuery图片切换动画效果
2017/02/28 Javascript
微信小程序 下拉菜单简单实例
2017/04/13 Javascript
实例详解JSON取值(key是中文或者数字)方式
2017/08/24 Javascript
vue2.0 使用element-ui里的upload组件实现图片预览效果方法
2018/09/04 Javascript
layui 弹出层回调获取弹出层数据的例子
2019/09/02 Javascript
python利用正则表达式排除集合中字符的功能示例
2017/10/10 Python
对python数据切割归并算法的实例讲解
2018/12/12 Python
解决pycharm工程启动卡住没反应的问题
2019/01/19 Python
Django 开发环境配置过程详解
2019/07/18 Python
Python字符串的修改方法实例
2019/12/19 Python
python文件绝对路径写法介绍(windows)
2019/12/25 Python
python定时截屏实现
2020/11/02 Python
Redbubble法国:由独立艺术家设计的独特产品
2019/01/08 全球购物
类如何去实现接口
2013/12/19 面试题
介绍一下Linux中的链接
2016/06/05 面试题
美术专业学生个人自我评价
2013/09/19 职场文书
草船借箭教学反思
2014/02/03 职场文书
《永远的白衣战士》教学反思
2014/04/25 职场文书
市贸粮局召开党的群众路线教育实践活动总结大会新闻稿
2014/10/21 职场文书
惹女朋友生气检讨书
2015/05/06 职场文书
安全责任协议书范本
2016/03/23 职场文书
springboot临时文件存储目录配置方式
2021/07/01 Java/Android
springboot使用Redis作缓存使用入门教程
2021/07/25 Redis
Oracle中日期的使用方法实例
2022/07/07 Oracle