php生成短网址/短链接原理和用法实例分析
吾爱主题
阅读:132
2021-10-15 14:56:00
评论:0
本文实例讲述了php生成短网址/短链接原理和用法。分享给大家供大家参考,具体如下:
需求
在我们的项目当中,如果需要更好传播我们的活动链接,但是链接太长1来是不美观,2来是太过于“笨重”,例如拼多多,淘宝联盟,他们的推广链接都是有短链接的,还有新浪微博。
但是,这些始终都是别人的,我们调用别人的API进行生成,不稳定,所以可以自己做一个,注册一个稍微短一些的域名就行。
生成源码api.php
?1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 | <?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
?1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | <?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
?1 2 3 | RewriteEngine On #RewriteBase / RewriteRule ^(\w+)$ index.php? id =$1 |
数据库字段
?1 2 3 4 | id( int )自增 dwz_key( varchar ) long_url(text) creat_time( TIMESTAMP ) |
使用方法
1、访问api.php?url=长链接,即可生成短链接,例如返回JSON
?1 | { "code" : "0" , "url" : "http://xxx.cn/Hp8R" } |
2、新建.htaccess,把上面规则复制进去,保存
3、新建index.php,把上面代码拷贝进去,配置好数据库。访问http://xxx.cn/Hp8R,就会自动跳转到你的长链接
希望本文所述对大家PHP程序设计有所帮助。
原文链接:https://segmentfault.com/a/1190000022651751
声明
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。