吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 6857|回复: 22
收起左侧

[其他转载] php生成短网址 短链接原理和源码

[复制链接]
yuupuu 发表于 2020-5-15 14:24
需求
在我们的项目当中,如果需要更好传播我们的活动链接,但是链接太长1来是不美观,2来是太过于“笨重”,例如拼多多,淘宝联盟,他们的推广链接都是有短链接的,还有新浪微博。但是,这些始终都是别人的,我们调用别人的API进行生成,不稳定,所以可以自己做一个,注册一个稍微短一些的域名就行。

生成源码api.php
[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] 纯文本查看 复制代码
<?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
[Asm] 纯文本查看 复制代码
RewriteEngine On
#RewriteBase / 
RewriteRule ^(\w+)$ index.php?id=$1


数据库字段
id(int)自增
dwz_key(varchar)
long_url(text)
creat_time(TIMESTAMP)

使用方法
1、访问api.php?url=长链接,即可生成短链接,例如返回JSON
[JavaScript] 纯文本查看 复制代码
{"code":"0","url":"http://xxx.cn/Hp8R"}

2、新建.htaccess,把上面规则复制进去,保存
3、新建index.php,把上面代码拷贝进去,配置好数据库。访问http://xxx.cn/Hp8R,就会自动跳转到你的长链接

微信截图_20200515141903.png


OK了!

免费评分

参与人数 3吾爱币 +7 热心值 +3 收起 理由
Jmq421516 + 1 + 1 热心回复!
苏紫方璇 + 5 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
坐久落花多 + 1 + 1 谢谢@Thanks!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

流年 发表于 2020-5-15 14:55
yuupuu 发表于 2020-5-15 14:42
我的php环境一直处于5.5,用这个就够了。

php7.0的效率是php5.6的3倍,这是我个人曾经亲自体验过的,当时做了个网吧项目,全国接近有800多家网吧在用,客户端接近二十万台左右在线。之前一直用的php5.6版本,一到晚上19点左右,压力就会激增,服务器CPU就会飙到90%多,偶尔还会出现访问失败的情况。
没办法所以有一次我们决定升级php版本尝试看看,新服务器升级到php7.0后,立即把业务切过去,老5.6的服务器关闭,一模一样配置的服务器,新服务器一直稳定在CPU30%多,这效率立竿见影。。。从此我就只用PHP7以上的版本,因为那是真的香。
而且真要做支持大压力的短网址服务,在解析短网址的地方,不仅上高版本PHP,还要上redis来来给数据库减压,这样的系统基本就很健壮了。
shaolongchao 发表于 2020-5-15 14:31
wjb6666 发表于 2020-5-15 14:34
大侠在路上 发表于 2020-5-15 14:37
学习了,感谢楼主分享,要是能防红就更好了。
流年 发表于 2020-5-15 14:38
这代码好老啊亲,这种连接数据库的方式,php7都已经抛弃了。
所以别说基于redis的短链接了,至少来个pdo方式啊
ggogg928 发表于 2020-5-15 14:41
这短网址会红麻?
 楼主| yuupuu 发表于 2020-5-15 14:42
流年 发表于 2020-5-15 14:38
这代码好老啊亲,这种连接数据库的方式,php7都已经抛弃了。
所以别说基于redis的短链接了,至少来个pdo方 ...

我的php环境一直处于5.5,用这个就够了。
 楼主| yuupuu 发表于 2020-5-15 14:44
大侠在路上 发表于 2020-5-15 14:37
学习了,感谢楼主分享,要是能防红就更好了。

防红的话,很简单,在index.php加一个js判断,判断是不是在微信或者QQ打开就行。
 楼主| yuupuu 发表于 2020-5-15 14:45
ggogg928 发表于 2020-5-15 14:41
这短网址会红麻?

红不红就看你做什么了,建议自己做自己用,公开给别人用那肯定滥用了。
zucker 发表于 2020-5-15 14:51
WordPress很多插件,抄一个
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-25 14:22

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表