大家可能對這個算法很眼熟。一搜到處是這個算法!
不過這個算法不支持PHP7.0
今天調試好把它發出來
然后在分享一個 class類的 算法
每個網址用6個字符代替,(32^6) 最多可以擁有1,073,741,824個短網址。當然,你還可以記錄更詳細的信息,如訪問記錄,創建時間等。如果真不夠用了,還可以刪掉很久不用的。
修復版
<?php print_r(shorturl('http://www.zoe725.cn')); function shorturl($input){ $base32 = array('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5'); $hex = md5($input); $hexLen = strlen($hex); $subHexLen = $hexLen / 8; $output = array(); for ($i = 0; $i < 4; $i++) { //把加密字符按照8位一組16進制與0x3FFFFFFF(30位1)進行位與運算 $subHex = substr($hex, $i * 8, 8); $int = hexdec($subHex) & 0x3fffffff; //$int = 0x3fffffff & 1 * ('0x' . $subHex); $out = ''; for ($j = 0; $j < 6; $j++) { //把得到的值與0x0000001F進行位與運算,取得字符數組chars索引 $val = 0x1f & $int; $out .= $base32[$val]; $int = $int >> 5; } $output[] = $out; } return $output[]; }算法二
<?php $url = "http://www.cnblogs.com/zemliu/"; $short = Short_Url::short($url); print_r($short); class Short_Url { #字符表 public static $charset = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"; public static function short($url) { $key = "alexis"; $urlhash = md5($key . $url); $len = strlen($urlhash); #將加密后的串分成4段,每段4字節,對每段進行計算,一共可以生成四組短連接 for ($i = 0; $i < 4; $i++) { $urlhash_piece = substr($urlhash, $i * $len / 4, $len / 4); #將分段的位與0x3fffffff做位與,0x3fffffff表示二進制數的30個1,即30位以后的加密串都歸零 $hex = hexdec($urlhash_piece) & 0x3fffffff; #此處需要用到hexdec()將16進制字符串轉為10進制數值型,否則運算會不正常 $short_url = ''; #生成6位短連接 for ($j = 0; $j < 6; $j++) { #將得到的值與0x0000003d,3d為61,即charset的坐標最大值 $short_url .= self::$charset[$hex & 0x0000003d]; #循環完以后將hex右移5位 $hex = $hex >> 5; } $short_url_list[] = $short_url; } return $short_url_list; } }
轉載請注明出處 AE博客|墨淵 ? PHP網址縮短算法代碼(修復PHP7.0問題)
發表評論