异或的符号是^。按位异或运算, 对等长二进制模式按位或二进制数的每一位执行逻辑按位异或操作. 操作的结果是如果某位不同则该位为1, 否则该位为0.
xor运算的逆运算是它本身,也就是说两次异或同一个数最后结果不变,即(a xor b) xor b = a。xor运算可以用于简单的加密,比如我想对我MM说1314520,但怕别人知道,于是双方约定拿我的生日19880516作为密钥。1314520 xor 19880516 = 20665500,我就把20665500告诉MM。MM再次计算20665500 xor 19880516的值,得到1314520,于是她就明白了我的企图。
相同位不同则为1,相同则为0。
00101
11100
(^或者xor)
----------------
11001
运算结果
x <- x # y
y <- x @ y
x <- x @ y
执行了第一句后x变成了x # y。那么第二句实质就是y <- x # y @ y,由于#和@互为逆运算,那么此时的y变成了原来的x。第三句中x实际上被赋值为(x # y) @ x,如果#运算具有交换律,那么赋值后x就变成最初的y了。这三句话的结果是,x和y的位置互换了。
通过这个原理运用PHP可实现简单高效的加密
注意:
PHP语言的^运算符经常用来做加密的运算,解密也直接用^就行,但是和其他语言通信时,其他语言例如objective-c未必能解的出来PHP的^,尤其是当php使用多个字符串如:'abc'^'def',这样的运算时,其他语言少有这种直接可运算的,更不能解的出来 计算原理: 'a'^'b' : a和b的ASCII分别为97和98,转换2进制后分别为:1100001,1100010 然后使用此二位进行异或运算,得到结果:11 再用把二进制数11转换为字符串 在windon命令行下计算结果会显示一个乱码
以下为实现方法:
<?php $k = 'app'; $v = '321'; echo '秘钥:'.$k; echo '</br>'; echo '明文:'.$v; echo '</br>'; $key = sha1($k); echo 'sha1加密秘钥:'.$key; echo '</br>'; $yihuo = $v ^ $key; echo '异或运算:'.$yihuo; echo '</br>'; echo 'base64_encode编码:'.base64_encode($yihuo); //按位异或运算加密 function xorencrypt( $str, $key ){ $slen = strlen( $str ); $klen = strlen( $key ); $cipher = ''; for ($i=0;$i<$slen;$i=$i+$klen) { $cipher .