微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

自己用php做一个“生成短网址/短链接”的功能

@H_404_3@@H_404_3@

在我们的项目当中,如果需要更好传播我们的活动链接,但是链接太长1来是不美观,2来是太过于“笨重”,例如拼多多,淘宝联盟,他们的推广链接都是有短链接的,还有新浪微博。@H_404_3@

但是,这些始终都是别人的,我们调用别人的API进行生成,不稳定,所以可以自己做一个注册一个稍微短一些的域名就行。@H_404_3@

生成源码的API文件@H_404_3@

<?PHP@H_404_3@

header("Content-type:application/json");@H_404_3@

//GETURL@H_404_3@

$url=$_GET["url"];@H_404_3@

//过滤数据@H_404_3@

if(trim(empty($url))){@H_404_3@

echo"{"code":"1","url":"未传入URL"}";@H_404_3@

}else{@H_404_3@

//定义数据库配置@H_404_3@

$dbhost="xxx";//数据库服务器地址@H_404_3@

$dbuser="xxx";//数据库账号@H_404_3@

$dbpwd="xxx";//数据库密码@H_404_3@

$dbname="xxx";//数据库名@H_404_3@

//连接数据库@H_404_3@

$con=MysqL_connect($dbhost,$dbuser,$dbpwd);@H_404_3@

if(!$con)@H_404_3@

{@H_404_3@

die('Couldnotconnect:'.MysqL_error());@H_404_3@

}@H_404_3@

MysqL_select_db($dbname,$con);@H_404_3@

//检查数据库是否已经存在该URL@H_404_3@

$check=MysqL_query("SELECT*FROM表名WHERElong_url='$url'");@H_404_3@

$check_result=MysqL_num_rows($check);@H_404_3@

//如果已经存在,则直接返回之前生成链接@H_404_3@

if($check_result){@H_404_3@

while($row_yicunzai=MysqL_fetch_array($check)){@H_404_3@

$yicunzai_key=$row_yicunzai["dwz_key"];@H_404_3@

//返回KEY@H_404_3@

echo"{"code":"0","url":"域名".$yicunzai_key.""}";@H_404_3@

}@H_404_3@

}else{@H_404_3@

//生成KEY@H_404_3@

$key_str="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMnopQRSTUVWXYZ1234567890";@H_404_3@

$key=substr(str_shuffle($key_str),mt_rand(0,strlen($key_str)-11),4);@H_404_3@

//生成链接@H_404_3@

MysqL_query("INSERTINTOlkydwz(long_url,dwz_key)VALUES('$url','$key')");@H_404_3@

//返回结果@H_404_3@

echo"{"code":"0","url":"域名".$key.""}";@H_404_3@

}@H_404_3@

//断开数据库连接@H_404_3@

MysqL_close($con);@H_404_3@

}@H_404_3@

?>访问源码index.PHP@H_404_3@

<?PHP@H_404_3@

header("Content-Type:text/html;charset=utf-8");@H_404_3@

//获得当前传过来的KEY@H_404_3@

$key=$_GET["id"];@H_404_3@

echo"<title>正在跳转</title>";@H_404_3@

//过滤数据@H_404_3@

if(trim(empty($key))){@H_404_3@

echo"链接不存在";@H_404_3@

}else{@H_404_3@

//解析KEY@H_404_3@

//定义数据库配置@H_404_3@

$dbhost="xxx";//数据库服务器地址@H_404_3@

$dbuser="xxx";//数据库账号@H_404_3@

$dbpwd="xxx";//数据库密码@H_404_3@

$dbname="xxx";//数据库名@H_404_3@

//连接数据库@H_404_3@

$con=MysqL_connect($dbhost,$dbuser,$dbpwd);@H_404_3@

if(!$con)@H_404_3@

{@H_404_3@

die('Couldnotconnect:'.MysqL_error());@H_404_3@

}@H_404_3@

MysqL_select_db($dbname,$con);@H_404_3@

//查询数据库,通过KEY获取长链接进行跳转@H_404_3@

//检查数据库是否存在该KEY@H_404_3@

$check=MysqL_query("SELECT*FROM表名WHEREdwz_key='$key'");@H_404_3@

$check_result=MysqL_num_rows($check);@H_404_3@

//如果存在,则解析出长链接跳转@H_404_3@

if($check_result){@H_404_3@

while($row_long_url=MysqL_fetch_array($check)){@H_404_3@

$long_url=$row_long_url["long_url"];@H_404_3@

//echo"<script>location.href="".$long_url."";</script>";@H_404_3@

header("Location:$long_url");@H_404_3@

}@H_404_3@

}else{@H_404_3@

echo"链接不存在";@H_404_3@

}@H_404_3@

}@H_404_3@

?>Apache规则.htaccess@H_404_3@

RewriteEngineOn@H_404_3@

#RewriteBase/@H_404_3@

RewriteRule^(w+)nbsp;index.PHP?id=$1数据库字段@H_404_3@

id(int)自增@H_404_3@

dwz_key(varchar)@H_404_3@

long_url(text)@H_404_3@

creat_time(TIMESTAMP)@H_404_3@

@H_404_3@@H_404_3@

使用方法@H_404_3@

1、访问api.PHP?url=长链接,即可生成链接,例如返回JSON@H_404_3@

{"code":"0","url":"http://xxx.cn/Hp8R"}A2、新建.htaccess,把上面规则复制进去,保存@H_404_3@

3、新建index.PHP,把上面代码拷贝进去,配置好数据库。访问http://xxx.cn/Hp8R,就会自动跳转到你的长链接@H_404_3@

@H_404_3@@H_404_3@

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐