当前位置:首页 > AI技术 > 正文内容

Think如何保护敏感目录不被访问 目录权限与防盗链设置完全指南|Duuu笔记

admin2个月前 (04-01)AI技术52

必须禁止Web访问的目录有application、config、runtime、common(若存在)、extend(含敏感配置),因其存储核心逻辑、数据库密码、日志缓存等,直接暴露将导致严重安全风险。

ThinkPHP 项目根目录下哪些目录必须禁止 Web 访问

直接答案:

application

config

runtime

common

(如果存在)、

extend

(若含敏感配置)这些目录,**绝不能通过浏览器 URL 直接访问**。它们存放了应用逻辑、数据库配置、缓存/日志文件,一旦暴露,轻则泄露数据库密码,重则被上传 WebShell。

常见错误现象:

http://yourdomain.com/application/database.php

能直接打开并显示明文配置;

http://yourdomain.com/runtime/log/

列出所有日志文件甚至可下载。

Web 服务器默认允许目录索引(如 Apache 的

Options Indexes

或 Nginx 未禁用

autoindex

),会导致目录遍历

ThinkPHP 的入口文件

public/index.php

是唯一合法入口,但其他目录没做路由拦截,靠 Web 服务器层防护

本地开发时用 PHP 内置服务器(

php -S

)不带路由规则,会直接暴露所有文件 —— 这不是 ThinkPHP 的锅,是启动方式错了

Apache 下用 .htaccess 禁止敏感目录访问

核心思路:在项目根目录(即包含

application

public

的那层)放

.htaccess

,对每个敏感目录单独加

Deny from all

。别指望一个规则管全部,ThinkPHP 目录结构可能因版本或定制而异。

典型配置示例(放在项目根目录):

PHP免费学习笔记(深入)

”;

独响

一个轻笔记+角色扮演的app

下载

Require all denied

Require all denied

Require all denied

Require all denied

必须确认服务器启用了

mod_rewrite

AllowOverride All

已在虚拟主机配置中开启,否则

.htaccess

完全不生效

ThinkPHP 6+ 默认使用

app

替代

application

,注意核对实际目录名,写错就等于没防

别把

.htaccess

放进

public/

目录 —— 它只对所在目录及子目录生效,根目录的规则才覆盖

application

等同级目录

Nginx 中 location 匹配要避开 rewrite 陷阱

Nginx 没有

.htaccess

,所有规则写在 server 块里。关键点:用

location ^~

做前缀精确匹配,**不能用

location ~

正则匹配敏感目录** —— 因为正则优先级低于

^~

,而 ThinkPHP 的通用 rewrite 规则(如

try_files

)常位于正则块中,会导致“禁止访问”被绕过。

正确写法(在 server 块内,位于 root 指令之后):

location ^~ /application/ { deny all; }

location ^~ /config/ { deny all; }

location ^~ /runtime/ { deny all; }

location ^~ /common/ { deny all; }

^~

表示“前缀匹配且不再检查正则”,确保这些规则绝对优先执行

路径末尾的

/

必须带上,否则

/application.php

这类文件也会被误拦

如果用了 ThinkPHP 的多应用模式,

app

目录名可能不同,得同步改

location

路径

某些运维习惯在

location /

里写

try_files $uri $uri/ /index.php?$query_string

,这个本身不危险,但必须保证上面的

deny all

规则在它之前 —— Nginx 按配置顺序匹配

防盗链只是补充,别指望它防目录遍历

防盗链(

valid_referers

)只能限制图片/CSS/JS 等静态资源被外站引用,对

/application/database.php

这种 PHP 文件完全无效 —— 浏览器访问时 referer 可伪造,且命令行

curl

根本不带 referer。

如果你看到网上教程让在

location ~ \.php$

里加防盗链,那是错的:PHP 脚本不该被直接访问,该被

deny all

,而不是“看 referer 再决定给不给”

真正需要防盗链的是

public/

下的上传目录(如

public/uploads/

),防止别人盗链你的用户头像或附件,这和保护

runtime

是两回事

别在

public/

里放

.htaccess

或写 Nginx

location

去拦

/application/

—— public 是 Web 根目录,它根本看不到上层目录,拦了个寂寞

最易被忽略的一点:上线前一定要用浏览器手动试几个敏感路径,比如

/runtime/

/config/

,别只信配置写了就完事。有些环境(如宝塔面板)会自动覆盖或禁用用户自定义的

location

规则,得去面板里关掉“防跨站攻击”之类的功能再测试。

相关文章

神经网络分类总结

从网络性能角度可分为连续型与离散型网络、确定性与随机性网络。 从网络结构角度可为前向网络与反馈网络。 从学习方式角度可分为有导师学习网络和无导师学习网络。 按连续突触性...

神经网络中的单层神经网络

神经网络是一种模拟人脑的神经网络以期能够实现类人工智能的机器学习技术。人脑中的神经网络是一个非常复杂的组织。成人的大脑中估计有1000亿个神经元之多。 看一个经典的神经网络。这是一个包...

推荐10个AI人工智能技术网站

除了研究和开发人工智能技术,OpenAI还积极参与人工智能伦理和安全的研究和探讨。 认为,人工智能技术的发展必须遵循伦理和法律的规范,以确保人工智能的应用不会对人类带来负面影响。...

一文讲清神经网络、BP神经网络、深度学习的关系

人工神经网络中的顶级代表。往往说《神经网络》就是指《BP神经网络》。 大家研究着各种神经网络,研究得不亦乐乎, 来了两个家伙Romelhart 和Mcclelland,...

前端开发高级应用:MuleRun如何连接Slack通知 MuleRun消息推送集成配置步骤实战案例|Duuu笔记

若MuleRun无法向Slack推送通知,需依次配置Incoming Webhook或Bot Token、在MuleRun中设置对应通知目标参数,并通过最小化任务测试验证;常见失败原因包括凭据错误、权...

AI核心技巧:如何重置openclaw硬件设置 openclaw恢复出厂设置操作方法【操作】深度解析|Duuu笔记

重置 OpenClaw 配置有四种方法:一、交互式向导重置(openclaw onboard --reset);二、指定作用域的命令行重置(如--reset-scope config);三、手动删除~...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。