• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

测试XXTea算法,网上没有一个php版本能还原我的字符串,太奇葩了。

php 搞代码 4年前 (2022-01-23) 14次浏览 已收录 0个评论
文章目录[隐藏]

Xxtea Xxtea算法

原文=”你是我的,sdfsdfsdfasd,error\4&:1234/?.,\3&%$#@@”;
还原过的 =你是我的,sdfsdfsdfasd,error&:1234/?.,&%$#@@;

只要遇到 \3,就不行。还有个别的\4,5,6,7,8,9本文来源gaodaimacom搞#^代%!码&网*

搞代gaodaima码

,有的能还原,有的不能。

网上的所有php版本的XXTea算法基本都测试过,全是同样的问题,很奇怪。有高手吗指点一二?

<?phpClass Xxtea {	public function encrypt($s, $key) {		return self :: xxtea_encrypt($s, $key);	}	public function decrypt($e, $key) {		return self :: xxtea_decrypt($e, $key);	}	private function long2str($v, $w) {		$len = count($v);		$n = ($len -1) << 2;		if ($w) {			$m = $v[$len -1];			if (($m  $n))				return false;			$n = $m;		}		$s = array ();		for ($i = 0; $i = 2147483648)			$n -= 4294967296;		while ($n <= -2147483649)			$n += 4294967296;		return (int) $n;	}	private function xxtea_encrypt($str, $key) {		if ($str == "") {			return "";		}		$v = self :: str2long($str, true);		$k = self :: 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 > 2 & 3;			for ($p = 0; $p > 5 & 0x07ffffff) ^ $y <> 3 & 0x1fffffff) ^ $z <> 5 & 0x07ffffff) ^ $y <> 3 & 0x1fffffff) ^ $z << 4)) ^ self :: int32(($sum ^ $y) + ($k[$p & 3 ^ $e] ^ $z));			$z = $v[$n] = self :: int32($v[$n] + $mx);		}		return self :: long2str($v, false);	}	private function xxtea_decrypt($str, $key) {		if ($str == "") {			return "";		}		$v = self :: str2long($str, false);		$k = self :: str2long($key, false);		if (count($k) < 4) {			for ($i = count($k); $i > 2 & 3;			for ($p = $n; $p > 0; $p--) {				$z = $v[$p -1];				$mx = self :: int32((($z >> 5 & 0x07ffffff) ^ $y <> 3 & 0x1fffffff) ^ $z <> 5 & 0x07ffffff) ^ $y <> 3 & 0x1fffffff) ^ $z <

附一个php版本的xxtea算法代码,其他版本的也存在同样的问题。

回复讨论(解决方案)

是否被转义了?

本帖最后由 xuzuning 于 2013-06-11 09:38:43 编辑

不就是个平衡加密么?只要加密、解密后与原文相同不就是对了吗?

echo $s = "你是我的,sdfsdfsdfasd,error\4&:1234/?.,\3&%$#@@", '<br>';echo $t = @Xxtea::decrypt(@xxtea::encrypt($s)), '<br>';var_dump($t == $s);echo '<p>';echo $s = '你是我的,sdfsdfsdfasd,error\4&:1234/?.,\3&%$#@@', '<br>';echo $t = @Xxtea::decrypt(@xxtea::encrypt($s)), '<br>';var_dump($t == $s);

你是我的,sdfsdfsdfasd,error&:1234/?.,&%$#@@
你是我的,sdfsdfsdfasd,error&:1234/?.,&%$#@@
bool(true)
你是我的,sdfsdfsdfasd,error\4&:1234/?.,\3&%$#@@
你是我的,sdfsdfsdfasd,error\4&:1234/?.,\3&%$#@@
bool(true)

\4是特殊字符,显示不出来正常


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:测试XXTea算法,网上没有一个php版本能还原我的字符串,太奇葩了。

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址