复制代码 代码如下:
encode(123);
* echo $e_txt.'
';
* echo $key->decode($e_txt);
*/
class xdeode{
private $strbase = flpvf70csakvjqgewupxqxsyjizmnh6b1u3b8caekwtd54nrtzomdhog2ylri;
private $key,$length,$codelen,$codenums,$codeext;
function __construct($length = 9,$key = 2543.5415412812){
$this->key = $key;
$this->length = $length;
$this->codelen = substr($this->strbase,0,$this->length);
$this->codenums = substr($this->strbase,$this->length,10);
$this->codeext = substr($this->strbase,$this->length + 10);
}
function encode($nums){
$rtn = ;
$numslen = strlen($nums);
//密文第一位标记数字的长度
$begin = substr($this->codelen,$numslen - 1,1);
//密文的扩展位
$extlen = $this->length - $numslen - 1;
$temp = str_replace('.', '', $nums / $this->key);
$temp = substr($temp,-$extlen);
$arrexttemp = str_split($this->codeext);
$arrext = str_split($temp);
foreach ($arrext as $v) {
$rtn .= $arrexttemp[$v];
}
$arrnumstemp = str_split($this->codenums);
$arrnums = str_split($nums);
foreach ($arrnums as $v) {
$rtn .= $arrnumstemp[$v];
}
return $begin.$rtn;
}
function decode($code){
$begin = substr($code,0,1);
$rtn = '';
$len = strpos($this->codelen,$begin);
if($len!== false){
$len++;
$arrnums = str_split(substr($code,-$len));
foreach ($arrnums as $v) {
$rtn .= strpos($this->codenums,$v);
}
}
return $rtn;
}
}
/**** 示例 ****/
$begin = 9950;
$end = $begin + 50;
$obj = new xdeode(9);
for($i=$begin;$i $en = $obj->encode($i);
$de = $obj->decode($en);
echoln([{$i}]=[{$en}]=[{$de}]);
}
function echoln($str){
echo {$str}
;
}
?>
运行示例结果:[9950]=[vmizxppga]=[9950]
[9951]=[vsnssppgk]=[9951]
[9952]=[vnqnyppgv]=[9952]
[9953]=[vyyjjppgj]=[9953]
[9954]=[vnzqzppgq]=[9954]
[9955]=[vynzmppgg]=[9955]
[9956]=[vxxsnppge]=[9956]
[9957]=[vxjjjppgw]=[9957]
[9958]=[vxziqppgu]=[9958]
[9959]=[vixxsppgp]=[9959]
[9960]=[vqxmyppea]=[9960]
[9961]=[vijyjppek]=[9961]
http://www.bkjia.com/phpjc/743929.htmlwww.bkjia.comtruehttp://www.bkjia.com/phpjc/743929.htmltecharticle复制代码 代码如下: ?php /** * 加密解密类 * 该算法仅支持加密数字。比较适用于数据库中id字段的加密解密,以及根据数字显示url的加密。...