zoukankan      html  css  js  c++  java
  • TP扩展Xxtea.class.php加密解密函数用法

    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("", (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');//解密

  • 相关阅读:
    S3C2440实现dm9000网卡驱动程序移植
    IMX257虚拟网卡vnet驱动程序
    ram_flash驱动
    S3C2440 nor_flash驱动程序
    Java 打印* 三角形
    Java系列学习说明
    java案例1,打印hello java
    zabbixproxy安装
    python鉴黄程序
    mssql发布订阅事项
  • 原文地址:https://www.cnblogs.com/echohao/p/5408703.html
Copyright © 2011-2022 走看看