php实现短链接系统
短链接的好处:
节省网址长度,便于社交化传播。(短信或者微博,字数长度受限制时。这样的短链接制作二维码也是易于识别)
方便后台跟踪点击量、地域分布等用户统计。(统计流量访问,延伸可以做网址举报屏蔽。只屏蔽短链接即可,控制输出)
规避关键词、域名屏蔽手段。
隐藏真实地址,适合做付费推广链接。
然后组合成 http://域名/编码参数/。我们既得到了短链接。当我们访问短链接时,解析参数转为10进制。到数据库中查找获得相应的链接,进行301跳转。此功能既为完成。
1.1 修改hosts文件,将测试域名指向本机ip
1.2 配置apache,添加虚拟域名映射,参考:http://blog.csdn.net/nuli888/article/details/51830659
4、创建短链接生成与长链接获取功能
节省网址长度,便于社交化传播。(短信或者微博,字数长度受限制时。这样的短链接制作二维码也是易于识别)
方便后台跟踪点击量、地域分布等用户统计。(统计流量访问,延伸可以做网址举报屏蔽。只屏蔽短链接即可,控制输出)
规避关键词、域名屏蔽手段。
隐藏真实地址,适合做付费推广链接。
实现思路:
将传入的长链接存入数据库中,并记录创建时间,返回自增ID。
将返回的id进行10进制转64进制编码:如自增id为10时,64进制转换为A;即使当我们记录到1亿条时,1亿的64进制为:F9eEA,才5个字符长度,非常适合作为短链接的参数。然后组合成 http://域名/编码参数/。我们既得到了短链接。当我们访问短链接时,解析参数转为10进制。到数据库中查找获得相应的链接,进行301跳转。此功能既为完成。
步骤如下:
1、修改host文件->配置网站虚拟目录->进行URL重写1.1 修改hosts文件,将测试域名指向本机ip
C:WindowsSystem32driversetchosts 127.0.0.1 d.cn
1.2 配置apache,添加虚拟域名映射,参考:http://blog.csdn.net/nuli888/article/details/51830659
<VirtualHost *:80> DocumentRoot "D:/webroot/test/link" ServerName d.cn <Directory "D:/webroot/test/link"> DirectoryIndex index.html index.php AllowOverride All Order deny,allow Allow from all </Directory> </VirtualHost> <VirtualHost *:80> DocumentRoot "D:/webroot" ServerName localhost <Directory "D:/webroot"> DirectoryIndex index.html index.PHP AllowOverride All Order deny,allow Allow from all </Directory> </VirtualHost>
1.3 配置.htaccess文件,将短连接重定向,设置如下:
<IfModule mod_rewrite.c> RewriteEngine on RewriteRule ^(S{1,7})$ index.php?code=$1 [L] </IfModule>
URL短链接的实现原理和方法
2、增加64进制编码与解码方法:
func.php
<?php function b64dec($b64) { //64进制转换成10进制 $map = array( "0"=>0,"1"=>1,"2"=>2,"3"=>3,"4"=>4,"5"=>5,"6"=>6,"7"=>7,"8"=>8,"9"=>9, "A"=>10,"B"=>11,"C"=>12,"D"=>13,"E"=>14,"F"=>15,"G"=>16,"H"=>17,"I"=>18,"J"=>19, "K"=>20,"L"=>21,"M"=>22,"N"=>23,"O"=>24,"P"=>25,"Q"=>26,"R"=>27,"S"=>28,"T"=>29, "U"=>30,"V"=>31,"W"=>32,"X"=>33,"Y"=>34,"Z"=>35,"a"=>36,"b"=>37,"c"=>38,"d"=>39, "e"=>40,"f"=>41,"g"=>42,"h"=>43,"i"=>44,"j"=>45,"k"=>46,"l"=>47,"m"=>48,"n"=>49, "o"=>50,"p"=>51,"q"=>52,"r"=>53,"s"=>54,"t"=>55,"u"=>56,"v"=>57,"w"=>58,"x"=>59, "y"=>60,"z"=>61,"_"=>62,"="=>63 ); $dec = 0; $len = strlen($b64); for ($i = 0; $i < $len; $i++) { $b = $map[$b64{$i}]; if ($b === NULL) { return FALSE; } $j = $len - $i - 1; $dec += ($j == 0 ? $b : (2 << (6 * $j - 1)) * $b); } return $dec; } function decb64($dec) { //10进制转换成64进制 if ($dec < 0) { return FALSE; } $map = array( 0=>"0",1=>"1",2=>"2",3=>"3",4=>"4",5=>"5",6=>"6",7=>"7",8=>"8",9=>"9", 10=>"A",11=>"B",12=>"C",13=>"D",14=>"E",15=>"F",16=>"G",17=>"H",18=>"I",19=>"J", 20=>"K",21=>"L",22=>"M",23=>"N",24=>"O",25=>"P",26=>"Q",27=>"R",28=>"S",29=>"T", 30=>"U",31=>"V",32=>"W",33=>"X",34=>"Y",35=>"Z",36=>"a",37=>"b",38=>"c",39=>"d", 40=>"e",41=>"f",42=>"g",43=>"h",44=>"i",45=>"j",46=>"k",47=>"l",48=>"m",49=>"n", 50=>"o",51=>"p",52=>"q",53=>"r",54=>"s",55=>"t",56=>"u",57=>"v",58=>"w",59=>"x", 60=>"y",61=>"z",62=>"_",63=>"=", ); $b64 = ""; do { $b64 = $map[($dec % 64)] . $b64; $dec /= 64; } while ($dec >= 1); return $b64; }
3、创建数据表links
CREATE TABLE `links` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `url` varchar(255) DEFAULT NULL, `ctime` int(11) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=26262628 DEFAULT CHARSET=latin1; -- ---------------------------- -- Records of links -- ---------------------------- INSERT INTO `links` VALUES ("10900", "http://www.cnblogs.com", "1489568387"); INSERT INTO `links` VALUES ("10901", "http://www.baidu.com", "1489569782");
4、创建短链接生成与长链接获取功能
index.php
<?php include "func.php"; define("HOST","localhost"); define("DB_NAME","test"); define("USER","root"); define("PASS","123456"); function make_short_url($url){ $url=str_ireplace("http://","",$url); $pdo = new PDO("mysql:host=".HOST.";dbname=".DB_NAME,USER,PASS); $rs = $pdo ->query("select id from links where url="".$url."""); $row = $rs -> fetch(); if($row==false){ $pdo -> exec("insert into links(url,ctime) values("".$url."","".mktime()."")"); $id=$pdo -> lastinsertid(); return "http://d.cn/".decb64($id); }else{ return "http://d.cn/".decb64($row["id"]); } } function get_long_url($code){ $pdo = new PDO("mysql:host=".HOST.";dbname=".DB_NAME,USER,PASS); $rs = $pdo ->query("select url from links where id="".b64dec($code)."""); $row = $rs -> fetch(); if($row==false){ print "链接错误"; exit; }else{ return "http://".$row["url"]; } } //参数的接收与短链接返回部分 if($_GET["code"]){ $code=trim($_GET["code"],"/"); $url=get_long_url($code); if($url){ header("location:$url"); } }elseif($_GET["url"]){ $url=trim($_GET["url"]); print make_short_url($url); }
5、测试
返回内容为:http://d.cn/2gL。在浏览器中访问http://d.cn/2gL,即会跳转到http://www.baidu.com
一个短链接已经基本实现,仍然有一些可待优化的地方。如跳转方式改为301跳转;数据库数据量大时,可以采取分库操作。或者用memcache或者redis缓存服务器来代替mysql,提升效率等等
声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。
- 上一篇: mysql分库分表实战及php代码操作完整实例
- 下一篇: php模拟post提交提交json数据