您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)php生成短網(wǎng)址/短鏈接的方法是什么,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
在我們的項(xiàng)目當(dāng)中,如果需要更好傳播我們的活動(dòng)鏈接,但是鏈接太長(zhǎng)1來(lái)是不美觀,2來(lái)是太過(guò)于“笨重”,例如拼多多,淘寶聯(lián)盟,他們的推廣鏈接都是有短鏈接的,還有新浪微博。
但是,這些始終都是別人的,我們調(diào)用別人的API進(jìn)行生成,不穩(wěn)定,所以可以自己做一個(gè),注冊(cè)一個(gè)稍微短一些的域名就行。
<?php header("Content-type:application/json"); //GET URL $url = $_GET["url"]; //過(guò)濾數(shù)據(jù) if (trim(empty($url))) { echo "{\"code\":\"1\",\"url\":\"未傳入U(xiǎn)RL\"}"; }else{ //定義數(shù)據(jù)庫(kù)配置 $dbhost = "xxx";//數(shù)據(jù)庫(kù)服務(wù)器地址 $dbuser = "xxx";//數(shù)據(jù)庫(kù)賬號(hào) $dbpwd = "xxx";//數(shù)據(jù)庫(kù)密碼 $dbname = "xxx";//數(shù)據(jù)庫(kù)名 //連接數(shù)據(jù)庫(kù) $con = mysql_connect($dbhost,$dbuser,$dbpwd); if (!$con) { die('Could not connect: ' . mysql_error()); } mysql_select_db($dbname, $con); //檢查數(shù)據(jù)庫(kù)是否已經(jīng)存在該URL $check = mysql_query("SELECT * FROM 表名 WHERE long_url = '$url'"); $check_result = mysql_num_rows($check); //如果已經(jīng)存在,則直接返回之前生成的鏈接 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')"); //返回結(jié)果 echo "{\"code\":\"0\",\"url\":\"域名".$key."\"}"; } //斷開(kāi)數(shù)據(jù)庫(kù)連接 mysql_close($con); } ?>
<?php header("Content-Type:text/html;charset=utf-8"); //獲得當(dāng)前傳過(guò)來(lái)的KEY $key = $_GET["id"]; echo "<title>正在跳轉(zhuǎn)</title>"; //過(guò)濾數(shù)據(jù) if (trim(empty($key))) { echo "鏈接不存在"; }else{ //解析KEY //定義數(shù)據(jù)庫(kù)配置 $dbhost = "xxx";//數(shù)據(jù)庫(kù)服務(wù)器地址 $dbuser = "xxx";//數(shù)據(jù)庫(kù)賬號(hào) $dbpwd = "xxx";//數(shù)據(jù)庫(kù)密碼 $dbname = "xxx";//數(shù)據(jù)庫(kù)名 //連接數(shù)據(jù)庫(kù) $con = mysql_connect($dbhost,$dbuser,$dbpwd); if (!$con) { die('Could not connect: ' . mysql_error()); } mysql_select_db($dbname, $con); //查詢數(shù)據(jù)庫(kù),通過(guò)KEY獲取長(zhǎng)鏈接進(jìn)行跳轉(zhuǎn) //檢查數(shù)據(jù)庫(kù)是否存在該KEY $check = mysql_query("SELECT * FROM 表名 WHERE dwz_key = '$key'"); $check_result = mysql_num_rows($check); //如果存在,則解析出長(zhǎng)鏈接并跳轉(zhuǎn) 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)
1、訪問(wèn)api.php?url=長(zhǎng)鏈接,即可生成短鏈接,例如返回JSON
{"code":"0","url":"http://xxx.cn/Hp8R"}
2、新建.htaccess,把上面規(guī)則復(fù)制進(jìn)去,保存
3、新建index.php,把上面代碼拷貝進(jìn)去,配置好數(shù)據(jù)庫(kù)。訪問(wèn)http://xxx.cn/Hp8R,就會(huì)自動(dòng)跳轉(zhuǎn)到你的長(zhǎng)鏈接
關(guān)于php生成短網(wǎng)址/短鏈接的方法是什么就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。