之前做网站,看很多新闻网站都对文章id进行了加密,加密后的url链接看起来比较美观。上次网站改版的时候找了一个加密数字的类,原作者:深秋的竹子,感觉十分好用。就收藏一下。
<?php /** * 加密解密类 * 该算法仅支持加密数字。比较适用于数据库中id字段的加密解密,以及根据数字显示url的加密。 * @author 深秋的竹子 * @version alpha * @加密原则 标记长度 + 补位 + 数字替换 * @加密步骤: * 将a-z,A-Z,0-9 62个字符打乱,取前M(数字最大的位数)位作为标记长度字符串, * 取第M+1到第M+10位为数字替换字符串,剩余的为补位字符串 * 1.计算数字长度n,取乱码的第n位作为标记长度。 * 2.计算补位的长度,加密串的长度N -1 - n 为补位的长度。根据指定的算法得到补位字符串。 * 3.根据数字替换字符串替换数字,得到数字加密字符串。 * 标记长度字符 + 补位字符串 + 数字加密字符串 = 加密串 * Usage: * $obj = new XDeode(9); * $e_txt = $obj->encode(123); * echo $e_txt.'<br/>'; * 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; } } ?>
thinkphp在使用的时候可以在ORG里新建一个XDeode.class.php文件,把上面的代码复制进去。在公共函数里定义两个加解密的函数。如下:
/** * 加密 * @param $val 传入数字 */ function encode($val){ import('@.ORG.Xdeode'); $XDeode = new Xdeode(); return $XDeode->encode($val); } /** * 解密 * @param $val 传入数字 */ function decode($val){ import('@.ORG.Xdeode'); $XDeode = new Xdeode(); return $XDeode->decode($val); }
就可以直接在写程序的时候使用传入要加密的id就可以。上面是我根据自己的需要来写的,也可以直接写一个函数来实现加密和解密的功能同时传入要生成的密匙的长度。
/** * 加密 * @param $deode e代表加密d代表解密; * $val 传入数字或者要解密的字符串; * $lenggth 要生成的字符串长度 */ function xdeode($deode,$val,$length){ import('@.ORG.Xdeode'); $XDeode = new Xdeode($length); if($deode == 'e'){ return $XDeode->encode($val); }else if($deode == 'd'){ return $XDeode->decode($val); } }
更推荐第一种的使用方式简单明了,使用也方便。
如果是没有使用框架,则可以把两个函数放到XDeode.class.php最底部,在需要使用该函数的地方,使用include或require引入XDeode.class.php就可以使用了。