美文网首页
Nginx 403 forbidden多种原因及故障模拟重现

Nginx 403 forbidden多种原因及故障模拟重现

作者: 天上的小仙女呀 | 来源:发表于2021-03-03 11:55 被阅读0次

访问Nginx出现状态码为403 forbidden原因及故障模拟
1 nginx配置文件里不配置默认首页参数或者首页文件在站点目录下没有
index index.php index.html index.htm;
复制代码
问题模拟示例:
[root@www extra]# cat www.conf

www virtualhost by oldboy

server {
listen 80;
server_name www.etiantian.org;
location / {
root html/www;
#index index.html index.htm;#<==注释首页文件配置
}
access_log off;
}
[root@www extra]# ../../sbin/nginx -sreload
[root@www extra]# tail -1 /etc/hosts
10.0.0.8 www.etiantian.orgbbs.etiantian.org blog.etiantian.org etiantian.org
[root@www extra]# ll ../../html/www/
总用量 12
drwxr-xr-x 2 root root 4096 4月 15 14:20 blog
-rw-r--r-- 1 root root 4 4月 17 17:11index.html #<==存在首页文件
drwxr-xr-x 2 root root 4096 4月 15 14:19 oldboy
[root@www extra]# curl -I -s 10.0.0.8|head-1
HTTP/1.1 403 Forbidden #<==问题是,Nginx没有指定首页文件的参数,因此访问Nginx时不会把index.html当首页,所以报403错误。
复制代码
站点目录下没有配置文件里指定的首页文件index.php index.html index.htm。
[root@www extra]# cat www.conf

www virtualhost by oldboy

server {
listen 80;
server_name www.etiantian.org;
location / {
root html/www;
index index.htmlindex.htm; #<==配置首页文件配置
}
access_log off;
}
[root@www extra]# ../../sbin/nginx -sreload
[root@www extra]# rm -f ../../html/www/index.html#<==删除物理首页文件
[root@www extra]# curl -I -s 10.0.0.8|head-1
HTTP/1.1 403 Forbidden
复制代码
提示:以上1和2有一个参数可以解决这个问题就是:
autoindex on;
[root@www extra]# cat www.conf

www virtualhost by oldboy

server {
listen 80;
server_name www.etiantian.org;
location / {
root html/www;
autoindex on; #<==当找不到首页文件时,会展示目录结构,这个功能一般不要用除非有需求。
}
access_log off;
}
复制代码
效果如下:
站点目录或内部的程序文件没有Nginx用户访问权限。
[root@www extra]# echo test >../../html/www/index.html
[root@www extra]# chmod 700../../html/www/index.html #<==设置700让nginx用户无权读取
[root@www extra]# ls -l ../../html/www/index.html
-rwx------ 1 root root 5 4月 17 17:15../../html/www/index.html
[root@www extra]# curl -I -s 10.0.0.8|head-1
HTTP/1.1 403 Forbidden #<==403错误
[root@www extra]# chmod 755../../html/www/index.html #<==设置755让nginx用户有权读取
[root@www extra]# curl -I -s 10.0.0.8|head-1
HTTP/1.1 200 OK #<==200 OK了
复制代码
Nginx配置文件中设置allow、deny等权限控制,导致客户端没有没权限访问。
[root@www extra]# cat www.conf

www virtualhost by oldboy

server {
listen 80;
server_name www.etiantian.org;
location / {
root html/www;
index index.html index.htm;
allow 192.168.1.0/24;
deny all;
}
access_log off;
}
[root@www extra]# curl -I -s 10.0.0.8|head-1
HTTP/1.1 200 OK #<==设置755让nginx用户有权读取
[root@www extra]# ../../sbin/nginx -sreload
[root@www extra]# curl -I -s 10.0.0.8|head-1
HTTP/1.1 403 Forbidden
复制代码
提示:上述403问题并不是nginx才有,apache服务的Forbidden 403问题同样也是这几个问题导致的。
学linux运维或需运维文档资料请留邮箱

作者:老码农阿
链接:https://juejin.cn/post/6935271174083444743/
来源:掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

相关文章

  • Nginx 403 forbidden多种原因及故障模拟重现

    访问Nginx出现状态码为403 forbidden原因及故障模拟1 nginx配置文件里不配置默认首页参数或者首...

  • nginx 403 forbidden

    首先确保虚拟主机路径配置正确 nginx django .conf 配置nginx python Django 集...

  • Nginx 403 forbidden

    修改nginx.conf

  • Nginx 403 Forbidden

    原文链接:https://zhongyi.io/2017/11/nginx-403-forbidden/每次重新部...

  • nginx 403 forbidden

    当你将 nginx 作为 web server 的时候,403 错误主要是下面两条原因: 一、所有者对目录没有写的...

  • NGINX 403 FORBIDDEN

    作为一个phper,常常需要编译LNMP环境,一会儿在公司电脑,一会儿在家的电脑,一会儿在Mac下,一会儿在Ubu...

  • nginx 403 Forbidden

    出现403 不要怕,一般是没有权限,使用管理员身份打开 使用后发现还是不行 查看nginx 目录下error.lo...

  • 错误:Nginx 403 forbidden

    当Nginx读取本地目录时如果收到403错误,是由于nginx的权限问题。修改nginx的权限: 编辑nginx....

  • Nginx 出现 403 Forbidden

    步骤一: 检查目录权限。权限不足的就加个权限吧。 例子:chmod -R 755 / var/www 步骤二: 打...

  • Nginx容器报错:403 forbidden

    参考:Nginx出现403 forbidden 二、缺少index.html或者index.php文件,就是配置文...

网友评论

      本文标题:Nginx 403 forbidden多种原因及故障模拟重现

      本文链接:https://www.haomeiwen.com/subject/kldqqltx.html