在Laravel框架中,我们可以使用表单请求验证来确保上传的文件具有正确的MIME类型。以下是一个示例,演示如何创建一个自定义的表单请求来验证MIME类型:
首先,创建一个新的表单请求类:
use Illuminate\Foundation\Http\FormRequest;
class UploadFileRequest extends FormRequest
{
public function authorize()
{
// 这里可以放置授权逻辑,例如检查用户是否已认证
return true;
}
public function rules()
{
return [
'file' => [
// 确保文件是必须的
'required',
// 使用mimes规则来指定MIME类型
'mimes:jpg,jpeg,png', // 仅允许jpg, jpeg, png 类型
],
];
}
}
然后,在控制器中使用这个请求类:
use App\Http\Requests\UploadFileRequest;
class FileUploadController extends Controller
{
public function upload(UploadFileRequest $request)
{
// 文件验证通过,处理文件上传逻辑
$file = $request->file('file');
// ... 上传文件的代码
}
}
在上述代码中,mimes
规则被用来限制用户上传的文件必须是jpg
、jpeg
或png
类型。如果你需要更复杂的MIME类型验证,可以使用mimetypes
规则,它与mimes
规则用法一样,但是它检查的是完整的MIME类型。