详解 PHP加密解密字符串函数附源码下载

发布时间:2022-04-30 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了详解 PHP加密解密字符串函数附源码下载脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

项目中有时我们需要使用PHP将特定的信息进行加密,也就是通过加密算法生成@L_360_2@加密字符串,这个加密后的字符串可以通过解密算法进行解密,便于程序对解密后的信息进行处理。@H_406_1@

下面先给大家展示下效果图,感兴趣的朋友继续阅读全文。

详解 PHP加密解密字符串函数附源码下载

笔者收录了一些比较经典的PHP加密解密函数代码分享给大家。加密解密原理一般都是通过一定的加密解密算法,将密钥加入到算法中,最终得到加密解密结果。

1、非常给力的authcode加密函数,Discuz!经典代码(带详解):

生成不同密文就是依靠动态密匙 
 $ckey_length = 4; 
 // 密匙 
 $key = md5($key ? $key : $GLOBALS['discuz_auth_key']); 
 // 密匙a会参与加解密 
 $keya = md5(substr($key,16)); 
 // 密匙b会用来做数据完整性验证 
 $keyb = md5(substr($key,16,16)); 
 // 密匙c用于变化生成的密文 
 $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string,$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),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,10)="=" 0="" ||="" substr($result,10)="" -="" time()=""> 0) && 
substr($result,10,16) == substr(md5(substr($result,26).$keyb),16)) { 
  return substr($result,26); 
 } else { 
  return ''; 
 } 
 } else { 
 // 把动态密匙保存在密文里,这也是为什么同样的明文,生产不同密文后能解密的原因 
 // 因为加密后的密文可能是一些特殊字符,复制过程可能会丢失,所以用base64编码 
 return $keyc.str_replace('=','',base64_encode($result)); 
 } 
}

脚本宝典总结

以上是脚本宝典为你收集整理的详解 PHP加密解密字符串函数附源码下载全部内容,希望文章能够帮你解决详解 PHP加密解密字符串函数附源码下载所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: