主頁(yè) > 知識(shí)庫(kù) > PHP實(shí)現(xiàn)的XXTEA加密解密算法示例

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

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

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

?php
/**
 * Xxtea 加密實(shí)現(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);
  }
}
//用法測(cè)試:
$strDemo = "www.jb51.net";
$key = "123456";
$pwd = new Xxtea();
$pwdrel = $pwd->encrypt($strDemo, $key);
echo $pwdrel;
echo "br/>";
echo $pwd->decrypt($pwdrel, $key);
?>

運(yùn)行結(jié)果:

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

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

在線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

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

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

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

標(biāo)簽:太原 廊坊 衡陽(yáng) 綏化 鄂州 崇左 辛集 白銀

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP實(shí)現(xiàn)的XXTEA加密解密算法示例》,本文關(guān)鍵詞  PHP,實(shí)現(xiàn),的,XXTEA,加密解密,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP實(shí)現(xiàn)的XXTEA加密解密算法示例》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于PHP實(shí)現(xiàn)的XXTEA加密解密算法示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章