php写的AES加密解密类分享


Posted in PHP onJune 20, 2014

今天写了一个php的AES加密类。适用于Yii的扩展。
如果不用在Yii框架中,把代码中Yii::app()->params['encryptKey'] 换成你对应的默认key就可以了。
类代码:

<?php
/**
 * php AES加解密类
 * 如果要与java共用,则密钥长度应该为16位长度
 * 因为java只支持128位加密,所以php也用128位加密,可以与java互转。
 * 同时AES的标准也是128位。只是RIJNDAEL算法可以支持128,192和256位加密。
 * java 要使用AES/CBC/NoPadding标准来加解密
 * 
 * @author Terry
 *
 */
class PhpAes
{
	/**
	 * This was AES-128 / CBC / NoPadding encrypted.
	 * return base64_encode string
	 * @author Terry
	 * @param string $plaintext
	 * @param string $key
	 */
	public static function AesEncrypt($plaintext,$key = null)
	{
		$plaintext = trim($plaintext);
		if ($plaintext == '') return '';
		if(!extension_loaded('mcrypt'))
			throw new CException(Yii::t('yii','AesEncrypt requires PHP mcrypt extension to be loaded in order to use data encryption feature.'));
		$size = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
		$module = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, '');
		$key=self::substr($key===null ? Yii::app()->params['encryptKey'] : $key, 0, mcrypt_enc_get_key_size($module));
		/* Create the IV and determine the keysize length, use MCRYPT_RAND
		 * on Windows instead */
		$iv = substr(md5($key),0,mcrypt_enc_get_iv_size($module));
		/* Intialize encryption */
		mcrypt_generic_init($module, $key, $iv);

		/* Encrypt data */
		$encrypted = mcrypt_generic($module, $plaintext);

		/* Terminate encryption handler */
		mcrypt_generic_deinit($module);
		mcrypt_module_close($module);
		return base64_encode($encrypted);
	}

	/**
	 * This was AES-128 / CBC / NoPadding decrypted.
	 * @author Terry
	 * @param string $encrypted		base64_encode encrypted string
	 * @param string $key
	 * @throws CException
	 * @return string
	 */
	public static function AesDecrypt($encrypted, $key = null)
	{
		if ($encrypted == '') return '';
		if(!extension_loaded('mcrypt'))
			throw new CException(Yii::t('yii','AesDecrypt requires PHP mcrypt extension to be loaded in order to use data encryption feature.'));

		$ciphertext_dec = base64_decode($encrypted);
		$module = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, '');
		$key=self::substr($key===null ? Yii::app()->params['encryptKey'] : $key, 0, mcrypt_enc_get_key_size($module));

		$iv = substr(md5($key),0,mcrypt_enc_get_iv_size($module));

		/* Initialize encryption module for decryption */
		mcrypt_generic_init($module, $key, $iv);

		/* Decrypt encrypted string */
		$decrypted = mdecrypt_generic($module, $ciphertext_dec);

		/* Terminate decryption handle and close module */
		mcrypt_generic_deinit($module);
		mcrypt_module_close($module);
		return rtrim($decrypted,"\0");
	}

	/**
	 * Returns the length of the given string.
	 * If available uses the multibyte string function mb_strlen.
	 * @param string $string the string being measured for length
	 * @return integer the length of the string
	 */
	private static function strlen($string)
	{
		return extension_loaded('mbstring') ? mb_strlen($string,'8bit') : strlen($string);
	}

	/**
	 * Returns the portion of string specified by the start and length parameters.
	 * If available uses the multibyte string function mb_substr
	 * @param string $string the input string. Must be one character or longer.
	 * @param integer $start the starting position
	 * @param integer $length the desired portion length
	 * @return string the extracted part of string, or FALSE on failure or an empty string.
	 */
	private static function substr($string,$start,$length)
	{
		return extension_loaded('mbstring') ? mb_substr($string,$start,$length,'8bit') : substr($string,$start,$length);
	}
}
PHP 相关文章推荐
谈谈新手如何学习PHP 默默经典版本
Aug 04 PHP
批量修改RAR文件注释的php代码
Nov 20 PHP
深入PHP中的HashTable结构详解
Jun 13 PHP
解析PHP SPL标准库的用法(遍历目录,查找固定条件的文件)
Jun 18 PHP
smarty内置函数capture用法分析
Jan 22 PHP
PHP速成大法
Jan 30 PHP
举例讲解PHP面对对象编程的多态
Aug 12 PHP
PHP MYSQL实现登陆和模糊查询两大功能
Feb 05 PHP
一个非常实用的php文件上传类
Jul 04 PHP
Laravel中批量赋值Mass-Assignment的真正含义详解
Sep 29 PHP
PHP对称加密算法(DES/AES)类的实现代码
Nov 14 PHP
PHP实现图片压缩
Sep 09 PHP
PHP提交表单失败后如何保留已经填写的信息
Jun 20 #PHP
将酷狗krc歌词解析并转换为lrc歌词php源码
Jun 20 #PHP
Yii Framework框架获取分类下面的所有子类方法
Jun 20 #PHP
windows下配置apache+php+mysql时出现问题的处理方法
Jun 20 #PHP
PHP扩展CURL的用法详解
Jun 20 #PHP
教你如何解密 “ PHP 神盾解密工具 ”
Jun 20 #PHP
ThinkPHP3.1查询语言详解
Jun 19 #PHP
You might like
PHP分页显示制作详细讲解
2006/10/09 PHP
FleaPHP的安全设置方法
2008/09/15 PHP
探讨fckeditor在Php中的配置详解
2013/06/08 PHP
php通过ajax实现双击table修改内容
2014/04/28 PHP
php使用sql server验证连接数据库的方法
2014/12/25 PHP
php+ajax实时输入自动搜索匹配的方法
2014/12/26 PHP
Laravel 自定命令以及生成文件的例子
2019/10/23 PHP
jQuery使用手册之二 DOM操作
2007/03/24 Javascript
细说浏览器特性检测(2)-通用事件检测
2010/11/05 Javascript
在JavaScript中获取请求的URL参数[正则]
2010/12/25 Javascript
JS返回上一页实例代码通过图片和按钮分别实现
2013/08/16 Javascript
jquery中animate动画积累的解决方法
2013/10/05 Javascript
改变隐藏的input中value的值代码
2013/12/30 Javascript
深入理解JavaScript系列(38):设计模式之职责链模式详解
2015/03/04 Javascript
深入探秘jquery瀑布流的实现
2016/01/30 Javascript
Angularjs 双向绑定时字符串的转换成数字类型的问题
2017/06/12 Javascript
ExtJs异步无法向外传值和赋值的完美解决办法
2017/06/14 Javascript
Vue 中mixin 的用法详解
2018/04/23 Javascript
浅谈node.js 命令行工具(cli)
2018/05/10 Javascript
element-ui表格列金额显示两位小数的方法
2018/08/24 Javascript
Vue路由管理器Vue-router的使用方法详解
2020/02/05 Javascript
python用BeautifulSoup库简单爬虫实例分析
2018/07/30 Python
python使用pdfminer解析pdf文件的方法示例
2018/12/20 Python
对python 通过ssh访问数据库的实例详解
2019/02/19 Python
Python中zip()函数的简单用法举例
2019/09/02 Python
python脚本和网页有何区别
2020/07/02 Python
Python Flask异步发送邮件实现方法解析
2020/08/01 Python
幼师求职自荐信范文
2014/01/26 职场文书
社区国庆节活动方案
2014/02/05 职场文书
《学会合作》教学反思
2014/04/12 职场文书
教师学习党的群众路线教育实践活动心得体会
2014/10/31 职场文书
2014大学辅导员工作总结
2014/12/02 职场文书
孝老爱亲事迹材料
2014/12/24 职场文书
2015年图书馆个人工作总结
2015/05/26 职场文书
医院见习总结
2015/06/24 职场文书
浅谈css实现背景颜色半透明的两种方法
2021/12/06 HTML / CSS