> 文章列表 > Nginx常用安全加固措施

Nginx常用安全加固措施

Nginx常用安全加固措施

安全加固
1、禁止目录浏览/隐藏版本信息
编辑nginx.conf配置文件,HTTP模块添加如下一行内容,并重启:

autoindex off;      #禁止目录浏览
server_tokens off;       #隐藏版本信息

2、限制http请求方法

if ($request_method !~ ^(GET|HEAD|POST)$ ) {return444; 
}

3、限制IP访问

location / { deny 192.168.1.1; #拒绝IPallow 192.168.1.0/24; #允许IP allow 10.1.1.0/16; #允许IP deny all; #拒绝其他所有IP 
}

4、限制并发和速度

limit_zone one $binary_remote_addr 10m; 
server {      listen   80;      server_name www.test.com;      index index.html index.htm index.php;      root  /usr/local/www;      #Zone limit;      location / {          limit_conn one 1;          limit_rate 20k;      } ……… 
}

5、控制超时时间

client_body_timeout 10;  #设置客户端请求主体读取超时时间 
client_header_timeout 10;  #设置客户端请求头读取超时时间 
keepalive_timeout 55;  #第一个参数指定客户端连接保持活动的超时时间,第二个参数是可选的,它指定了消息头保持活动的有效时间 
send_timeout10;  #指定响应客户端的超时时间

6、nginx降权

user nobody;

7、配置防盗链

location ~* ^.+\\.(gif|jpg|png|swf|flv|rar|zip)$ {     valid_referers none blocked server_names *.test.com http://localhost baidu.com;if ($invalid_referer) {         rewrite ^/ [img]http://www.XXX.com/images/default/logo.gif[/img];         # return403;     } 
}

8、针对SSL 策略进行加固(需ngnix版本支持)

server { ssl_protocols TLSv1.2,TLSv1.3;
}

9、确保NGINX配置文件权限为644

修改Nginx配置文件权限: 
执行chmod 644 <conf_path>来限制Nginx配置文件的权限;(<conf_path>为配置文件的路径,
如默认/安装目录/conf/nginx.conf或者/etc/nginx/nginx.conf,或用户自定义,请 自行查找)

10、更改源码隐藏软件名称及版本号

在nginx编译安装之前,先更改,之后再编译安装1.更改版本号修改nginx-1.6.4/src/core/nginx.h
nginx-1.6.2/src/core# 
sed -n '13,17p' nginx.h
#修改为需要的版本号
#将nginx修改为其他名称

11、高Nginx后端服务指定的Header隐藏状态

当nginx作为反向代理时,会配置很多站点,为了不想泄露后端webserver主机信息,可以在http全局下配置隐藏Nginx后端服务X-Powered-By头。

隐藏Nginx后端服务X-Powered-By头

1、打开conf/nginx.conf配置文件; 
2、在http下配置proxy_hide_header项; 增加或修改为 proxy_hide_header X-Powered-By; proxy_hide_header Server;http {.....proxy_hide_header X-Powered-By; proxy_hide_header Server;....
}

12、Nginx解决跨域问题

复杂跨域的条件是:

①、非GET、HEAD、POST请求。

②、POST请求的Content-Type不是application/x-www-form-urlencoded, multipart/form-data, 或text/plain。

③、添加了自定义header,例如Token。

跨域请求浏览器会在Headers中添加Origin,通常情况下不允许用户修改其值。

在编辑状态下,在http节点下添加三条命令就行了,命令如下:add_headerAccess-Control-Allow-Origin*;
add_headerAccess-Control-Allow-MethodsGET,POST,OPTIONS;
add_headerAccess-Control-Allow-HeadersX-Requested-With;

1、首先查看http头部有无origin字段;
2、如果没有,或者不允许,直接当成普通人请求处理,结束;
3、如果有并且是允许的,那么再看是否是preflight(method=OPTIONS);
4、如果是preflight,就返回Allow-Headers、Allow-Methods等,内容为空;
5、如果不是preflight,就返回Allow-Origin、Allow-Credentials等,并返回正常内容。

  1 location /pub/(.+) {2     if ($http_origin ~ <允许的域(正则匹配)>) {3         add_header 'Access-Control-Allow-Origin' "$http_origin";4         add_header 'Access-Control-Allow-Credentials' "true";5         if ($request_method = "OPTIONS") {6             add_header 'Access-Control-Max-Age' 86400;7             add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS, DELETE';8             add_header 'Access-Control-Allow-Headers' 'reqid, nid, host, x-real-ip, x-forwarded-ip, event-type, event-id, accept, content-type';9             add_header 'Content-Length' 0;10             add_header 'Content-Type' 'text/plain, charset=utf-8';11             return 204;12         }13     }14     # 正常nginx配置15     ......16 }

方案1 *:通配符,全部允许,存在安全隐患(不推荐)。

一旦启用本方法,表示任何域名皆可直接跨域请求:

  1     server {2         ...3         location / {4             # 允许 所有头部 所有域 所有方法5             add_header 'Access-Control-Allow-Origin' '*';6             add_header 'Access-Control-Allow-Headers' '*';7             add_header 'Access-Control-Allow-Methods' '*';8             # OPTIONS 直接返回2049             if ($request_method = 'OPTIONS') {10                 return 204;11             }12         }13         ...14     }

方案2:多域名配置(推荐)

配置多个域名在map中 只有配置过的允许跨域:

  1  map $http_origin $corsHost {2         default 0;3         "~https://zzzmh.cn" https://zzzmh.cn;4         "~https://chrome.zzzmh.cn" https://chrome.zzzmh.cn;5         "~https://bz.zzzmh.cn" https://bz.zzzmh.cn;6     }7     server {8         ...9         location / {10             # 允许 所有头部 所有$corsHost域 所有方法11             add_header 'Access-Control-Allow-Origin' $corsHost;12             add_header 'Access-Control-Allow-Headers' '*';13             add_header 'Access-Control-Allow-Methods' '*';14             # OPTIONS 直接返回20415             if ($request_method = 'OPTIONS') {16                 return 204;17             }18         }19         ...20     }

链接:Nginx跨域配置_nginx配置跨域访问_huang714的博客-CSDN博客