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. $z = $v[$n];
  14. $y = $v[0];
  15. $delta = 0x9E3779B9;
  16. $q = floor(6 + 52 / ($n + 1));
  17. $sum = 0;
  18. while (0 < $q--) {
  19. $sum = int32($sum + $delta);
  20. $e = $sum >> 2 & 3;
  21. for ($p = 0; $p < $n; $p++) {
  22. $y = $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. $z = $v[$p] = int32($v[$p] + $mx);
  25. }
  26. $y = $v[0];
  27. $mx = int32((($z >> 5 & 0x07ffffff) ^ $y << 2) + (($y >> 3 & 0x1fffffff) ^ $z << 4)) ^ int32(($sum ^ $y) + ($k[$p & 3 ^ $e] ^ $z));
  28. $z = $v[$n] = int32($v[$n] + $mx);
  29. }
  30. return long2str($v, false);
  31. }

//核心解密函数

  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. $z = $v[$n];
  14. $y = $v[0];
  15. $delta = 0x9E3779B9;
  16. $q = floor(6 + 52 / ($n + 1));
  17. $sum = int32($q * $delta);
  18. while ($sum != 0) {
  19. $e = $sum >> 2 & 3;
  20. for ($p = $n; $p > 0; $p--) {
  21. $z = $v[$p - 1];
  22. $mx = int32((($z >> 5 & 0x07ffffff) ^ $y << 2) + (($y >> 3 & 0x1fffffff) ^ $z << 4)) ^ int32(($sum ^ $y) + ($k[$p & 3 ^ $e] ^ $z));
  23. $y = $v[$p] = int32($v[$p] - $mx);
  24. }
  25. $z = $v[$n];
  26. $mx = int32((($z >> 5 & 0x07ffffff) ^ $y << 2) + (($y >> 3 & 0x1fffffff) ^ $z << 4)) ^ int32(($sum ^ $y) + ($k[$p & 3 ^ $e] ^ $z));
  27. $y = $v[0] = int32($v[0] - $mx);
  28. $sum = int32($sum - $delta);
  29. }
  30. return long2str($v, true);
  31. }

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

  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加密解密函数用法的更多相关文章

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

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

  2. php中base64_decode与base64_encode加密解密函数

    php中base64_decode与base64_encode加密解密函数,实例分析了base64加密解密函数的具体用法,具有一定的实用价值,需要的朋友可以参考下 本文实例讲述了php中base64_ ...

  3. onethink加密解密函数

    onethink中封装的加密解密函数 <?php /** * 系统加密方法 * @param string $data 要加密的字符串 * @param string $key 加密密钥 * @ ...

  4. 各种加密解密函数(URL加密解密、sha1加密解密、des加密解密)

    原文:各种加密解密函数(URL加密解密.sha1加密解密.des加密解密) 普通hash函数如md5.sha1.base64等都是不可逆函数.虽然我们利用php可以利用这些函数写出可逆函数来.但是跨语 ...

  5. C# 字符串加密解密函数

    原文:C# 字符串加密解密函数 using System; using System.Text;using System.Security.Cryptography; using System.IO; ...

  6. PHP 2个比较经典的加密解密函数

    这篇文章主要介绍了2个比较经典的PHP加密解密函数分享,一个是Discuz!的authcode加密函数(带详细分解),一个是encrypt()函数,都比较经典,需要的朋友可以参考下 项目中有时我们需要 ...

  7. 介绍几个PHP 自带的加密解密函数

    PHP 自带的加密解密函数 目前经常使用的加密函数有:md5(), sha1(), crypt(), base64_encode(), urlencode() . 其中 md5(), sha1(), ...

  8. php自带加密解密函数

    php自带加密解密函数 一.总结 一句话总结:可逆和不可逆函数. 二.php自带加密解密函数 1.不可逆的加密函数为:md5().crypt() md5() 用来计算 MD5 哈稀.语法为:strin ...

  9. [PHP]加密解密函数

    非常给力的authcode加密函数,Discuz!经典代码(带详解) function authcode($string, $operation = 'DECODE', $key = '', $exp ...

随机推荐

  1. C#找到目录和其子目录的某个文件

    string url = ""; string[] urls = Directory.GetFiles(目录, 文件名, SearchOption.AllDirectories); ...

  2. Dapper相关了解

    公司新项目用的是Dapper,做的时候没有具体看dapper的具体用法,现在回来回顾总结一下. 1-总体介绍dapper 我们都知道ORM全称叫做Object Relationship Mapper, ...

  3. Gazebo学习随记3 图形界面的使用

    直接写模型的SDF文件实在是太反人类啦! 可以在gazebo图形界面中设置好模型的链接(碰撞外观惯性),关节等等参数-然后生成SDF文件

  4. 洛谷P3604 美好的每一天(莫队)

    传送门 由乃的题还是一如既往的可怕…… 先放上原题解 标解: 一个区间可以重排成为回文串,即区间中最多有一个字母出现奇数次,其他的都出现偶数次 发现这个和  类似 这样如果一个区间的  和为  或者  ...

  5. 使用remove_constants工具查看Oracle是否使用绑定变量

    https://asktom.oracle.com/pls/asktom/f?p=100:11:::::P11_QUESTION_ID:1163635055580 http://blog.csdn.n ...

  6. Scene is unreachable due to lack of entry points and does not have an identifier for runtime access via -instantiateViewControllerWithIdentifier解决办法

    使用Storyboard时出现以下警告: warning: Unsupported Configuration: Scene is unreachable due to lack of entry p ...

  7. asp.net mvc 中的 controller和asp.net web api 的apicontroller有什么区别?(转)

    本质上区别不大,一个返回html/text类型的response,一个返回json/text或者xml/text类型的response,对于api环境而言,apicontroller更智能一点,他可以 ...

  8. Step by Step: 基于MFC下的COM组件开发-Helloworld

    http://blog.csdn.net/sybifei/article/details/45008745 [这篇文章有问题, 仅供参考] http://blog.csdn.net/define_us ...

  9. spring boot +Thymeleaf+mybatis 集成通用PageHelper,做分页

    controller: /**  * 分页查询用户  * @param request  * @param response  * @return  * @throws Exception  */ @ ...

  10. ubuntu 16 64位编译安装php

    ./configure \ --prefix=/usr/local/php7 \ --exec-prefix=/usr/local/php7 \ --with-config-file-path=/us ...