key = $key; } /** * 对数字编码 */ function encode($value) { $x = sprintf("%d", intval($value) ^ intval($this->key)); $y = $this->encode_b64(intval($x)); return $y; } /** *解码 */ function decode($pwd) { $pwd = $this->decode_b64($pwd); $re = strval(intval($pwd) ^ intval($this->key)); return $re; } /** * 重置密钥 */ function reset_key($key) { $this->key = $key; } /** * 64进位编码 */ public function encode_b64($n) { $table = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ-_'; $result = array(); $temp = $n; if (0 == $temp) { $result[] = '0'; } else { while (0 < $temp) { $result[] = $table[$temp % 64]; $temp = intval($temp / 64); } } //反转数组 krsort($result); return implode('', $result); } /** * 64进位解码 */ public function decode_b64($str) { $table = array("0" => 0, "1" => 1, "2" => 2, "3" => 3, "4" => 4, "5" => 5, "6" => 6, "7" => 7, "8" => 8, "9" => 9, "a" => 10, "b" => 11, "c" => 12, "d" => 13, "e" => 14, "f" => 15, "g" => 16, "h" => 17, "i" => 18, "j" => 19, "k" => 20, "l" => 21, "m" => 22, "n" => 23, "o" => 24, "p" => 25, "q" => 26, "r" => 27, "s" => 28, "t" => 29, "u" => 30, "v" => 31, "w" => 32, "x" => 33, "y" => 34, "z" => 35, "A" => 36, "B" => 37, "C" => 38, "D" => 39, "E" => 40, "F" => 41, "G" => 42, "H" => 43, "I" => 44, "J" => 45, "K" => 46, "L" => 47, "M" => 48, "N" => 49, "O" => 50, "P" => 51, "Q" => 52, "R" => 53, "S" => 54, "T" => 55, "U" => 56, "V" => 57, "W" => 58, "X" => 59, "Y" => 60, "Z" => 61, "-" => 62, "_" => 63); $result = 0; foreach (range(0, strlen($str) - 1) as $i) { $result *= 64; $result += $table[$str[$i]]; } return $result; } } $d = new code('123123'); echo $d->encode(222584587), "\\n"; echo $d->decode('dhr_U'), "\\n"; $d = new code('333333'); echo $d->encode(222584587), "\\n"; echo $d->decode('dgkAu'), "\\n"; //该片段来自于http://yuncode.net