
ThinkPHP 6 实现文件上传需创建上传目录并设置可写权限,前端表单使用 multipart/form-data 编码,控制器通过 Request::file() 获取文件,利用 Filesystem 组件的 putFile() 方法自动重命名并保存至 public/storage 目录,支持 validate() 自定义大小、类型限制,超出规则抛出 ValidateException 异常,上传后执行 php think storage:link 创建软链接,即可通过 /storage/avatars/xxx.jpg 访问文件,整体流程简洁安全。
ThinkPHP 实现文件上传功能非常方便,框架内置了完善的文件处理类,可以快速完成图片、文档等常见格式的上传操作。下面以 ThinkPHP 6 为例,介绍如何实现一个基本且安全的文件上传流程。
在项目根目录下创建用于存放上传文件的目录,例如:
public/uploads/确保该目录有可写权限,Web 服务器能正常读写。
上传页面需要使用 multipart/form-data 编码类型,才能正确提交文件数据:
在控制器中使用 \think\facade\Request 获取上传文件,并进行验证和移动操作:
use think\facade\Request;说明:
如果需要更严格的控制,比如限制类型、大小:
$savename = \think\facade\Filesystem::disk('public')超出限制会抛出 ValidateException 异常,可在 catch 中捕获提示用户。
上传后返回的路径是类似 avatars/xxxxx.jpg,要通过 URL 访问,需配置路由或软链接:
执行命令创建软链接(Linux/Mac):
php think storage:link之后可通过 /storage/avatars/xxxxx.j
pg 直接访问。
基本上就这些。ThinkPHP 的 Filesystem 组件封装得很简洁,配合验证机制能有效防止恶意上传。只要注意目录权限和文件类型限制,就能实现一个安全可靠的上传功能。