长链接转短链接

<?php
/**
 * @author http://weibo.com/codersay
 * 
 * 功能说明:由长连接生成短链接操作
 *
 * 算法描述:使用6个字符来表示短链接,我们使用ASCII字符中的'a'-'z','0'-'9','A'-'Z',共计62个字符做为集合。
 * 		     每个字符有62种状态,六个字符就可以表示62^6(56800235584),那么如何得到这六个字符,
 *           具体描述如下:
 *		  1. 对传入的长URL+设置key值 进行Md5,得到一个32位的字符串(32 字符十六进制数),即16的32次方;
 *        2. 将这32位分成四份,每一份8个字符,将其视作16进制串与0x3fffffff(30位1)与操作, 即超过30位的忽略处理;
 *		  3. 这30位分成6段, 每5个一组,算出其整数值,然后映射到我们准备的62个字符中, 依次进行获得一个6位的短链接地址。
 */
  

 $url = 'http://list.tmall.com/search_product.htm?spm=3.1000473.a2223p1.4.naAM6o&active=1&from=sn_1_cat&area_code=330100&search_condition=7&vmarket=0&style=g&sort=s&n=60&s=0&cat=50041288#J_crumbs 中文字符yyg';
 $urlarr =  shortUrl($url);
 print_r($urlarr);

	function shortUrl( $long_url )
	{
		$key = 'codersay';
		$base32 = "abcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
	
		// 利用md5算法方式生成hash值
		$hex = hash('md5', $long_url.$key);
		$hexLen = strlen($hex);
		$subHexLen = $hexLen / 8;
	
		$output = array();
		for( $i = 0; $i < $subHexLen; $i++ )
		{
			// 将这32位分成四份,每一份8个字符,将其视作16进制串与0x3fffffff(30位1)与操作
			$subHex = substr($hex, $i*8, 8);
			$idx = 0x3FFFFFFF & (1 * ('0x' . $subHex));
			 
			// 这30位分成6段, 每5个一组,算出其整数值,然后映射到我们准备的62个字符
			$out = '';
			for( $j = 0; $j < 6; $j++ )
			{
				$val = 0x0000003D & $idx;
				$out .= $base32[$val];
				$idx = $idx >> 5;
			}
			$output[$i] = $out;
		}
	
		return $output;
	}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值