2个比较经典的PHP加密解密函数分享


Posted in PHP onJuly 01, 2014

项目中有时我们需要使用PHP将特定的信息进行加密,也就是通过加密算法生成一个加密字符串,这个加密后的字符串可以通过解密算法进行解密,便于程序对解密后的信息进行处理。
最常见的应用在用户登录以及一些API数据交换的场景。

笔者收录了一些比较经典的PHP加密解密函数代码,分享给大家。加密解密原理一般都是通过一定的加密解密算法,将密钥加入到算法中,最终得到加密解密结果。
1、非常给力的authcode加密函数,Discuz!经典代码(带详解):

function authcode($string, $operation = 'DECODE', $key = '', $expiry = 0) {   

    // 动态密匙长度,相同的明文会生成不同密文就是依靠动态密匙   

    $ckey_length = 4;   

       

    // 密匙   

    $key = md5($key ? $key : $GLOBALS['discuz_auth_key']);   

       

    // 密匙a会参与加解密   

    $keya = md5(substr($key, 0, 16));   

    // 密匙b会用来做数据完整性验证   

    $keyb = md5(substr($key, 16, 16));   

    // 密匙c用于变化生成的密文   

    $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length): 

substr(md5(microtime()), -$ckey_length)) : '';   

    // 参与运算的密匙   

    $cryptkey = $keya.md5($keya.$keyc);   

    $key_length = strlen($cryptkey);   

    // 明文,前10位用来保存时间戳,解密时验证数据有效性,10到26位用来保存$keyb(密匙b), 

//解密时会通过这个密匙验证数据完整性   

    // 如果是解码的话,会从第$ckey_length位开始,因为密文前$ckey_length位保存 动态密匙,以保证解密正确   

    $string = $operation == 'DECODE' ? base64_decode(substr($string, $ckey_length)) :  

sprintf('%010d', $expiry ? $expiry + time() : 0).substr(md5($string.$keyb), 0, 16).$string;   

    $string_length = strlen($string);   

    $result = '';   

    $box = range(0, 255);   

    $rndkey = array();   

    // 产生密匙簿   

    for($i = 0; $i <= 255; $i++) {   

        $rndkey[$i] = ord($cryptkey[$i % $key_length]);   

    }   

    // 用固定的算法,打乱密匙簿,增加随机性,好像很复杂,实际上对并不会增加密文的强度   

    for($j = $i = 0; $i < 256; $i++) {   

        $j = ($j + $box[$i] + $rndkey[$i]) % 256;   

        $tmp = $box[$i];   

        $box[$i] = $box[$j];   

        $box[$j] = $tmp;   

    }   

    // 核心加解密部分   

    for($a = $j = $i = 0; $i < $string_length; $i++) {   

        $a = ($a + 1) % 256;   

        $j = ($j + $box[$a]) % 256;   

        $tmp = $box[$a];   

        $box[$a] = $box[$j];   

        $box[$j] = $tmp;   

        // 从密匙簿得出密匙进行异或,再转成字符   

        $result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256]));   

    }   

    if($operation == 'DECODE') {  

        // 验证数据有效性,请看未加密明文的格式   

        if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) &&  

substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16)) {   

            return substr($result, 26);   

        } else {   

            return '';   

        }   

    } else {   

        // 把动态密匙保存在密文里,这也是为什么同样的明文,生产不同密文后能解密的原因   

        // 因为加密后的密文可能是一些特殊字符,复制过程可能会丢失,所以用base64编码   

        return $keyc.str_replace('=', '', base64_encode($result));   

    }   

}

函数authcode($string, $operation, $key, $expiry)中的$string:字符串,明文或密文;$operation:DECODE表示解密,其它表示加密;$key:密匙;$expiry:密文有效期。

用法:

$str = 'abcdef'; 

$key = 'www.helloweba.com'; 

echo authcode($str,'ENCODE',$key,0); //加密 

$str = '56f4yER1DI2WTzWMqsfPpS9hwyoJnFP2MpC8SOhRrxO7BOk'; 

echo authcode($str,'DECODE',$key,0); //解密

2、加解密函数encrypt():

function encrypt($string,$operation,$key=''){ 

    $key=md5($key); 

    $key_length=strlen($key); 

      $string=$operation=='D'?base64_decode($string):substr(md5($string.$key),0,8).$string; 

    $string_length=strlen($string); 

    $rndkey=$box=array(); 

    $result=''; 

    for($i=0;$i<=255;$i++){ 

           $rndkey[$i]=ord($key[$i%$key_length]); 

        $box[$i]=$i; 

    } 

    for($j=$i=0;$i<256;$i++){ 

        $j=($j+$box[$i]+$rndkey[$i])%256; 

        $tmp=$box[$i]; 

        $box[$i]=$box[$j]; 

        $box[$j]=$tmp; 

    } 

    for($a=$j=$i=0;$i<$string_length;$i++){ 

        $a=($a+1)%256; 

        $j=($j+$box[$a])%256; 

        $tmp=$box[$a]; 

        $box[$a]=$box[$j]; 

        $box[$j]=$tmp; 

        $result.=chr(ord($string[$i])^($box[($box[$a]+$box[$j])%256])); 

    } 

    if($operation=='D'){ 

        if(substr($result,0,8)==substr(md5(substr($result,8).$key),0,8)){ 

            return substr($result,8); 

        }else{ 

            return''; 

        } 

    }else{ 

        return str_replace('=','',base64_encode($result)); 

    } 

}

函数encrypt($string,$operation,$key)中$string:需要加密解密的字符串;$operation:判断是加密还是解密,E表示加密,D表示解密;$key:密匙。
用法:

$str = 'abc'; 

$key = 'www.helloweba.com'; 

$token = encrypt($str, 'E', $key); 

echo '加密:'.encrypt($str, 'E', $key); 

echo '解密:'.encrypt($str, 'D', $key);
PHP 相关文章推荐
PHP入门
Oct 09 PHP
PHP入门学习的几个不错的实例代码
Jul 13 PHP
php递归列出所有文件和目录的代码
Sep 10 PHP
PHP字符串的递增和递减示例介绍
Feb 11 PHP
php获取域名的google收录示例
Mar 24 PHP
PHP跨平台获取服务器IP地址自定义函数分享
Dec 29 PHP
PHP易混淆知识整理笔记
Sep 24 PHP
在Mac OS上搭建PHP的Yii框架及相关测试环境
Feb 14 PHP
php实现mysql连接池效果实现代码
Jan 25 PHP
php实现姓名根据首字母排序的类与方法(实例代码)
May 16 PHP
PHP递归统计系统中代码行数
Sep 19 PHP
laravel使用数据库测试注意事项
Apr 10 PHP
PHP实现生成唯一编号(36进制的不重复编号)
Jul 01 #PHP
ThinkPHP使用smarty模板引擎的方法
Jul 01 #PHP
PHP使用GIFEncoder类处理gif图片实例
Jul 01 #PHP
ThinkPHP模板IF标签用法详解
Jul 01 #PHP
PHP使用GIFEncoder类生成gif动态滚动字幕
Jul 01 #PHP
PHP使用GIFEncoder类生成的GIF动态图片验证码
Jul 01 #PHP
ThinkPHP模板范围判断输出In标签与Range标签用法详解
Jun 30 #PHP
You might like
PHP中数组定义的几种方法
2013/09/01 PHP
php采用curl模仿登录人人网发布动态的方法
2014/11/07 PHP
浅谈PHP中如何实现Hook机制
2017/11/14 PHP
Laravel 登录后清空COOKIE的操作方法
2019/10/14 PHP
IE event.srcElement和FF event.target 功能比较
2010/03/01 Javascript
Javascript 类、命名空间、代码组织代码
2011/07/31 Javascript
浅谈JavaScript Math和Number对象
2015/01/26 Javascript
js实现文字跟随鼠标移动而移动的方法
2015/02/28 Javascript
jQuery选择器源码解读(三):tokenize方法
2015/03/31 Javascript
jQuery+jsp下拉框联动获取本地数据的方法(附源码)
2015/12/03 Javascript
angular+ionic返回上一页并刷新页面
2017/08/08 Javascript
详解Vue微信授权登录前后端分离较为优雅的解决方案
2018/06/29 Javascript
vue-cli webpack 引入swiper的操作方法
2018/09/15 Javascript
Javascript实现秒表计时游戏
2020/05/27 Javascript
深入理解 ES6中的 Reflect用法
2020/07/18 Javascript
[03:27]最受玩家喜爱奖提名:PZH_Element 致玩家寄语
2016/12/20 DOTA
Python解释执行原理分析
2014/08/22 Python
python daemon守护进程实现
2016/08/27 Python
Python基础语言学习笔记总结(精华)
2017/11/14 Python
Python实现替换文件中指定内容的方法
2018/03/19 Python
Python使用pickle模块实现序列化功能示例
2018/07/13 Python
Django框架搭建的简易图书信息网站案例
2019/05/25 Python
Python 面向对象之封装、继承、多态操作实例分析
2019/11/21 Python
python 如何利用argparse解析命令行参数
2020/09/11 Python
python各种excel写入方式的速度对比
2020/11/10 Python
大码女装:Ulla Popken
2019/08/06 全球购物
邮政员工辞职信
2014/01/16 职场文书
上课睡觉检讨书
2014/01/28 职场文书
大学自主招生自荐信范文
2014/02/26 职场文书
旅游市场营销方案
2014/03/09 职场文书
学习交流会主持词
2014/04/01 职场文书
承诺书格式范文
2014/06/03 职场文书
机电一体化毕业生自荐信
2014/06/19 职场文书
我爱家乡演讲稿
2014/09/12 职场文书
群众路线教育实践活动剖析材料
2014/09/30 职场文书
如何用JS实现网页瀑布流布局
2021/04/24 Javascript