php生成短網址 短連接原理和源碼

需求

在咱們的項目當中,若是須要更好傳播咱們的活動連接,可是連接太長1來是不美觀,2來是太過於「笨重」,例如拼多多,淘寶聯盟,他們的推廣連接都是有短連接的,還有新浪微博。php

可是,這些始終都是別人的,咱們調用別人的API進行生成,不穩定,因此能夠本身作一個,註冊一個稍微短一些的域名就行。html

生成源碼api.php

<?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);
}

?>

訪問源碼index.php

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

Apache規則.htaccess

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,就會自動跳轉到你的長連接數據庫

微信截圖_20200515141903.png

Author:TANKING
Web:https://www.likeyunba.com/
WeChat:face6009
Date:2020-05-15json

相關文章
相關標籤/搜索