php id编码,php 可加密解密64编码解码,用于对ID的编码解码

[php]代码库<?php

/**

* 可加密64编码解码,用于对ID的编码解码

*/

class code {

private $key = null;

function __construct($key) {

$this->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

694748ed64b9390909c0d88230893790.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值