13518219792

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

程序员安全规范:安全无小事,安全防范从Nginx配置做起

 隐藏版本号

目前成都创新互联已为千余家的企业提供了网站建设、域名、网络空间、网站改版维护、企业网站设计、志丹网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

 
 
 
  1. http { 
  2.  server_tokens off; 

经常会有针对某个版本的nginx安全漏洞出现,隐藏nginx版本号就成了主要的安全优化手段之一,当然最重要的是及时升级修复漏洞。

开启HTTPS

 
 
 
  1. server { 
  2.  listen 443; 
  3.  server_name ops-coffee.cn; 
  4.   
  5.  ssl on; 
  6.  ssl_certificate /etc/nginx/server.crt; 
  7.  ssl_certificate_key /etc/nginx/server.key; 
  8.  ssl_protocols TLSv1 TLSv1.1 TLSv1.2; 
  9.  ssl_ciphers HIGH:!aNULL:!MD5; 

添加黑白名单

白名单配置

 
 
 
  1. location /admin/ { 
  2.  allow 192.168.1.0/24; 
  3.  deny all; 

上边表示只允许192.168.1.0/24网段的主机访问,拒绝其他所有

也可以写成黑名单的方式禁止某些地址访问,允许其他所有,例如

 
 
 
  1. location /ops-coffee/ { 
  2.  deny 192.168.1.0/24; 
  3.  allow all; 

更多的时候客户端请求会经过层层代理,我们需要通过$http_x_forwarded_for来进行限制,可以这样写

 
 
 
  1. set $allow false; 
  2. if ($http_x_forwarded_for = "211.144.204.2") { set $allow true; } 
  3. if ($http_x_forwarded_for ~ "108.2.66.[89]") { set $allow true; } 
  4. if ($allow = false) { return 404; } 

添加账号认证

 
 
 
  1. server { 
  2.  location / { 
  3.  auth_basic "please input user&passwd"; 
  4.  auth_basic_user_file key/auth.key; 
  5.  } 

限制请求方法

 
 
 
  1. if ($request_method !~ ^(GET|POST)$ ) { 
  2.  return 405; 

$request_method能够获取到请求nginx的method

配置只允许GET\POST方法访问,其他的method返回405

拒绝User-Agent

 
 
 
  1. if ($http_user_agent ~* LWP::Simple|BBBike|wget|curl) { 
  2.  return 444; 

可能有一些不法者会利用wget/curl等工具扫描我们的网站,我们可以通过禁止相应的user-agent来简单的防范

Nginx的444状态比较特殊,如果返回444那么客户端将不会收到服务端返回的信息,就像是网站无法连接一样

图片防盗链

 
 
 
  1. location /images/ { 
  2.  valid_referers none blocked www.ops-coffee.cn ops-coffee.cn; 
  3.  if ($invalid_referer) { 
  4.  return 403; 
  5.  } 

valid_referers: 验证referer,其中none允许referer为空,blocked允许不带协议的请求,除了以上两类外仅允许referer为www.ops-coffee.cn或ops-coffee.cn时访问images下的图片资源,否则返回403

当然你也可以给不符合referer规则的请求重定向到一个默认的图片,比如下边这样

 
 
 
  1. location /images/ { 
  2.  valid_referers blocked www.ops-coffee.cn ops-coffee.cn 
  3.  if ($invalid_referer) { 
  4.  rewrite ^/images/.*\.(gif|jpg|jpeg|png)$ /static/qrcode.jpg last; 
  5.  } 

控制并发连接数

可以通过ngx_http_limit_conn_module模块限制一个IP的并发连接数

 
 
 
  1. http { 
  2.  limit_conn_zone $binary_remote_addr zone=ops:10m; 
  3.  server { 
  4.  listen 80; 
  5.  server_name ops-coffee.cn; 
  6.   
  7.  root /home/project/webapp; 
  8.  index index.html; 
  9.  location / { 
  10.  limit_conn ops 10; 
  11.  } 
  12.  access_log /tmp/nginx_access.log main; 
  13.  } 

limit_conn_zone: 设定保存各个键(例如$binary_remote_addr)状态的共享内存空间的参数,zone=空间名字:大小

大小的计算与变量有关,例如$binary_remote_addr变量的大小对于记录IPV4地址是固定的4 bytes,而记录IPV6地址时固定的16 bytes,存储状态在32位平台中占用32或者64 bytes,在64位平台中占用64 bytes。1m的共享内存空间可以保存大约3.2万个32位的状态,1.6万个64位的状态

limit_conn: 指定一块已经设定的共享内存空间(例如name为ops的空间),以及每个给定键值的最大连接数

上边的例子表示同一IP同一时间只允许10个连接

当有多个limit_conn指令被配置时,所有的连接数限制都会生效

 
 
 
  1. http { 
  2.  limit_conn_zone $binary_remote_addr zone=ops:10m; 
  3.  limit_conn_zone $server_name zone=coffee:10m; 
  4.   
  5.  server { 
  6.  listen 80; 
  7.  server_name ops-coffee.cn; 
  8.   
  9.  root /home/project/webapp; 
  10.  index index.html; 
  11.   
  12.  location / { 
  13.  limit_conn ops 10; 
  14.  limit_conn coffee 2000; 
  15.  } 
  16.  } 

上边的配置不仅会限制单一IP来源的连接数为10,同时也会限制单一虚拟服务器的总连接数为2000

缓冲区溢出攻击

缓冲区溢出攻击 是通过将数据写入缓冲区并超出缓冲区边界和重写内存片段来实现的,限制缓冲区大小可有效防止

 
 
 
  1. client_body_buffer_size 1K; 
  2. client_header_buffer_size 1k; 
  3. client_max_body_size 1k; 
  4. large_client_header_buffers 2 1k; 

同时需要修改几个超时时间的配置

 
 
 
  1. client_body_timeout 10; 
  2. client_header_timeout 10; 
  3. keepalive_timeout 5 5; 
  4. send_timeout 10; 

Header头设置

通过以下设置可有效防止XSS攻击

 
 
 
  1. add_header X-Frame-Options "SAMEORIGIN"; 
  2. add_header X-XSS-Protection "1; mode=block"; 
  3. add_header X-Content-Type-Options "nosniff"; 

在通常的请求响应中,浏览器会根据Content-Type来分辨响应的类型,但当响应类型未指定或错误指定时,浏览会尝试启用MIME-sniffing来猜测资源的响应类型,这是非常危险的

例如一个.jpg的图片文件被恶意嵌入了可执行的js代码,在开启资源类型猜测的情况下,浏览器将执行嵌入的js代码,可能会有意想不到的后果

另外还有几个关于请求头的安全配置需要注意

Content-Security-Policy: 定义页面可以加载哪些资源,

 
 
 
  1. add_header Content-Security-Policy "default-src 'self'"; 

上边的配置会限制所有的外部资源,都只能从当前域名加载,其中default-src定义针对所有类型资源的默认加载策略,self允许来自相同来源的内容

Strict-Transport-Security: 会告诉浏览器用HTTPS协议代替HTTP来访问目标站点

 
 
 
  1. add_header Strict-Transport-Security "max-age=31536000; includeSubDomains"; 

上边的配置表示当用户第一次访问后,会返回一个包含了Strict-Transport-Security响应头的字段,这个字段会告诉浏览器,在接下来的31536000秒内,当前网站的所有请求都使用https协议访问,参数includeSubDomains是可选的,表示所有子域名也将采用同样的规则


本文标题:程序员安全规范:安全无小事,安全防范从Nginx配置做起
网页路径:http://cdbrznjsb.com/article/cdppgei.html

其他资讯

让你的专属顾问为你服务