2011年8月4日木曜日

[PHP]URL短縮用62進数ハッシュ

URL短縮サービスによく使われている手法をメモ
DBに登録された自動発番の数値を単純に0​-9,a-z,A-Zの62進数で変換します。

  1. /** 
  2.  * 数値を0-9,a-z,A-Zの62進数に変換する 
  3.  */  
  4. function getEncodeToBase62($id$base = 0)  
  5. {  
  6.     $sbox = array(  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61);  
  7.     $char = array( 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 97, 98, 99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122);  
  8.     $hash = array();  
  9.     $i = 0;  
  10.     do  
  11.     {  
  12.         $hash[$i] = chr$char[$sbox[(int)( floor$id / pow( 62, $i )) + $i ) % 62]] );  
  13.         $i = count($hash);  
  14.     } while(( $base > $i ) || ( pow( 62, $i ) <= $id ));  
  15.   
  16.     return implode( ""$hash );  
  17. }  

0 件のコメント:

コメントを投稿