Apache/Nginx/PHP服务器反爬虫代码大全

发布时间:2022-07-24 06:34:02 作者:hartlion 阅读量:4633

今天小编为大家汇总了Apache/Nginx/PHP服务器反爬虫代码大全,希望对你做网站优化有所帮助,如果想对爬虫技术深入了解的,请看《帮你深入了解爬虫与反爬虫技术》。

一、Apache

①、通过修改 .htaccess 文件

修改网站目录下的.htaccess,添加如下代码即可(2 种代码任选):

可用代码 (1):


  1. RewriteEngine On 
  2. RewriteCond %{HTTP_USER_AGENT} (^$|FeedDemon|In Library|Alexa Toolbar|AskTbFXTV|AhrefsBot|CrawlDad|CoolpadWebkit|Java|Feedly|UniversalFeedParser|ApacheBench|Microsoft URL Control|Swiftbot|ZmEu|oBot|jaunty|Python–urllib|lightDeckReports Bot|YYSpider|DigExt|HttpClient|MJ12bot|heritrix|EasouSpider|Ezooms) [NC] 
  3. RewriteRule ^(.*)$ – [F] 

可用代码 (2):


  1. SetEnvIfNoCase ^User–Agent$ .*(FeedDemon|In Library|Alexa Toolbar|AskTbFXTV|AhrefsBot|CrawlDad|CoolpadWebkit|Java|Feedly|UniversalFeedParser|ApacheBench|Microsoft URL Control|Swiftbot|ZmEu|oBot|jaunty|Python–urllib|lightDeckReports Bot|YYSpider|DigExt|HttpClient|MJ12bot|heritrix|EasouSpider|Ezooms) BADBOT 
  2. Order Allow,Deny 
  3. Allow from all 
  4. Deny from env=BADBOT 

②、通过修改 httpd.conf 配置文件

找到如下类似位置,根据以下代码 新增 / 修改,然后重启 Apache 即可:

Shell


  1. DocumentRoot /home/wwwroot/xxx 
  2. <Directory “/home/wwwroot/xxx”> 
  3. SetEnvIfNoCase User–Agent “.*(FeedDemon|In Library|Alexa Toolbar|AskTbFXTV|AhrefsBot|CrawlDad|CoolpadWebkit|Java|Feedly|UniversalFeedParser|ApacheBench|Microsoft URL Control|Swiftbot|ZmEu|oBot|jaunty|Python-urllib|lightDeckReports Bot|YYSpider|DigExt|HttpClient|MJ12bot|heritrix|EasouSpider|Ezooms)” BADBOT 
  4.         Order allow,deny 
  5.         Allow from all 
  6.        deny from env=BADBOT 
  7. </Directory> 

 

二、Nginx 代码

进入到 nginx 安装目录下的 conf 目录,将如下代码保存为 agent_deny.conf


  1. cd /usr/local/nginx/conf 
  2. vim agent_deny.conf 

  1. #禁止Scrapy等工具的抓取 
  2. if ($http_user_agent ~* (Scrapy|Curl|HttpClient)) { 
  3.      return 403; 
  4. #禁止指定UA及UA为空的访问 
  5. if ($http_user_agent ~* “FeedDemon|In Library|Alexa Toolbar|AskTbFXTV|AhrefsBot|CrawlDad|CoolpadWebkit|Java|Feedly|UniversalFeedParser|ApacheBench|Microsoft URL Control|Swiftbot|ZmEu|oBot|jaunty|Python-urllib|lightDeckReports Bot|YYSpider|DigExt|HttpClient|MJ12bot|heritrix|EasouSpider|Ezooms|^$” ) { 
  6.      return 403;             
  7. #禁止非GET|HEAD|POST方式的抓取 
  8. if ($request_method !~ ^(GET|HEAD|POST)$) { 
  9.     return 403; 

然后,在网站相关配置中的 location / { 之后插入如下代码:

Shell


  1. include agent_deny.conf; 

如下的配置:

Shell


  1. [marsge@Mars_Server ~]$ cat /usr/local/nginx/conf/zhangge.conf 
  2. location / { 
  3.         try_files $uri $uri/ /index.php?$args; 
  4.         #这个位置新增1行: 
  5.         include agent_deny.conf; 
  6.         rewrite ^/sitemap_360_sp.txt$ /sitemap_360_sp.php last
  7.         rewrite ^/sitemap_baidu_sp.xml$ /sitemap_baidu_sp.php last
  8.         rewrite ^/sitemap_m.xml$ /sitemap_m.php last

保存后,执行如下命令,平滑重启 nginx 即可:

Shell


  1. /usr/local/nginx/sbin/nginx –s reload 

三、PHP 代码

将如下方法放到贴到网站入口文件 index.php 中的第一个

PHP


  1. //获取UA信息 
  2. $ua = $_SERVER[‘HTTP_USER_AGENT’]; 
  3. //将恶意USER_AGENT存入数组 
  4. $now_ua = array(‘FeedDemon ‘,‘BOT/0.1 (BOT for JCE)’,‘CrawlDad ‘,‘Java’,‘Feedly’,‘UniversalFeedParser’,‘ApacheBench’,‘Swiftbot’,‘ZmEu’,‘In Library’,‘oBot’,‘jaunty’,‘YandexBot’,‘AhrefsBot’,‘MJ12bot’,‘WinHttp’,‘EasouSpider’,‘HttpClient’,‘Microsoft URL Control’,‘YYSpider’,‘jaunty’,‘Python-urllib’,‘lightDeckReports Bot’); 
  5. //禁止空USER_AGENT,dedecms等主流采集程序都是空USER_AGENT,部分sql注入工具也是空USER_AGENT 
  6. if(!$ua) { 
  7.     header(“Content-type: text/html; charset=utf-8”); 
  8.     die(‘请勿采集本站,因为采集的站长木有小JJ!’); 
  9. }else
  10.     foreach($now_ua as $value ) 
  11. //判断是否是数组中存在的UA 
  12.     if(eregi($value,$ua)) { 
  13.         header(“Content-type: text/html; charset=utf-8”); 
  14.         die(‘请勿采集本站,因为采集的站长木有小JJ!’); 
  15.     } 

四、测试效果

如果是vps,那非常简单,使用 curl -A 模拟抓取即可,比如:

模拟宜搜蜘蛛抓取:

Shell


  1. curl –I –A ‘YisouSpider’ bizhi.bcoderss.com 

模拟 UA 为空的抓取:

Shell


  1. curl –I –A ” bizhi.bcoderss.com 

模拟百度蜘蛛的抓取:

Shell


  1. curl –I –A ‘Baiduspider’ bizhi.bcoderss.com  

***本网站图片,文字之类版权申明,因为网站可以由注册用户自行上传图片或文字,本网站无法鉴别所上传图片或文字的知识版权,如果侵犯,请及时通知我们,本网站将在第一时间及时删除。

我要评论

网友评论


评论时间:2024-03-01 00:25:02

虽然服务器的价格相对便宜一些,但由于其工作环境比较复杂、硬件要求较高以及对网络速度等云主机操作系统有哪些 性能要求比较严格,因此,服务器的售价也相应地高于台台式计算机所提供的服务虚拟主机哪个性价比最高 高于台台式计算机所提供的服务


评论时间:2023-09-27 21:25:02

3、在“选项-高级/安全”选项卡上单网络直播服务器搭建 免费使用的虚拟主机 3、在“选项-高级/安全”选项卡上单击“创建虚拟网卡(XP)”命令


评论时间:2023-08-05 12:25:02

服务器构建虚拟主机虚拟主机背后有服务器吗 的过程中最核心的环节就是如何把服务器端与客户端连接好,而服务器构建就必须ecs云主机购买 而服务器构建就必须先解决这个难点!下面介绍几种常用的解决方案及特点,供大家参考学习


评论时间:2023-04-24 21:25:02

其中,数据中心及云计算服务收入占比最大,且近年来呈现逐年49元虚拟主机 增加阿里云虚拟主机控制台 ,数据中心及云计算服务收入占比最大,且近年来呈现逐年增加趋势


评论时间:2023-01-08 21:25:01

2、在服务器端创建一虚拟主机能下载软件吗 个UDP连接(默认为TCP/I主流服务器CPU 接(默认为TCP/IP)


评论时间:2022-12-06 00:25:02

那么租用主机又分为哪种类型呢?租用主机可以划分为三种类型:1.独立主机(也叫虚拟主机):在自己的网站上建立属于自己的服务器空间,用户不需要另外投入资金和人力成一文详解刀片式服务器 本,只需简单操作即可实现与服务器进行数据交换实现虚拟主机的3种方式是什么 不需要另外投入资金和人力成本,只需简单操作即可实现与服务器进行数据交换


评论时间:2022-11-16 00:25:01

3、在选择了X86和Windo国内云主机试用 ws操作系统之后,就可以根据自己的需求进行配置便宜好用的云主机 求进行配置

最新文章

 2023-12-25 22:44:35   admin

活动发布区版规

 2023-05-27 22:03:52   御风而行

容器、无服务器、虚拟机:安全性差...

 2023-05-27 19:08:41   小绵羊0123

科技巨头布局云端 服务器 网络硬...

 2023-05-27 18:17:46   姐姐的跟屁虫

钉钉因系统访问流量激增,宕机1小...

热门阅读

 2022-07-23 00:34:02   freeatom

常见ftp命令 FTP命令使用详...

 2022-07-21 02:17:02   ares

双硬盘组建Raid0磁盘阵列图文...

 2022-07-20 06:17:02   mankeung123

用友软件客户端连接不上服务器的解...

 2022-07-23 00:51:02   antonfxb

WebService实例

 2022-07-13 05:38:02   苯小孩

开发、运维不可不看的Linux调...

 2022-07-20 18:51:02   nightstone

如何使用Charles抓取Web...

随机文章

 2022-01-21 05:38:02   lbm

如何保证托管数据中心的安全?

 2022-07-19 13:17:03   wcloud

linux系统安装教程

 2022-07-19 15:00:04   lglglglglg

服务器操作系统的选择与安装

 2022-07-19 16:17:02   jtchenmin

搭建N点虚拟主机管理系统教程

 2022-07-20 04:51:02   wolfssss

ACL权限-默认与递归(4)

 2022-07-20 09:17:02   swm-chicken

Bash的运算符:数值运算与运算...

热评文章

 2022-07-19 20:17:02   dengyu0429

linux vi使用及详细介绍

 2022-07-20 01:00:05   激动的舌头

Linux视频教程:用户管理命令...

 2022-07-21 20:51:02   jessica-an

创建本地FTP站点

 2022-02-07 05:38:03   jasonkidd

WEB服务器配置详解

 2022-07-20 04:51:02   wolfssss

ACL权限-默认与递归(4)

 2022-07-22 15:00:05   淡水珊瑚

Linux下 Samba Ser...
全球云服务器
Catfish(鲶鱼) Blog V 4.7.3