php防采集,PHP加密URL防止采集的方法实例

本文主要和大家分享PHP加密URL防止采集的方法实例,希望能帮助到大家到大家。

网上有很多采集工具,他们是如何采集的。

这些网址都很有规律,都是(blog-)+ 数字 组成,采集很大程度上利用这个网址规律自动采集网页。

如何更好的避免网站被采集?我们可以把网址中的(关键数字)部分加密一下。

供出加密方法,生成的加密网址短,稳定,非随机数加密方式,对seo友好。算法自行研究。/**

* 加密数字方法

* echo idEncode(222);

* @author uuleaf[] 小叶

* @param int $int 要加密的数字

* @return string 加密后的字符串

*/

function idEncode($int)

{

$str = md5($int);

$sarr = str_split($str);

$stai = (ord($str) + 8) % 10;

if ($stai == 0) $stai = 8;

$idstr = base_convert($int * $stai, 10, 32);

$str1 = substr($str, 10, 2);

$str2 = substr($str, 14, 2);

$str3 = substr($str, 18, 2);

return $str1 . $idstr . $str2 . $stai . $str3;

}

解密方法

/**

* 解密数字方法

* echo idDncode("");

* @author uuleaf[] 小叶

* @param string $str 要解密的数字

* @return int 解密后的数字

*/

function idDecode($str)

{

$idstr = substr(substr($str, 2), 0, -5);

$ji = base_convert($idstr, 32, 10);

$si = (int)substr($str, -3, -2);

return floor($ji / $si);

}

测试echo "加密前的网址:http://thinkphp.cn/blog-54.html";

echo "\n";

$encode_str = idEncode(54);

echo "加密后的网址:http://thinkphp.cn/blog-{$encode_str}.html";

echo "\n";

$decode_str = idDecode($encode_str);

echo "还原后的网址:http://thinkphp.cn/blog-{$decode_str}.html";

输出结果

482b0496dfb3dae66fecc7152f08c901.png

相关推荐:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值