PHP数字和字符串ID互转函数(类似优酷ID)_php教程-查字典教程网
PHP数字和字符串ID互转函数(类似优酷ID)
PHP数字和字符串ID互转函数(类似优酷ID)
发布时间:2016-12-29 来源:查字典编辑
摘要:不知道你注意了没有,类似优酷、腾讯视频等其他视频链接似乎类似这样的复制代码代码如下:http://v.youku.com/v_show/id...

不知道你注意了没有,类似优酷、腾讯视频等其他视频链接似乎类似这样的

复制代码 代码如下:

http://v.youku.com/v_show/id_XNjA5MjE5OTM2.html

注意id_xxx那段,是不是看不懂了,但你无可否认这个就是id,这不国外的一位牛人早在09年就写了针对PHP/Python/Javascript/Java/SQL的生成方法,可见我现在是多么的落伍,下面我把代码贴出来,希望分享精神永存。

复制代码 代码如下:

<?php

/**

* @author Kevin van Zonneveld <kevin@vanzonneveld.net>

* @author Simon Franz

* @author Deadfish

* @copyright 2008 Kevin van Zonneveld (http://kevin.vanzonneveld.net)

* @license http://www.opensource.org/licenses/bsd-license.php New BSD Licence

* @version SVN: Release: $Id: alphaID.inc.php 344 2009-06-10 17:43:59Z kevin $

* @link http://kevin.vanzonneveld.net/

*

* @param mixed $in String or long input to translate

* @param boolean $to_num Reverses translation when true

* @param mixed $pad_up Number or boolean padds the result up to a specified length

* @param string $passKey Supplying a password makes it harder to calculate the original ID

*

* @return mixed string or long

*/

function alphaID($in, $to_num = false, $pad_up = false, $passKey = null)

{

$index = "abcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";

if ($passKey !== null) {

// Although this function's purpose is to just make the

// ID short - and not so much secure,

// with this patch by Simon Franz (http://blog.snaky.org/)

// you can optionally supply a password to make it harder

// to calculate the corresponding numeric ID

for ($n = 0; $n<strlen($index); $n++) {

$i[] = substr( $index,$n ,1);

}

$passhash = hash('sha256',$passKey);

$passhash = (strlen($passhash) < strlen($index))

? hash('sha512',$passKey)

: $passhash;

for ($n=0; $n < strlen($index); $n++) {

$p[] = substr($passhash, $n ,1);

}

array_multisort($p, SORT_DESC, $i);

$index = implode($i);

}

$base = strlen($index);

if ($to_num) {

// Digital number < 0) {

$out -= pow($base, $pad_up);

}

}

$out = sprintf('%F', $out);

$out = substr($out, 0, strpos($out, '.'));

} else {

// Digital number -->> alphabet letter code

if (is_numeric($pad_up)) {

$pad_up--;

if ($pad_up > 0) {

$in += pow($base, $pad_up);

}

}

$out = "";

for ($t = floor(log($in, $base)); $t >= 0; $t--) {

$bcp = bcpow($base, $t);

$a = floor($in / $bcp) % $base;

$out = $out . substr($index, $a, 1);

$in = $in - ($a * $bcp);

}

$out = strrev($out); // reverse

}

return $out;

}

使用举例

复制代码 代码如下:<?php

alphaID(9007199254740989);

执行结果将被返回“fE2XnNGpF”,我们可以把它认为是加密,进行反解密则

复制代码 代码如下:<?php

alphaID('fE2XnNGpF', true);

那么就转换成真实的数字“9007199254740989”。方法还可以支持使用key进行加密,使得别人无法解得你真实的ID。

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新php教程学习
    热门php教程学习
    编程开发子分类