我正在/ test /上托管一个网站,但如果用户知道文件名,可以通过访问网址来访问文件.例如:domain.com/test/readmesample.txt我有它像上面设置但现在当我去domain.com/test index.html文件不会加载,我得到403禁止.如何...

我正在/ test /上托管一个网站,但如果用户知道文件名,可以通过访问网址来访问文件.例如:
domain.com/test/readmesample.txt
我有它像上面设置但现在当我去domain.com/test index.html文件不会加载,我得到403禁止.
如何进行设置,以便在进行/测试时允许加载html文件,同时仍然阻止该目录中的文件?这包括index.html以外的文件,文件夹和.files.
location ~ /test {
deny all;
}
这是我的配置文件
server {
listen 80;
listen 443 ssl default_server;
root /config/www;
index index.html index.htm index.php;
server_name www.domain.com;
ssl_certificate /config/keys/letsencrypt/fullchain.pem;
ssl_certificate_key /config/keys/letsencrypt/privkey.pem;
ssl_dhparam /config/nginx/dhparams.pem;
ssl_ciphers 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX';
ssl_prefer_server_ciphers on;
client_max_body_size 0;
location / {
try_files $uri $uri/ /index.html /index.php?$args =404;
}
location ~ /new {
deny all;
}
location ~ \.php${
fastcgi_split_path_info ^(.+\.php)(/.+)$;
# With php5-cgi alone:
fastcgi_pass 127.0.0.1:9000;
# With php5-fpm:
#fastcgi_pass unix:/var/run/php5-fpm.sock;
fastcgi_index index.php;
include /etc/nginx/fastcgi_params;
}
先感谢您
解决方法:
你可以用以下方法明确地打破/test/index.html:
location = /test/index.html {
}
location ^~ /test {
deny all;
}
精确匹配位置具有最高优先级,并且^?修饰符将前缀位置的优先级置于同一级别的正则表达式位置之上.
有关更多信息,请参见this document
本文标题为:nginx – 阻止访问目录中的文件但允许index.html


基础教程推荐
- ajax中用josnp接收josn数据的实现方法 2023-02-14
- 详解ajax跨域问题解决方案 2023-02-13
- Ajax 入门之 GET 与 POST 的不同处详解 2023-01-31
- ajax+springmvc实现C与View之间的数据交流方法 2023-01-31
- springmvc 发送ajax出现中文乱码的解决方法汇总 2022-12-18
- Web应用开发(Servlet+html+Mysql)入门小示例 2023-10-25
- 如何学习html的各种标签 2022-11-16
- html学习笔记 2023-10-27
- 关于 html:如何在 css 中使表格的整行可点击? 2022-09-21
- Ajax 动态载入html页面后不能执行其中的js快速解决方法 2023-02-14