翼度科技»论坛 云主机 服务器技术 查看内容

Nginx 禁止直接访问目录或文件的操作方法

11

主题

11

帖子

33

积分

新手上路

Rank: 1

积分
33
前言
  1. Nginx 默认是不允许列出整个目录的。
复制代码
如需此功能,打开
  1. nginx.conf
复制代码
文件或你要启用目录浏览虚拟主机的配置文件,在
  1. location server
复制代码
  1. http
复制代码
段中加入
  1. autoindex on;
复制代码
另外两个参数最好也加上去:
  1. autoindex_exact_size off;
复制代码
默认为
  1. on
复制代码
,显示出文件的确切大小,单位是 bytes。
改为
  1. off
复制代码
后,显示出文件的大概大小,单位是 KB 或者 MB 或者 GB
  1. autoindex_localtime on;
复制代码
默认为
  1. off
复制代码
,显示的文件时间为 GMT 时间。
改为
  1. on
复制代码
后,显示的文件时间为文件的服务器时间。

第一种:autoindex 配置


一级目录或整个虚拟主机开启目录流量

  1. nginx.conf
复制代码
文件 中
  1. server
复制代码
段添加
  1. location / {
  2.   autoindex on;
  3.   autoindex_localtime on; #之类的参数写这里
  4. }
复制代码
单独目录开启目录流量


二级目录开启目录流量
  1. location /down/ {
  2.   autoindex on;
  3. }
复制代码
虚拟目录开启目录流量
  1. location /down/ {
  2.   alias /home/wwwroot/test/;
  3.   autoindex on;
  4. }
复制代码
第二种:nginx location 配置


一、禁止访问某些后缀文件
  1. location ~ \.(ini|conf|txt)$ {
  2.     deny all;
  3. }
复制代码
二、禁止访问目录或目录下文件
  1. #禁止访问目录
  2. location ^~ /test/ {
  3.     deny all;
  4. }
复制代码
  1. #禁止访问目录下文件
  2. location ^~ /test {
  3.     deny all;
  4. }
复制代码
三、禁止访问某个目录下的指定文件后缀文件
  1. # 禁止访问某个目录下的 php 后缀文件
  2. location /directory {
  3.     location ~ .*\.(php)?$ {
  4.     deny all;
  5.     }
  6. }
复制代码
  1. # 禁止访问多个目录下的 php 后缀文件
  2. location ~* ^/(directory1|directory2)/.*\.(php)${
  3.     deny all;
  4. }
复制代码
四、nginx location 匹配相关


    1. =
    复制代码
    表示精确匹配
    1. ^~
    复制代码
    表示 uri 以某个字符串开头
    1. ~
    复制代码
    正则匹配(区分大小写)
    1. ~*
    复制代码
    正则匹配(不区分大小写) !和!*分别为区分大小写不匹配及不区分大小写不匹配的正则
    1. /
    复制代码
    任何请求都会匹配
  • 匹配优先级:
    1. = > ^~ > /
    复制代码

五、nginx 配置图片直接下载不打开
  1. location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ {
  2.     add_header Content-Disposition attachment;                  
  3. }
复制代码
到此这篇关于Nginx 禁止直接访问目录或文件的方法的文章就介绍到这了,更多相关nginx 禁止直接访问目录内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

来源:https://www.jb51.net/article/266355.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

举报 回复 使用道具