Nginx 只允许 www 域名访问并禁止裸域名访问的实现步骤
|
如何通过 Nginx 只允许 www 域名访问并禁止裸域名访问
在网站管理中,很多时候我们希望用户只能通过带有的域名访问,而对于裸域名(即没有前缀的域名)则禁止访问或进行重定向。这可以通过修改 Nginx(或 Tengine)的服务器配置来实现。本文将介绍如何配置 Nginx,以实现用户只能通过访问网站,而禁止或重定向裸域名。
步骤 1:配置 Nginx 处理 www 域名
首先,我们在 Nginx 中为域名创建一个虚拟主机,确保所有通过的请求都指向网站的正确目录。具体配置如下:- server {
- listen 80;
- server_name www.test.net;
- root /var/www/test;
- index index.html index.php;
- location / {
- try_files $uri $uri/ =404;
- }
- }
复制代码 这个配置告诉 Nginx,所有的请求将指向网站根目录,并尝试加载或文件。
步骤 2:禁止裸域名访问
为了禁止用户通过裸域名访问,我们可以创建一个独立的虚拟主机,并使用 Nginx 的指令。这会让 Nginx 立即关闭连接,不返回任何内容,从而禁止访问。- server {
- listen 80;
- server_name test.net;
- return 444;
- }
复制代码 这种方式非常直接,用户尝试访问时将看到连接被拒绝的提示。
步骤 3:重定向裸域名到 www 域名(可选)
如果你希望访问的用户自动重定向到,可以修改配置使用重定向。这样,所有对裸域名的请求都会被引导到带的域名。- server {
- listen 80;
- server_name test.net;
- return 301 http://www.test.net$request_uri;
- }
复制代码 这种方式不仅可以保留用户请求的路径(例如会重定向到),还对 SEO 更加友好。
步骤 4:重启 Nginx 应用配置
完成配置后,记得重启 Nginx 服务器,使更改生效:- sudo systemctl restart nginx
复制代码 总结
通过修改 Nginx 配置,我们可以轻松实现用户只能通过域名访问,而直接访问裸域名时禁止访问或自动重定向到。这不仅提升了网站的品牌统一性,还能改善用户体验和 SEO 效果。
到此这篇关于如何通过 Nginx 只允许 www 域名访问并禁止裸域名访问的文章就介绍到这了,更多相关 Nginx www 域名访问内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
来源:https://www.jb51.net/server/329030koy.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作! |
|
|
|
发表于 2024-11-7 16:56:28
举报
回复
分享
|
|
|
|