在咱们的项目当中,若是须要更好传播咱们的活动连接,可是连接太长1来是不美观,2来是太过于“笨重”,例如拼多多,淘宝联盟,他们的推广连接都是有短连接的,还有新浪微博。php
可是,这些始终都是别人的,咱们调用别人的API进行生成,不稳定,因此能够本身作一个,注册一个稍微短一些的域名就行。html
<?php header("Content-type:application/json"); //GET URL $url = $_GET["url"]; //过滤数据 if (trim(empty($url))) { echo "{\"code\":\"1\",\"url\":\"未传入URL\"}"; }else{ //定义数据库配置 $dbhost = "xxx";//数据库服务器地址 $dbuser = "xxx";//数据库帐号 $dbpwd = "xxx";//数据库密码 $dbname = "xxx";//数据库名 //链接数据库 $con = mysql_connect($dbhost,$dbuser,$dbpwd); if (!$con) { die('Could not connect: ' . mysql_error()); } mysql_select_db($dbname, $con); //检查数据库是否已经存在该URL $check = mysql_query("SELECT * FROM 表名 WHERE long_url = '$url'"); $check_result = mysql_num_rows($check); //若是已经存在,则直接返回以前生成的连接 if ($check_result) { while ($row_yicunzai = mysql_fetch_array($check)) { $yicunzai_key = $row_yicunzai["dwz_key"]; //返回KEY echo "{\"code\":\"0\",\"url\":\"域名".$yicunzai_key."\"}"; } }else{ //生成KEY $key_str = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890"; $key = substr(str_shuffle($key_str),mt_rand(0,strlen($key_str)-11),4); //生成短连接 mysql_query("INSERT INTO lkydwz (long_url, dwz_key) VALUES ('$url', '$key')"); //返回结果 echo "{\"code\":\"0\",\"url\":\"域名".$key."\"}"; } //断开数据库链接 mysql_close($con); } ?>
<?php header("Content-Type:text/html;charset=utf-8"); //得到当前传过来的KEY $key = $_GET["id"]; echo "<title>正在跳转</title>"; //过滤数据 if (trim(empty($key))) { echo "连接不存在"; }else{ //解析KEY //定义数据库配置 $dbhost = "xxx";//数据库服务器地址 $dbuser = "xxx";//数据库帐号 $dbpwd = "xxx";//数据库密码 $dbname = "xxx";//数据库名 //链接数据库 $con = mysql_connect($dbhost,$dbuser,$dbpwd); if (!$con) { die('Could not connect: ' . mysql_error()); } mysql_select_db($dbname, $con); //查询数据库,经过KEY获取长连接进行跳转 //检查数据库是否存在该KEY $check = mysql_query("SELECT * FROM 表名 WHERE dwz_key = '$key'"); $check_result = mysql_num_rows($check); //若是存在,则解析出长连接并跳转 if ($check_result) { while ($row_long_url = mysql_fetch_array($check)) { $long_url = $row_long_url["long_url"]; // echo "<script>location.href=\"".$long_url."\";</script>"; header("Location: $long_url"); } }else{ echo "连接不存在"; } } ?>
RewriteEngine On #RewriteBase / RewriteRule ^(\w+)$ index.php?id=$1
id(int)自增
dwz_key(varchar)
long_url(text)
creat_time(TIMESTAMP)mysql
一、访问api.php?url=长连接,便可生成短连接,例如返回JSONsql
{"code":"0","url":"http://xxx.cn/Hp8R"}
二、新建.htaccess,把上面规则复制进去,保存
三、新建index.php,把上面代码拷贝进去,配置好数据库。访问http://xxx.cn/Hp8R,就会自动跳转到你的长连接数据库
Author:TANKING
Web:https://www.likeyunba.com/
WeChat:face6009
Date:2020-05-15json