欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php生成短網(wǎng)址/短鏈接原理和用法實(shí)例分析

 更新時(shí)間:2020年05月29日 08:50:48   作者:TANKING  
這篇文章主要介紹了php生成短網(wǎng)址/短鏈接原理和用法,結(jié)合實(shí)例形式分析了php生成短網(wǎng)址/短鏈接的基本原理、實(shí)現(xiàn)方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了php生成短網(wǎng)址/短鏈接原理和用法。分享給大家供大家參考,具體如下:

需求

在我們的項(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è)稍微短一些的域名就行。

生成源碼api.php

<?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."\"}";
  }

  //斷開數(shù)據(jù)庫(kù)連接
  mysql_close($con);
}

?>

訪問源碼index.php

<?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 "鏈接不存在";
  }
}
?>

Apache規(guī)則.htaccess

RewriteEngine On
#RewriteBase / 
RewriteRule ^(\w+)$ index.php?id=$1

數(shù)據(jù)庫(kù)字段

id(int)自增
dwz_key(varchar)
long_url(text)
creat_time(TIMESTAMP)

使用方法

1、訪問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ù)。訪問http://xxx.cn/Hp8R,就會(huì)自動(dòng)跳轉(zhuǎn)到你的長(zhǎng)鏈接

PS:這里為大家推薦一款本站短網(wǎng)址生成工具(也是使用的第三方API接口生成的短網(wǎng)址)

短鏈(短網(wǎng)址)在線生成工具:
http://tools.jb51.net/password/dwzcreate

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php curl用法總結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》及《PHP中json格式數(shù)據(jù)操作技巧匯總

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • php計(jì)算年齡精準(zhǔn)到年月日

    php計(jì)算年齡精準(zhǔn)到年月日

    這篇文章主要介紹了php計(jì)算年齡精準(zhǔn)到年月日的方法,涉及php操作日期與字符串的相關(guān)技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下
    2015-11-11
  • PHP警告Cannot use a scalar value as an array的解決方法

    PHP警告Cannot use a scalar value as an array的解決方法

    PHP警告Cannot use a scalar value as an array的解決方法,需要的朋友可以參考下。
    2012-01-01
  • php實(shí)現(xiàn)留言板功能(代碼詳解)

    php實(shí)現(xiàn)留言板功能(代碼詳解)

    本文主要介紹了php實(shí)現(xiàn)留言板功能的步驟方法解析。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧
    2017-03-03
  • PHP在同一域名下兩個(gè)不同的項(xiàng)目做獨(dú)立登錄機(jī)制詳解

    PHP在同一域名下兩個(gè)不同的項(xiàng)目做獨(dú)立登錄機(jī)制詳解

    這篇文章主要給大家介紹了關(guān)于PHP在同一域名下兩個(gè)不同的項(xiàng)目如何做獨(dú)立登錄機(jī)制的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-09-09
  • 用php+javascript實(shí)現(xiàn)二級(jí)級(jí)聯(lián)菜單的制作

    用php+javascript實(shí)現(xiàn)二級(jí)級(jí)聯(lián)菜單的制作

    二級(jí)級(jí)聯(lián)菜單在我去年的時(shí)候就用asp+js做過(guò),而現(xiàn)在忽然拿出來(lái)再做的時(shí)候我發(fā)現(xiàn)我忘記了,而且原來(lái)用asp寫的程序都找不到了,真暈[emot]sweat[/emot],于是到網(wǎng)上搜,找了半天,我發(fā)現(xiàn)網(wǎng)上的寫法各異,而且都特別復(fù)雜,這么一個(gè)二級(jí)級(jí)聯(lián)菜單,有必要弄這么復(fù)雜嗎?于是自己想重新寫一個(gè)簡(jiǎn)單的。在經(jīng)過(guò)半個(gè)小時(shí)左右的思考后,我完成了二級(jí)級(jí)聯(lián)菜單的設(shè)計(jì)和制作。
    2008-05-05
  • php bugs代碼審計(jì)基礎(chǔ)詳解

    php bugs代碼審計(jì)基礎(chǔ)詳解

    代碼審計(jì)不會(huì),學(xué)習(xí)知識(shí)需要積累一下基礎(chǔ),因此來(lái)搭建php_bugs進(jìn)行相關(guān)學(xué)習(xí),題解如下,希望能對(duì)在學(xué)習(xí)代碼審計(jì)的同學(xué)們有所幫助
    2022-11-11
  • PHP單例模式Singleton Pattern的原理與實(shí)現(xiàn)介紹

    PHP單例模式Singleton Pattern的原理與實(shí)現(xiàn)介紹

    單例就是單實(shí)例的意思,即在系統(tǒng)全局,一個(gè)類只創(chuàng)建一個(gè)對(duì)象,并且在系統(tǒng)全局都可以訪問這個(gè)對(duì)象而不用重新創(chuàng)建。本文將通過(guò)示例為大家詳細(xì)講解Java單例模式的使用,需要的可以參考一下
    2023-03-03
  • php里array_work用法實(shí)例分析

    php里array_work用法實(shí)例分析

    這篇文章主要介紹了php里array_work用法,實(shí)例分析了array_work方法實(shí)現(xiàn)針對(duì)數(shù)組中每個(gè)元素應(yīng)用函數(shù)返回的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-07-07
  • 你應(yīng)該知道PHP浮點(diǎn)數(shù)知識(shí)

    你應(yīng)該知道PHP浮點(diǎn)數(shù)知識(shí)

    這篇文章主要介紹了你應(yīng)該知道PHP浮點(diǎn)數(shù)知識(shí),本文講解了PHP浮點(diǎn)數(shù)、PHP數(shù)字的臨界值,精度損失等問題,需要的朋友可以參考下
    2015-05-05
  • PHP中的異常處理機(jī)制深入講解

    PHP中的異常處理機(jī)制深入講解

    這篇文章主要給大家介紹了關(guān)于PHP中異常處理機(jī)制的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11

最新評(píng)論