码迷,mamicode.com
首页 > Web开发 > 详细

TP扩展Xxtea.class.php加密解密函数用法

时间:2016-04-19 17:22:26      阅读:193      评论:0      收藏:0      [点我收藏+]

标签:

http://www.coolcode.org/?action=show&id=128
这里可以查到一个相关文章.

附上xiunobbs里的代码,自己加了点注释,欢迎大牛批评指正

//将数值数组还原成字符串,$v为str2long返回的数组,$w为bool值(数组中是否包函原str长度)

  1. function long2str($v, $w) {
  2.     $len = count($v);
  3.     $n = ($len - 1) << 2;
  4.     if ($w) {
  5.         $m = $v[$len - 1];
  6.         if (($m < $n - 3) || ($m > $n)) return false;
  7.         $n = $m;
  8.     }
  9.     $s = array();
  10.     for ($i = 0; $i < $len; $i++) {
  11.         $s[$i] = pack("V", $v[$i]);
  12.     }
  13.     if ($w) {
  14.         return substr(join(‘‘, $s), 0, $n);
  15.     }
  16.     else {
  17.         return join(‘‘, $s);
  18.     }
  19.  }

//将字符串转换成数值数组,$s要转换的字符串,$w为bool值(数组中是否包函原str长度)

  1. function str2long($s, $w) {
  2.     $v = unpack("V*", $s. str_repeat("\0", (4 - strlen($s) % 4) & 3));
  3.     $v = array_values($v);
  4.     if ($w) {
  5.         $v[count($v)] = strlen($s);
  6.     }
  7.     return $v;
  8.  }
  1. function int32($n) {
  2.     while ($n >= 2147483648) $n -= 4294967296;
  3.     while ($n <= -2147483649) $n += 4294967296; 
  4.     return (int)$n;
  5.  }

//核心加密函数

  1. function xxtea_encrypt($str, $key) {
  2.     if ($str == "") {
  3.         return "";
  4.     }
  5.     $v = str2long($str, true);
  6.     $k = str2long($key, false);
  7.     if (count($k) < 4) {
  8.         for ($i = count($k); $i < 4; $i++) {
  9.             $k[$i] = 0;
  10.         }
  11.     }
  12.     $n = count($v) - 1;
  13.  
  14.     $z = $v[$n];
  15.     $y = $v[0];
  16.     $delta = 0x9E3779B9;
  17.     $q = floor(6 + 52 / ($n + 1));
  18.     $sum = 0;
  19.     while (0 < $q--) {
  20.         $sum = int32($sum + $delta);
  21.         $e = $sum >> 2 & 3;
  22.         for ($p = 0; $p < $n; $p++) {
  23.             $y = $v[$p + 1];
  24.             $mx = int32((($z >> 5 & 0x07ffffff) ^ $y << 2) + (($y >> 3 & 0x1fffffff) ^ $z << 4)) ^ int32(($sum ^ $y) + ($k[$p & 3 ^ $e] ^ $z));
  25.             $z = $v[$p] = int32($v[$p] + $mx);
  26.         }
  27.         $y = $v[0];
  28.         $mx = int32((($z >> 5 & 0x07ffffff) ^ $y << 2) + (($y >> 3 & 0x1fffffff) ^ $z << 4)) ^ int32(($sum ^ $y) + ($k[$p & 3 ^ $e] ^ $z));
  29.         $z = $v[$n] = int32($v[$n] + $mx);
  30.     }
  31.     return long2str($v, false);
  32.  }

//核心解密函数

  1. function xxtea_decrypt($str, $key) {
  2.     if ($str == "") {
  3.         return "";
  4.     }
  5.     $v = str2long($str, false);
  6.     $k = str2long($key, false);
  7.     if (count($k) < 4) {
  8.         for ($i = count($k); $i < 4; $i++) {
  9.             $k[$i] = 0;
  10.         }
  11.     }
  12.     $n = count($v) - 1;
  13.  
  14.     $z = $v[$n];
  15.     $y = $v[0];
  16.     $delta = 0x9E3779B9;
  17.     $q = floor(6 + 52 / ($n + 1));
  18.     $sum = int32($q * $delta);
  19.     while ($sum != 0) {
  20.         $e = $sum >> 2 & 3;
  21.         for ($p = $n; $p > 0; $p--) {
  22.             $z = $v[$p - 1];
  23.             $mx = int32((($z >> 5 & 0x07ffffff) ^ $y << 2) + (($y >> 3 & 0x1fffffff) ^ $z << 4)) ^ int32(($sum ^ $y) + ($k[$p & 3 ^ $e] ^ $z));
  24.             $y = $v[$p] = int32($v[$p] - $mx);
  25.         }
  26.         $z = $v[$n];
  27.         $mx = int32((($z >> 5 & 0x07ffffff) ^ $y << 2) + (($y >> 3 & 0x1fffffff) ^ $z << 4)) ^ int32(($sum ^ $y) + ($k[$p & 3 ^ $e] ^ $z));
  28.         $y = $v[0] = int32($v[0] - $mx);
  29.         $sum = int32($sum - $delta);
  30.     }
  31.     return long2str($v, true);
  32.  }

//包装修正后的加密函数,加密的文本越长返回值越长

  1. function encrypt($txt, $key = ‘abcd9667676effff‘) {
  2.     $s = urlencode(base64_encode(xxtea_encrypt($txt, $key)));
  3.     $s = str_replace(‘%2F‘, ‘%252F‘, $s);    // fix nginx %2F 导致 rewrite 失效的问题
  4.     return $s;
  5.  }

//包装修正后的解密函数,如果密钥不正确则返回值为空

  1. function decrypt($txt, $key = ‘abcd9667676effff‘) {
  2.     $txt = str_replace(‘%252F‘, ‘%2F‘, $txt);    // fix nginx %2F 导致 rewrite 失效的问题
  3.     return xxtea_decrypt(base64_decode(urldecode($txt)), $key);    
  4.  }

用法
$v= encrypt(‘huqinlou0123@163.com‘,‘huqinlou‘);//加密,密钥为huqinlou
echo decrypt($v,‘huqinlou‘);//解密

TP扩展Xxtea.class.php加密解密函数用法

标签:

原文地址:http://www.cnblogs.com/echohao/p/5408703.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!