php數(shù)字和字符串id互轉(zhuǎn)的實(shí)現(xiàn)方法:首先打開(kāi)相應(yīng)的PHP代碼文件;然后通過(guò)“alphaID(9007199254740989);”方式實(shí)現(xiàn)數(shù)字和字符串id互轉(zhuǎn)即可。
推薦:《PHP視頻教程》
PHP數(shù)字和字符串ID互轉(zhuǎn)函數(shù)(類(lèi)似優(yōu)酷ID)
不知道你注意了沒(méi)有,類(lèi)似優(yōu)酷、騰訊視頻等其他視頻鏈接似乎類(lèi)似這樣的
代碼如下:
http://v.youku.com/v_show/id_XNjA5MjE5OTM2.html
注意id_xxx那段,是不是看不懂了,但你無(wú)可否認(rèn)這個(gè)就是id,這不國(guó)外的一位牛人早在09年就寫(xiě)了針對(duì)PHP/Python/Javascript/Java/SQL的生成方法,可見(jiàn)我現(xiàn)在是多么的落伍,下面我把代碼貼出來(lái),希望分享精神永存。
代碼如下:
<?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);
執(zhí)行結(jié)果將被返回“fE2XnNGpF”,我們可以把它認(rèn)為是加密,進(jìn)行反解密則
代碼如下:
<?php alphaID('fE2XnNGpF', true);
那么就轉(zhuǎn)換成真實(shí)的數(shù)字“9007199254740989”。方法還可以支持使用key進(jìn)行加密,使得別人無(wú)法解得你真實(shí)的ID。