11月19日任务php
11.25 配置防盗链html
11.26 访问控制Directoryapache
11.27 访问控制FilesMatchvim
第三方的站点能够经过引用的方式来获取本服务器上的资源如图片等,可是相应的网络资源的使用这对于本机而言每每是多余的、浪费的。所以咱们须要限制这方面的资源访问,经过设置防盗链的方式。windows
referer是http数据包的header的一部分,当浏览器其向服务器发送请求时,将带上referer,以此来告诉浏览器该请求时从什么网页连接过来的,浏览器处理该连接并显示。浏览器
设置了防盗链后,一些站点将没法经过引用的方式来获取服务器的资源,只能经过直接访问本机来获取,这样就将有效的流量访问限定到了本机,不被不法站点所利用。服务器
编辑虚拟主机配置文件网络
[root@localhost ~]# vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf 插入下面的内容: <Directory /data/wwwroot/111.com> # 将111.com设为白名单,对应规则Allow SetEnvIfNoCase Referer "http://111.com" local_ref # 将aaa.com设为白名单,对应规则Allow SetEnvIfNoCase Referer "http://aaa.com" local_ref # 将空referer设为白名单,对应规则Allow;空referer即直接访问的地址 SetEnvIfNoCase Referer "^$" local_ref # 对txt、doc等格式的文件执行访问控制 <FilesMatch "\.(txt|doc|mp3|zip|rar|jpg|gif)"> # 白名单地址allow,其余deny # 执行顺序依次为allow、deny,反过来将致使都被禁止访问 Order Allow,Deny # 白名单为local_ref对应的地址 Allow from env=local_ref </FilesMatch> </Directory>
使用windows浏览器测试时,前提须要设置hosts文件!curl
我主机内的设置为测试
192.168.65.133 111.com
不注释空referer行
// 将第三方的域名加入白名单,我这里使用的是猿课论坛 SetEnvIfNoCase Referer "http://ask.apelearn.com" local_ref // 空referer行注释掉 #SetEnvIfNoCase Referer "^$" local_ref 保存后重启访问访问
效果以下:
成功获取到了图片
[root@localhost 111.com]# curl -e "http://111.com/test.jpg" -x 127.0.0.1:80 111.com/test.jpg -I HTTP/1.1 200 OK Date: ..., ... 14:14:43 GMT Server: Apache/2.4.28 (Unix) PHP/5.6.30 Last-Modified: ..., ... 13:20:20 GMT ETag: "18652-5612a0725ed00" Accept-Ranges: bytes Content-Length: 99922 Content-Type: image/jpeg
限制用户访问部分目录,容许特定ip访问
[root@localhost ~]# vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf 添加以下内容: <Directory /data/wwwroot/111.com/admin/> Order deny,allow # 决定规则的前后顺序 Deny from all Allow from 127.0.0.1 # 只容许本地访问 </Directory>
[root@localhost ~]# curl -x 127.0.0.1:80 http://111.com/admin/index.php -I HTTP/1.1 200 OK Date: ..., ... 12:58:07 GMT Server: Apache/2.4.28 (Unix) PHP/5.6.30 X-Powered-By: PHP/5.6.30 Content-Type: text/html; charset=UTF-8
[root@localhost ~]# curl -x 192.168.65.133:80 http://111.com/admin/index.php -I HTTP/1.1 403 Forbidden Date: ..., ... 12:59:11 GMT Server: Apache/2.4.28 (Unix) PHP/5.6.30 Content-Type: text/html; charset=iso-8859-1
除了可以限制访问目录,还能够限制某些文件的访问
[root@localhost ~]# vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf 修改目录访问控制的语段: <Directory /data/wwwroot/111.com> # 对文件admin.php进行限制 <FilesMatch "admin.php(.*)"> Order deny,allow Deny from all Allow from 127.0.0.1 </FilesMatch> </Directory>
[root@localhost ~]# curl -x 127.0.0.1:80 http://111.com/admin/admin.php?123 -I HTTP/1.1 404 Not Found Date: ..., ... 13:11:42 GMT Server: Apache/2.4.28 (Unix) PHP/5.6.30 Content-Type: text/html; charset=iso-8859-1
[root@localhost ~]# curl -x 192.168.65.133:80 http://111.com/admin/admin.php?123 -I HTTP/1.1 403 Forbidden Date: ..., ... 13:12:05 GMT Server: Apache/2.4.28 (Unix) PHP/5.6.30 Content-Type: text/html; charset=iso-8859-1