学生黑客联盟-官网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 253|回复: 10

php生成短网址 短链接原理和源码

[复制链接]

该用户从未签到

2

主题

2

帖子

8

积分

新手上路

Rank: 1

积分
8
发表于 2021-9-14 14:42:57 | 显示全部楼层 |阅读模式
需求
在我们的项目当中,如果需要更好传播我们的活动链接,但是链接太长1来是不美观,2来是太过于“笨重”,例如拼多多,淘宝联盟,他们的推广链接都是有短链接的,还有新浪微博。但是,这些始终都是别人的,我们调用别人的API进行生成,不稳定,所以可以自己做一个,注册一个稍微短一些的域名就行。

生成源码api.php
[PHP]  
  1. <?php
  2. header("Content-type:application/json");
  3. //GET URL
  4. $url = $_GET["url"];
  5. //过滤数据
  6. if (trim(empty($url))) {
  7.     echo "{"code":"1","url":"未传入URL"}";
  8. }else{
  9.     //定义数据库配置
  10.     $dbhost = "xxx";//数据库服务器地址
  11.     $dbuser = "xxx";//数据库账号
  12.     $dbpwd = "xxx";//数据库密码
  13.     $dbname = "xxx";//数据库名
  14.     //连接数据库
  15.     $con = mysql_connect($dbhost,$dbuser,$dbpwd);
  16.     if (!$con)
  17.       {
  18.       die('Could not connect: ' . mysql_error());
  19.       }
  20.     mysql_select_db($dbname, $con);
  21.     //检查数据库是否已经存在该URL
  22.     $check = mysql_query("SELECT * FROM 表名 WHERE long_url = '$url'");
  23.     $check_result = mysql_num_rows($check);
  24.     //如果已经存在,则直接返回之前生成的链接
  25.     if ($check_result) {
  26.         while ($row_yicunzai = mysql_fetch_array($check)) {
  27.             $yicunzai_key = $row_yicunzai["dwz_key"];
  28.             //返回KEY
  29.             echo "{"code":"0","url":"域名".$yicunzai_key.""}";
  30.         }
  31.     }else{
  32.         //生成KEY
  33.         $key_str = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890";
  34.         $key = substr(str_shuffle($key_str),mt_rand(0,strlen($key_str)-11),4);
  35.         //生成短链接
  36.         mysql_query("INSERT INTO lkydwz (long_url, dwz_key) VALUES ('$url', '$key')");
  37.         //返回结果
  38.         echo "{"code":"0","url":"域名".$key.""}";
  39.     }
  40.     //断开数据库连接
  41.     mysql_close($con);
  42. }
  43. ?>
复制代码


访问源码index.php
[PHP]  
  1. <?php
  2. header("Content-Type:text/html;charset=utf-8");
  3. //获得当前传过来的KEY
  4. $key = $_GET["id"];
  5. echo "<title>正在跳转</title>";
  6. //过滤数据
  7. if (trim(empty($key))) {
  8.     echo "链接不存在";
  9. }else{
  10.     //解析KEY
  11.     //定义数据库配置
  12.     $dbhost = "xxx";//数据库服务器地址
  13.     $dbuser = "xxx";//数据库账号
  14.     $dbpwd = "xxx";//数据库密码
  15.     $dbname = "xxx";//数据库名
  16.     //连接数据库
  17.     $con = mysql_connect($dbhost,$dbuser,$dbpwd);
  18.     if (!$con)
  19.       {
  20.       die('Could not connect: ' . mysql_error());
  21.       }
  22.     mysql_select_db($dbname, $con);
  23.     //查询数据库,通过KEY获取长链接进行跳转
  24.     //检查数据库是否存在该KEY
  25.     $check = mysql_query("SELECT * FROM 表名 WHERE dwz_key = '$key'");
  26.     $check_result = mysql_num_rows($check);
  27.     //如果存在,则解析出长链接并跳转
  28.     if ($check_result) {
  29.         while ($row_long_url = mysql_fetch_array($check)) {
  30.             $long_url = $row_long_url["long_url"];
  31.             // echo "<script>location.href="".$long_url."";</script>";
  32.             header("Location: $long_url");
  33.         }
  34.     }else{
  35.         echo "链接不存在";
  36.     }
  37. }
  38. ?>
复制代码


Apache规则.htaccess
[Asm]  
  1. RewriteEngine On
  2. #RewriteBase /
  3. RewriteRule ^(\w+)$ index.php?id=$1
复制代码


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

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

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

TBC新兵交流-需求在我们的项目当中,如果需要更好传播我们的活动链接,但是链接太长1来是不美观,2来是太过于“笨重”(1)


OK了!

该用户从未签到

0

主题

1683

帖子

2

积分

新手上路

Rank: 1

积分
2
发表于 2021-9-14 14:43:30 | 显示全部楼层
php7.0的效率是php5.6的3倍,这是我个人曾经亲自体验过的,当时做了个网吧项目,全国接近有800多家网吧在用,客户端接近二十万台左右在线。之前一直用的php5.6版本,一到晚上19点左右,压力就会激增,服务器CPU就会飙到90%多,偶尔还会出现访问失败的情况。
没办法所以有一次我们决定升级php版本尝试看看,新服务器升级到php7.0后,立即把业务切过去,老5.6的服务器关闭,一模一样配置的服务器,新服务器一直稳定在CPU30%多,这效率立竿见影。。。从此我就只用PHP7以上的版本,因为那是真的香。
而且真要做支持大压力的短网址服务,在解析短网址的地方,不仅上高版本PHP,还要上redis来来给数据库减压,这样的系统基本就很健壮了。
回复

使用道具 举报

该用户从未签到

1

主题

1574

帖子

1045

积分

金牌会员

Rank: 6Rank: 6

积分
1045
发表于 2021-9-14 14:43:59 | 显示全部楼层
好贴,顶你起来!多谢
回复

使用道具 举报

该用户从未签到

3

主题

1617

帖子

893

积分

高级会员

Rank: 4

积分
893
发表于 2021-9-14 14:44:37 | 显示全部楼层
可以的~ 感谢~
回复

使用道具 举报

该用户从未签到

3

主题

1617

帖子

893

积分

高级会员

Rank: 4

积分
893
发表于 2021-9-14 14:45:29 | 显示全部楼层
学习了,感谢楼主分享,要是能防红就更好了。
回复

使用道具 举报

该用户从未签到

1

主题

1574

帖子

1045

积分

金牌会员

Rank: 6Rank: 6

积分
1045
发表于 2021-9-14 14:46:14 | 显示全部楼层
这代码好老啊亲,这种连接数据库的方式,php7都已经抛弃了。
所以别说基于redis的短链接了,至少来个pdo方式啊
回复

使用道具 举报

该用户从未签到

0

主题

1683

帖子

2

积分

新手上路

Rank: 1

积分
2
发表于 2021-9-14 14:47:01 | 显示全部楼层
这短网址会红麻?
回复

使用道具 举报

该用户从未签到

1

主题

1574

帖子

1045

积分

金牌会员

Rank: 6Rank: 6

积分
1045
发表于 2021-9-14 14:47:11 | 显示全部楼层
我的php环境一直处于5.5,用这个就够了。
回复

使用道具 举报

该用户从未签到

0

主题

1683

帖子

2

积分

新手上路

Rank: 1

积分
2
发表于 2021-9-14 14:47:50 | 显示全部楼层
防红的话,很简单,在index.php加一个js判断,判断是不是在微信或者QQ打开就行。
回复

使用道具 举报

该用户从未签到

1

主题

1574

帖子

1045

积分

金牌会员

Rank: 6Rank: 6

积分
1045
发表于 2021-9-14 14:48:50 | 显示全部楼层
红不红就看你做什么了,建议自己做自己用,公开给别人用那肯定滥用了。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭Powered by ©科大讯飞语音云

QQ|Archiver|手机版|小黑屋|TBC ( 鄂ICP备19004742号(鄂ICP备19004742号-2) )|网站地图|鄂ICP备19004742号(鄂ICP备19004742号-2) 联系站长

GMT+8, 2021-9-23 14:44 , Processed in 0.968750 second(s), 38 queries .

Powered by TBC! X3.4

© 2001-2020 TBC.. 技术支持 by 复仇者黑客组织

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