因为该配置也使用location板块,所以本节可结合日志管理一起配置:
[root@centos-01linux ~]# vim /usr/local/nginx/conf/vhost/test.com.conf
……
location ~ ^.+.(gif|jpg|png|swf|flv|rar|zip|doc|pdf|gz|bz2|jpeg|bmp|xls)$
{
expires 7d;
valid_referers none blocked server_names .test.com ;
#定义referer白名单
if ($invalid_referer) {
return 403;
#if函数的意思是:如果不是白名单内的域名,返回值:403
}
access_log off;
}
……
[root@centos-01linux ~]# /usr/local/nginx/sbin/nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@centos-01linux ~]# /usr/local/nginx/sbin/nginx -s reload
说明: “location ~ ^.+”在此0“ ”的作用是后面匹配的内容不区分大小写。
检测
[root@centos-01linux ~]# curl -e "http://www.baidu.com/1.txt" -x127.0.0.1:80 -I test.com/baidu.png
HTTP/1.1 403 Forbidden
Server: nginx/1.12.1
Date: Mon, 14 Aug 2017 06:22:36 GMT
Content-Type: text/html
Content-Length: 169
Connection: keep-alive
即,使用非白名单内的referer进行访问,被拒绝!!!
12.14 Nginx访问控制
需求:访问/admin/目录的请求,只允许几个指定IP通过,配置如下:
[root@centos-01linux ~]# vim /usr/local/nginx/conf/vhost/test.com.conf
……
location /admin/
{
allow 192.168.8.132;
allow 127.0.0.1;
deny all;
#设置IP白名单
}
……
[root@centos-01linux ~]# /usr/local/nginx/sbin/nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@centos-01linux ~]# /usr/local/nginx/sbin/nginx -s reload
创建上面指定的目录:
[root@centos-01linux ~]# mkdir /data/wwwroot/test.com/admin
[root@centos-01linux ~]# echo “test,test”>/data/wwwroot/test.com/admin/1.html
测试
[root@centos-01linux ~]# curl -x127.0.0.1:80 test.com/admin/1.html
“test,test”
[root@centos-01linux ~]# curl -x192.168.8.132:80 test.com/admin/1.html
“test,test”
访问控制——正则匹配
location ~ .(abc|image)/..php$
{
deny all;
}
访问控制——user_agent限制
if ($http_user_agent ~ ‘Spider/3.0|YoudaoBot|Tomato‘)
{
return 403;
}
说明: deny all和return 403效果一样
12.15 Nginx解析PHP相关配置
核心配置:
vim /usr/local/nginx/conf/vhost/test.com.conf
……
location ~ .php$
{
include fastcgi_params;
#fastcgi_pass 127.0.0.1:9000
fastcgi_pass unix:/tmp/php-fcgi.sock;
##fastcgi_pass两种监听格式,但是要保证Nginx和php-fpm中格式一致
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /data/wwwroot/test.com$fastcgi_script_name;
}
……
注: 在此注意两点,fastcgi_pass有两种格式,但是无论使用哪种格式都有保证Nginx和php-fpm中格式一致,否则会报错502;fastcgi _param SCRIPT _FILENAME所在行的路径要和root路径一致!
12.16 Nginx代理
Nginx代理是一种反向代理。反向代理(Reverse Proxy)方式是指以代理服务器来接受Internet上的连接请求,然后将请求转发给内部网络上的服务器;并将从服务器上得到的结果返回给Internet上请求连接的客户端,此时代理服务器对外就表现为一个服务器。
工作原理
Nginx代理是在一台代理服务器中自定义一个域名,该域名指向一个IP,然后将用户的请求通过这台代理服务器访问指定的IP所对应的web服务器。
graph LR
用户-->代理服务器
代理服务器-->用户
代理服务器-->web服务器
web服务器-->代理服务器
进入虚拟主机目录:
[root@centos-01linux ~]# cd /usr/local/nginx/conf/vhost/
创建代理服务器
[root@centos-01linux vhost]# vim proxy.conf
server
{
listen 80;
server_name ask.apelearn.com;
#定义域名(一般和被代理ip的域名保持一致)
location /
{
proxy_pass http://121.201.9.155/;
#指定被代理(被访问)的IP(web服务器IP)
proxy_set_header Host $host;
#$host指的是代理服务器的servername(也是被代理IP的域名)
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
说明: 因为该虚拟主机只用作代理服务器,不需要访问本地文件,所以不需要设置根目录。
检测
设置代理前
[root@centos-01linux vhost]# curl -x127.0.0.1:80 ask.apelearn.com/robots.txt
<html>
<head><title>404 Not Found</title></head>
<body bgcolor="white">
<center><h1>404 Not Found</h1></center>
<hr><center>nginx/1.12.1</center>
</body>
</html>
设置代理后
[root@centos-01linux vhost]# /usr/local/nginx/sbin/nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@centos-01linux vhost]# /usr/local/nginx/sbin/nginx -s reload
[root@centos-01linux vhost]# curl -x127.0.0.1:80 ask.apelearn.com/robots.txt
#
#
User-agent: *
Disallow: /?/admin/
Disallow: /?/people/
Disallow: /?/question/
Disallow: /account/
Disallow: /app/
Disallow: /cache/
原文地址:http://blog.51cto.com/13242922/2087419