PHP封装的字符串加密解密函数

这篇文章主要给大家汇总介绍了PHP封装的字符串加密解密函数以及使用方法,非常的简单实用,有需要的小伙伴可以参考下。

程序中经常使用的PHP加密解密字符串函数,代码如下:

  1. /*********************************************************************
  2. 函数名称:encrypt
  3. 函数作用:加密解密字符串
  4. 使用方法:
  5. 加密 :encrypt('str','E','nowamagic');
  6. 解密 :encrypt('被加密过的字符串','D','nowamagic');
  7. 参数说明:
  8. $string :需要加密解密的字符串
  9. $operation:判断是加密还是解密:E:加密 D:解密
  10. $key :加密的钥匙(密匙);
  11. *********************************************************************/
  12. function encrypt($string,$operation,$key='')
  13. {
  14. $key=md5($key);
  15. $key_length=strlen($key);
  16. $string=$operation=='D'?base64_decode($string):substr(md5($string.$key),0,8).$string;
  17. $string_length=strlen($string);
  18. $rndkey=$box=array();
  19. $result='';
  20. for($i=0;$i<=255;$i++)
  21. {
  22. $rndkey[$i]=ord($key[$i%$key_length]);
  23. $box[$i]=$i;
  24. }
  25. for($j=$i=0;$i<256;$i++)
  26. {
  27. $j=($j+$box[$i]+$rndkey[$i])%256;
  28. $tmp=$box[$i];
  29. $box[$i]=$box[$j];
  30. $box[$j]=$tmp;
  31. }
  32. for($a=$j=$i=0;$i<$string_length;$i++)
  33. {
  34. $a=($a+1)%256;
  35. $j=($j+$box[$a])%256;
  36. $tmp=$box[$a];
  37. $box[$a]=$box[$j];
  38. $box[$j]=$tmp;
  39. $result.=chr(ord($string[$i])^($box[($box[$a]+$box[$j])%256]));
  40. }
  41. if($operation=='D')
  42. {
  43. if(substr($result,0,8)==substr(md5(substr($result,8).$key),0,8))
  44. {
  45. return substr($result,8);
  46. }
  47. else
  48. {
  49. return'';
  50. }
  51. }
  52. else
  53. {
  54. return str_replace('=','',base64_encode($result));
  55. }
  56. }

使用方法:

  1. $id = 132;
  2. $token = encrypt($id, 'E', 'a');
  3. echo '加密:'.encrypt($id, 'E', 'a');
  4. echo '<br />';
  5. echo '解密:'.encrypt($token, 'D', 'a');

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

  1. function authcode($string, $operation = 'DECODE', $key = '', $expiry = 0) {
  2. // 动态密匙长度,相同的明文会生成不同密文就是依靠动态密匙
  3. $ckey_length = 4;
  4. // 密匙
  5. $key = md5($key ? $key : $GLOBALS['discuz_auth_key']);
  6. // 密匙a会参与加解密
  7. $keya = md5(substr($key, 0, 16));
  8. // 密匙b会用来做数据完整性验证
  9. $keyb = md5(substr($key, 16, 16));
  10. // 密匙c用于变化生成的密文
  11. $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length):
  12. substr(md5(microtime()), -$ckey_length)) : '';
  13. // 参与运算的密匙
  14. $cryptkey = $keya.md5($keya.$keyc);
  15. $key_length = strlen($cryptkey);
  16. // 明文,前10位用来保存时间戳,解密时验证数据有效性,10到26位用来保存$keyb(密匙b),
  17. //解密时会通过这个密匙验证数据完整性
  18. // 如果是解码的话,会从第$ckey_length位开始,因为密文前$ckey_length位保存 动态密匙,以保证解密正确
  19. $string = $operation == 'DECODE' ? base64_decode(substr($string, $ckey_length)) :
  20. sprintf('%010d', $expiry ? $expiry + time() : 0).substr(md5($string.$keyb), 0, 16).$string;
  21. $string_length = strlen($string);
  22. $result = '';
  23. $box = range(0, 255);
  24. $rndkey = array();
  25. // 产生密匙簿
  26. for($i = 0; $i <= 255; $i++) {
  27. $rndkey[$i] = ord($cryptkey[$i % $key_length]);
  28. }
  29. // 用固定的算法,打乱密匙簿,增加随机性,好像很复杂,实际上对并不会增加密文的强度
  30. for($j = $i = 0; $i < 256; $i++) {
  31. $j = ($j + $box[$i] + $rndkey[$i]) % 256;
  32. $tmp = $box[$i];
  33. $box[$i] = $box[$j];
  34. $box[$j] = $tmp;
  35. }
  36. // 核心加解密部分
  37. for($a = $j = $i = 0; $i < $string_length; $i++) {
  38. $a = ($a + 1) % 256;
  39. $j = ($j + $box[$a]) % 256;
  40. $tmp = $box[$a];
  41. $box[$a] = $box[$j];
  42. $box[$j] = $tmp;
  43. // 从密匙簿得出密匙进行异或,再转成字符
  44. $result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256]));
  45. }
  46. if($operation == 'DECODE') {
  47. // 验证数据有效性,请看未加密明文的格式
  48. if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) &&
  49. substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16)) {
  50. return substr($result, 26);
  51. } else {
  52. return '';
  53. }
  54. } else {
  55. // 把动态密匙保存在密文里,这也是为什么同样的明文,生产不同密文后能解密的原因
  56. // 因为加密后的密文可能是一些特殊字符,复制过程可能会丢失,所以用base64编码
  57. return $keyc.str_replace('=', '', base64_encode($result));
  58. }
  59. }

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

用法:

  1. $str = 'abcdef';
  2. $key = 'www.phpfensi.com';
  3. echo authcode($str,'ENCODE',$key,0); //加密
  4. $str = '56f4yER1DI2WTzWMqsfPpS9hwyoJnFP2MpC8SOhRrxO7BOk';
  5. echo authcode($str,'DECODE',$key,0); //解密

3、加解密函数encrypt():

  1. function encrypt($string,$operation,$key=''){
  2. $key=md5($key);
  3. $key_length=strlen($key);
  4. $string=$operation=='D'?base64_decode($string):substr(md5($string.$key),0,8).$string;
  5. $string_length=strlen($string);
  6. $rndkey=$box=array();
  7. $result='';
  8. for($i=0;$i<=255;$i++){
  9. $rndkey[$i]=ord($key[$i%$key_length]);
  10. $box[$i]=$i;
  11. }
  12. for($j=$i=0;$i<256;$i++){
  13. $j=($j+$box[$i]+$rndkey[$i])%256;
  14. $tmp=$box[$i];
  15. $box[$i]=$box[$j];
  16. $box[$j]=$tmp;
  17. }
  18. for($a=$j=$i=0;$i<$string_length;$i++){
  19. $a=($a+1)%256;
  20. $j=($j+$box[$a])%256;
  21. $tmp=$box[$a];
  22. $box[$a]=$box[$j];
  23. $box[$j]=$tmp;
  24. $result.=chr(ord($string[$i])^($box[($box[$a]+$box[$j])%256]));
  25. }
  26. if($operation=='D'){
  27. if(substr($result,0,8)==substr(md5(substr($result,8).$key),0,8)){
  28. return substr($result,8);
  29. }else{
  30. return'';
  31. }
  32. }else{
  33. return str_replace('=','',base64_encode($result));
  34. }
  35. }

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

用法:

  1. $str = 'abc';
  2. $key = 'www.phpfensi.com';
  3. $token = encrypt($str, 'E', $key);
  4. echo '加密:'.encrypt($str, 'E', $key);
  5. echo '解密:'.encrypt($str, 'D', $key);