nginx配置只允许域名访问,禁止ip访问80,443端口
2021/12/19 7:24:25
本文主要是介绍nginx配置只允许域名访问,禁止ip访问80,443端口,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
一、背景
客户扫描阿里云服务器,发现渗透漏洞(.git文件泄露漏洞),可以直接使用IP访问项目底下的某个文件,针对这个问题,需要对nginx进行配置,不使用IP访问项目,而只能使用域名访问。
二、解决方法
1)先来配置80端口的
打开Nginx的配置文件:
#vi /usr/local/nginx/conf/nginx.conf
增加以下代码片段
1 server 2 { 3 listen 80 default; 4 return 403; 5 }
最后重载配置即可 nginx -s reload
http://ip访问报403,域名访问正常
以上代码是针对80端口的,如果跟我一样配置了https(443端口)的话,需要再加点东西
2)配置80 443端口一起的
1 server 2 { 3 listen 80 default; 4 listen 443 default_server; 5 server_name _; 6 return 403; 7 #SSL-START SSL相关配置,请勿删除或修改下一行带注释的404规则 8 #error_page 404/404.html; 9 ssl_certificate /etc/letsencrypt/live/0ne0ne.com/fullchain.pem; 10 ssl_certificate_key /etc/letsencrypt/live/0ne0ne.com/privkey.pem; 11 ssl_protocols TLSv1 TLSv1.1 TLSv1.2; 12 ssl_ciphers ECDHE-RSA-AES128-GCM- 13 SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4:!DH:!DHE; 14 ssl_prefer_server_ciphers on; 15 ssl_session_cache shared:SSL:10m; 16 ssl_session_timeout 10m; 17 error_page 497 https://$host$request_uri; 18 #SSL-END 19 }
3)为什么要加上ssl证书的配置
Nginx 上对于 SSL 服务器在不配置证书的时候会出现协议错误,哪怕端口上配置了其他网站也会报错。解决方法就是随便生成一个证书填进去就好。
就是说443端口如果也跟80端口那样子的配置,使用https方式访问正常的域名也会被拒绝连接。
最后重载配置即可
https://ip访问报403, 域名访问正常
参考链接https://www.jianshu.com/p/c632e98468cd
这篇关于nginx配置只允许域名访问,禁止ip访问80,443端口的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-13用Nginx防范DDoS攻击的那些事儿
- 2024-12-13用Terraform在AWS上搭建简单NGINX服务器指南
- 2024-10-29Nginx发布学习:从入门到实践的简单教程
- 2024-10-28Nginx发布:新手入门教程
- 2024-10-21nginx 怎么设置文件上传最大20M限制-icode9专业技术文章分享
- 2024-10-17关闭 nginx的命令是什么?-icode9专业技术文章分享
- 2024-09-17Nginx实用篇:实现负载均衡、限流与动静分离
- 2024-08-21宝塔nginx新增8022端口方法步骤-icode9专业技术文章分享
- 2024-08-21nginx配置,让ws升级为wss访问的方法步骤-icode9专业技术文章分享
- 2024-08-15nginx ws代理配置方法步骤-icode9专业技术文章分享