PHP mcrypt可逆加密算法分析


Posted in PHP onJuly 19, 2011

数据加密在我们生活中的地位已经越来越重要了,尤其是考虑到在网络上发生的大量交易和传输的大量数据。对于不需要还原为原始数据的信息我们可以使用MD5、sha1等不可逆加密算法对数据进行加密处理,但对于交易信息等需要还原为原始数据的重要信息则必须使用可还原的加密算法进行加密了。当然你可以自己写一个可逆加密的算法进行加密和解密计算。本文中我们介绍的是使用 mcrypt模块进行加密解密操作。
Mcrypt的优点不仅仅在于其提供的加密算法较多,在windows下随PHP包一起发布,还在于它可以对数据进行加/解密处理,此外,它还提供了包括DES算法在内的35种处理数据用的函数。

/** 
+----------------------------------------------------- 
* Mcrypt 加密/解密 
* @param String $date 要加密和解密的数据 
* @param String $mode encode 默认为加密/decode 为解密 
* @return String 
* @author zxing@97md.net Mon Sep 14 22:59:28 CST 2009 
+----------------------------------------------------- 
* @example 
*/ 
function ZxingCrypt($date,$mode = 'encode'){ 
$key = md5('zxing');//用MD5哈希生成一个密钥,注意加密和解密的密钥必须统一 
if ($mode == 'decode'){ 
$date = base64_decode($date); 
} 
if (function_exists('mcrypt_create_iv')){ 
$iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB); 
$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND); 
} 
if (isset($iv) && $mode == 'encode'){ 
$passcrypt = mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $key, $date, MCRYPT_MODE_ECB, $iv); 
}elseif (isset($iv) && $mode == 'decode'){ 
$passcrypt = mcrypt_decrypt(MCRYPT_RIJNDAEL_256, $key, $date, MCRYPT_MODE_ECB, $iv); 
} 
if ($mode == 'encode'){ 
$passcrypt = base64_encode($passcrypt); 
} 
return $passcrypt; 
}

别的网友的代码
<?php 
$td = mcrypt_module_open(MCRYPT_DES,'','ecb',''); //使用MCRYPT_DES算法,ecb模式 
$iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND); 
$ks = mcrypt_enc_get_key_size($td); 
$key = "ery secret key";//密钥 
$key = substr(md5($key), 0, $ks); 
mcrypt_generic_init($td, $key, $iv); //初始处理 
//加密 
$encrypted = mcrypt_generic($td, 'This is very important data'); 
//结束处理 
mcrypt_generic_deinit($td); 
//初始解密处理 
mcrypt_generic_init($td, $key, $iv); 
//解密 
$decrypted = mdecrypt_generic($td, $encrypted); 
//结束 
mcrypt_generic_deinit($td); 
mcrypt_module_close($td); 
//解密后,可能会有后续的\0,需去掉 
echo trim($decrypted) . "\n"; 
?>
PHP 相关文章推荐
56.com视频采集接口程序(PHP)
Sep 22 PHP
php一句话cmdshell新型 (非一句话木马)
Apr 18 PHP
php 分页类 扩展代码
Jun 11 PHP
PHP pathinfo()获得文件的路径、名称等信息说明
Sep 13 PHP
PHP实现下载功能的代码
Sep 29 PHP
PHP读取xml方法介绍
Jan 12 PHP
浅析PHP安装扩展mcrypt以及相关依赖项(PHP安装PECL扩展的方法)
Jul 05 PHP
改写ThinkPHP的U方法使其路由下分页正常
Jul 02 PHP
PHP中使用strpos函数实现屏蔽敏感关键字功能
Aug 21 PHP
WordPress中&quot;无法将上传的文件移动至&quot;错误的解决方法
Jul 01 PHP
Thinkphp5+Redis实现商品秒杀代码实例讲解
Dec 29 PHP
PHP实现考试倒计时功能代码
Apr 16 PHP
PHP中date()日期函数有关参数整理
Jul 19 #PHP
php URL验证正则表达式
Jul 19 #PHP
PHP中static关键字原理的学习研究分析
Jul 18 #PHP
在WAMP环境下搭建ZendDebugger php调试工具的方法
Jul 18 #PHP
无法载入 mcrypt 扩展,请检查 PHP 配置终极解决方案
Jul 18 #PHP
PHP通过iconv将字符串从GBK转换为UTF8字符集
Jul 18 #PHP
PHP中英混合字符串截取函数代码
Jul 17 #PHP
You might like
在PHP中使用XML
2006/10/09 PHP
Windows Apache2.2.11及Php5.2.9-1的安装与配置方法
2009/06/08 PHP
PHP获取栏目的所有子级和孙级栏目的ID号示例
2014/04/01 PHP
分享十款最出色的PHP安全开发库中文详细介绍
2015/03/22 PHP
Laravel 5 框架入门(二)构建 Pages 的管理功能
2015/04/09 PHP
WordPress中转义HTML与过滤链接的相关PHP函数使用解析
2015/12/22 PHP
[原创]解决wincache不支持64位PHP5.5/5.6的问题(提供64位wincache下载)
2016/06/22 PHP
PHP封装的数据库保存session功能类
2016/07/11 PHP
yii2 RBAC使用DbManager实现后台权限判断的方法
2016/07/23 PHP
javaScript arguments 对象使用介绍
2013/10/18 Javascript
js控制iframe的高度/宽度让其自适应内容
2014/04/09 Javascript
测试IE浏览器对JavaScript的AngularJS的兼容性
2015/06/19 Javascript
jquery及js实现动态加载js文件的方法
2016/01/21 Javascript
解决vue 中 echart 在子组件中只显示一次的问题
2018/08/07 Javascript
如何安装控制器JavaScript生成插件详解
2018/10/21 Javascript
在vue中使用echarts图表实例代码详解
2018/10/22 Javascript
JS使用栈判断给定字符串是否是回文算法示例
2019/03/04 Javascript
js作用域和作用域链及预解析
2019/04/11 Javascript
Vue2.0实现组件之间数据交互和通信操作示例
2019/05/16 Javascript
layui多图上传实现删除功能的例子
2019/09/23 Javascript
[05:29]2014DOTA2国际邀请赛 赛后专访:LGDNewbee顺利过关
2014/07/13 DOTA
[54:25]Ti4 循环赛第三日LGD vs MOUZ
2014/07/12 DOTA
Python标准库内置函数complex介绍
2014/11/25 Python
在Python的Django框架下使用django-tagging的教程
2015/05/30 Python
Python3操作MongoDB增册改查等方法详解
2020/02/10 Python
css3的动画特效之动画序列(animation)
2017/12/22 HTML / CSS
跑步、骑行和铁人三项的高性能眼镜和服装:ROKA
2018/07/06 全球购物
为您搜罗全球潮流時尚品牌:HBX
2019/12/04 全球购物
Java中采用什么结构来捕获、处理异常?各子句的顺序、功能如何
2013/10/07 面试题
开工仪式主持词
2014/03/20 职场文书
总经理助理岗位职责
2015/01/31 职场文书
个人售房合同协议书
2016/03/21 职场文书
建国70周年的心得体会(2篇)
2019/09/20 职场文书
python爬虫框架feapde的使用简介
2021/04/20 Python
使用Redis实现实时排行榜功能
2021/07/02 Redis
Mysql分库分表之后主键处理的几种方法
2022/02/15 MySQL