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生成月历代码
Jun 14 PHP
PHP MemCached高级缓存配置图文教程
Aug 05 PHP
php环境配置之CGI、FastCGI、PHP-CGI、PHP-FPM、Spawn-FCGI比较?
Oct 17 PHP
PHP表单提交表单名称含有点号(.)则会被转化为下划线(_)
Dec 14 PHP
PHP提交表单失败后如何保留已经填写的信息
Jun 20 PHP
ThinkPHP中的create方法与自动令牌验证实例教程
Aug 22 PHP
thinkphp实现上一篇与下一篇的方法
Dec 08 PHP
smarty内置函数section的用法
Jan 22 PHP
phpMyAdmin无法登陆的解决方法
Apr 27 PHP
php和vue配合使用技巧和方法
May 09 PHP
tp5.1 实现setInc字段自动加1
Oct 18 PHP
php解析非标准json、非规范json的方式实例
Dec 10 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
检查用户名是否已在mysql中存在的php写法
2014/01/20 PHP
phpmyadmin配置文件现在需要绝密的短密码(blowfish_secret)的2种解决方法
2014/05/07 PHP
php获取文件类型和文件信息的方法
2015/07/10 PHP
Zend Framework校验器Zend_Validate用法详解
2016/12/09 PHP
PHP检查网站是否宕机的方法示例
2017/07/24 PHP
JS焦点图切换,上下翻转
2011/05/12 Javascript
javascript中的nextSibling使用陷(da)阱(keng)
2014/05/05 Javascript
jQuery插件开发详细教程
2014/06/06 Javascript
jquery实现submit提交表单
2015/02/03 Javascript
JavaScript类型系统之Object详解
2016/01/07 Javascript
分享我对JS插件开发的一些感想和心得
2016/02/04 Javascript
AngularJS使用拦截器实现的loading功能完整实例
2017/05/17 Javascript
NodeJS使用七牛云存储上传文件的方法
2017/07/24 NodeJs
Angular4 反向代理Details实践
2018/05/30 Javascript
对vue事件的延迟执行实例讲解
2018/08/28 Javascript
vue 音乐App QQ音乐搜索列表最新接口跨域设置方法
2018/09/25 Javascript
vue和iview实现Scroll 数据无限滚动功能
2019/10/31 Javascript
JS造成内存泄漏的几种情况实例分析
2020/03/02 Javascript
vue使用map代替Aarry数组循环遍历的方法
2020/04/30 Javascript
python中正则表达式的使用方法
2018/02/25 Python
python读文件保存到字典,修改字典并写入新文件的实例
2018/04/23 Python
基于tensorflow加载部分层的方法
2018/07/26 Python
django框架forms组件用法实例详解
2019/12/10 Python
python中re模块知识点总结
2021/01/17 Python
CSS3 旋转立方体问题详解
2020/01/09 HTML / CSS
中软Java笔试题
2012/11/11 面试题
升职自荐信范文
2013/10/05 职场文书
出国留学自荐信
2013/10/25 职场文书
商场中秋节广播稿
2014/01/17 职场文书
基层党组织公开承诺书
2014/03/28 职场文书
合作意向书范本
2014/03/31 职场文书
单位工作证明格式模板
2014/10/04 职场文书
考研导师推荐信范文
2015/03/27 职场文书
golang 如何用反射reflect操作结构体
2021/04/28 Golang
解析laravel使用workerman用户交互、服务器交互
2021/04/28 PHP
openstack云计算keystone组件工作介绍
2022/04/20 Servers