濮阳杆衣贸易有限公司

主頁 > 知識庫 > PHP實現(xiàn)的XXTEA加密解密算法示例

PHP實現(xiàn)的XXTEA加密解密算法示例

熱門標簽:萍鄉(xiāng)商鋪地圖標注 桂陽公司如何做地圖標注 太原400電話申請流程 代理打電話機器人 企業(yè)400電話辦理多少費用 神龍斗士電話機器人 合肥企業(yè)外呼系統(tǒng)線路 電信外呼系統(tǒng)多少錢一個月 宿州正規(guī)外呼系統(tǒng)軟件

本文實例講述了PHP實現(xiàn)的XXTEA加密解密算法。分享給大家供大家參考,具體如下:

?php
/**
 * Xxtea 加密實現(xiàn)類
 */
class xxtea {
  private function long2str($v, $w) {
    $len = count($v);
    $n = ($len -1)  2;
    if ($w) {
      $m = $v[$len -1];
      if (($m  $n -3) || ($m > $n))
        return false;
      $n = $m;
    }
    $s = array ();
    for ($i = 0; $i  $len; $i++)
      $s[$i] = pack("V", $v[$i]);
    return $w ? substr(implode('', $s), 0, $n) : implode('', $s);
  }
  private function str2long($s, $w) {
    $v = unpack("V*", $s . str_repeat("/0", (4 - strlen($s) % 4)  3));
    $v = array_values($v);
    if ($w)
      $v[count($v)] = strlen($s);
    return $v;
  }
  private function int32($n) {
    while ($n >= 2147483648)
      $n -= 4294967296;
    while ($n = 2147483649)
      $n += 4294967296;
    return (int) $n;
  }
  public function encrypt($str, $key) {
    if ($str == '')
      return '';
    $v = $this->str2long($str, true);
    $k = $this->str2long($key, false);
    if (count($k)  4)
      for ($i = count($k); $i  4; $i++)
        $k[$i] = 0;
    $n = count($v) - 1;
    $z = $v[$n];
    $y = $v[0];
    $delta = 0x9E3779B9;
    $q = floor(6 + 52 / ($n +1));
    $sum = 0;
    while (0  $q--) {
      $sum = $this->int32($sum + $delta);
      $e = $sum >> 2  3;
      for ($p = 0; $p  $n; $p++) {
        $y = $v[$p +1];
        $mx = $this->int32((($z >> 5  0x07ffffff) ^ $y  2) + (($y >> 3  0x1fffffff) ^ $z  4)) ^ $this->int32(($sum ^ $y) + ($k[$p  3 ^ $e] ^ $z));
        $z = $v[$p] = $this->int32($v[$p] + $mx);
      }
      $y = $v[0];
      $mx = $this->int32((($z >> 5  0x07ffffff) ^ $y  2) + (($y >> 3  0x1fffffff) ^ $z  4)) ^ $this->int32(($sum ^ $y) + ($k[$p  3 ^ $e] ^ $z));
      $z = $v[$n] = $this->int32($v[$n] + $mx);
    }
    return $this->long2str($v, false);
  }
  public function decrypt($str, $key) {
    if ($str == '')
      return '';
    $v = $this->str2long($str, false);
    $k = $this->str2long($key, false);
    if (count($k)  4)
      for ($i = count($k); $i  4; $i++)
        $k[$i] = 0;
    $n = count($v) - 1;
    $z = $v[$n];
    $y = $v[0];
    $delta = 0x9E3779B9;
    $q = floor(6 + 52 / ($n +1));
    $sum = $this->int32($q * $delta);
    while ($sum != 0) {
      $e = $sum >> 2  3;
      for ($p = $n; $p > 0; $p--) {
        $z = $v[$p -1];
        $mx = $this->int32((($z >> 5  0x07ffffff) ^ $y  2) + (($y >> 3  0x1fffffff) ^ $z  4)) ^ $this->int32(($sum ^ $y) + ($k[$p  3 ^ $e] ^ $z));
        $y = $v[$p] = $this->int32($v[$p] - $mx);
      }
      $z = $v[$n];
      $mx = $this->int32((($z >> 5  0x07ffffff) ^ $y  2) + (($y >> 3  0x1fffffff) ^ $z  4)) ^ $this->int32(($sum ^ $y) + ($k[$p  3 ^ $e] ^ $z));
      $y = $v[0] = $this->int32($v[0] - $mx);
      $sum = $this->int32($sum - $delta);
    }
    return $this->long2str($v, true);
  }
}
//用法測試:
$strDemo = "www.jb51.net";
$key = "123456";
$pwd = new Xxtea();
$pwdrel = $pwd->encrypt($strDemo, $key);
echo $pwdrel;
echo "br/>";
echo $pwd->decrypt($pwdrel, $key);
?>

運行結果:

{���H(�S��7*�u7U
www.jb51.net

PS:關于加密解密感興趣的朋友還可以參考本站在線工具:

在線RSA加密/解密工具:
http://tools.jb51.net/password/rsa_encode

文字在線加密解密工具(包含AES、DES、RC4等):
http://tools.jb51.net/password/txt_encode

在線散列/哈希算法加密工具:
http://tools.jb51.net/password/hash_encrypt

在線MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.jb51.net/password/hash_md5_sha

在線sha1/sha224/sha256/sha384/sha512加密工具:
http://tools.jb51.net/password/sha_encode

更多關于PHP相關內容感興趣的讀者可查看本站專題:《php加密方法總結》、《PHP編碼與轉碼操作技巧匯總》、《PHP數(shù)學運算技巧總結》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結》、《PHP數(shù)據(jù)結構與算法教程》、《php程序設計算法總結》及《php正則表達式用法總結》

希望本文所述對大家PHP程序設計有所幫助。

您可能感興趣的文章:
  • 六種php加密解密方法實例講解
  • PHP rsa加密解密算法原理解析
  • 基于PHP實現(xiàn)解密或加密Cloudflar郵箱保護
  • php中加密解密DES類的簡單使用方法示例
  • php的RSA加密解密算法原理與用法分析
  • RSA實現(xiàn)JS前端加密與PHP后端解密功能示例
  • Js通過AES加密后PHP用Openssl解密的方法
  • PHP實現(xiàn)的AES雙向加密解密功能示例【128位】
  • PHP實現(xiàn)基于3DES算法加密解密字符串示例
  • PHP實現(xiàn)的AES加密、解密封裝類與用法示例
  • PHP實現(xiàn)的DES加密解密類定義與用法示例
  • 基于PHP RSA密文過長加密解密 越過1024的解決方法
  • PHP的RSA加密解密方法以及開發(fā)接口使用
  • PHP使用自定義key實現(xiàn)對數(shù)據(jù)加密解密的方法
  • php實現(xiàn)的三個常用加密解密功能函數(shù)示例
  • PHP代碼加密和擴展解密實戰(zhàn)

標簽:太原 廊坊 衡陽 綏化 鄂州 崇左 辛集 白銀

巨人網(wǎng)絡通訊聲明:本文標題《PHP實現(xiàn)的XXTEA加密解密算法示例》,本文關鍵詞  PHP,實現(xiàn),的,XXTEA,加密解密,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP實現(xiàn)的XXTEA加密解密算法示例》相關的同類信息!
  • 本頁收集關于PHP實現(xiàn)的XXTEA加密解密算法示例的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    屯留县| 武功县| 平罗县| 山阴县| 湾仔区| 余江县| 汝城县| 武汉市| 鄂托克旗| 登封市| 洛扎县| 北碚区| 吉首市| 永德县| 惠东县| 余干县| 高邑县| 衡阳县| 武功县| 福清市| 饶阳县| 阳东县| 二连浩特市| 佛坪县| 延吉市| 呼玛县| 桦甸市| 罗平县| 泸水县| 嘉峪关市| 龙泉市| 社会| 麻江县| 望奎县| 锡林浩特市| 灵武市| 营山县| 浏阳市| 安新县| 嘉义县| 当雄县|