欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

PHP数字和字符串ID互转函数(类似优酷ID)

程序员文章站 2023-11-17 12:49:10
不知道你注意了没有,类似优酷、腾讯视频等其他视频链接似乎类似这样的 复制代码 代码如下: http://v.youku.com/v_show/id_xnja5mje5o...

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

复制代码 代码如下:

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。