如何验证 Laravel 5.4 中的文件名
How to validate the file name in Laravel 5.4
我有一个包含三个输入字段的表单。我想在处理输入值之前验证它们。我想在处理文件名之前验证文件名的地方。我使用正则表达式和 alpha_dash。但是我收到一个有效文件名的错误。我希望我的文件名只包含小写字母、数字、下划线和破折号。如何检查文件名的有效性?
Html
<form action="create" method="POST" enctype="multipart/form-data">
{{csrf_field()}}
<table cellpadding="2" width="20%" align="center"
cellspacing="2">
<tr>
<td colspan=2>
<center><font size=4><b>Add the iteams please</b></font></center>
</td>
</tr>
<tr>
<td>Heading</td>
<td><input type="text" name="heading" id="heading" size="30">
{!! $errors->first('heading', '<p class="red">:message</p>') !!}
</td>
</tr>
<tr>
<td>Image</td>
<td><input type="file" name="image" id="image" size="40">
{!! $errors->first('image', '<p class="red">:message</p>') !!}
</td>
</tr>
<tr>
<td></td>
<td colspan="2"><input type="submit" name="submit" value="Add Item" /></td>
</tr>
</table>
</form>
控制器部分
- 使用正则表达式格式:
- 我收到错误消息,“图像格式无效”。
public function store(){
$this->validate(request(),[
'heading'=>'required',
'contentbody'=>'required',
‘image'=>['required','image','mimes:jpeg,png,jpg,gif,svg','max:2048','regex:/^[a-z0-9-_]+$/' ]
]);
}
- 使用 Alpa_dash:
- 我收到错误消息,“图像只能包含字母、数字和破折号”。
public function store(){
$this->validate(request(),[
'heading'=>'required',
'contentbody'=>'required',
'image'=>'required|image|mimes:jpg,png,jpeg,gif,svg|max:2048|alpha_dash'
}
请帮忙,
谢谢!
我认为您需要使用自定义正则表达式
^[a-z0-9_.-]*$
并在您的验证中像这样使用
public function store(){
$this->validate(request(),[
'heading'=>'required',
'contentbody'=>'required',
‘image'=>'required|image|mimes:jpg,png,jpeg,gif,svg|max:2048|regex:/^[a-z0-9_.-]*$/'
]);
编辑 2:
我不确定,但根据文档 laravel 仅支持上述格式。然而,当我对图像使用验证时,我发现 jpg 没有问题,但仍然让这个问题出现..
编辑 3
有关自定义验证,请参阅 here
如果有人和我有同样的问题。我通过将文件名更改为当前时间戳而不是使用原始文件名来解决我的问题。这样,我就不必担心要保存在数据库中的原始文件名的验证。
public function store(Request $request)
{
$this->validate($request,[
'heading'=>'required',
'contentbody'=>'required',
'image'=>['required','image','mimes:jpg,png,jpeg,gif,svg','max:2048']
]);
if($request->hasFile('image')){
$inputimagename= time().'.'.$request->file('image')->getClientOriginalExtension();
$request->image->storeAs('public/upload', $inputimagename);
Post::create([
'heading'=>request('heading'),
'content'=>request('contentbody'),
'image'=>$inputimagename,
]);
}
return redirect('/home');
}
- 创建自定义验证规则 class,例如
Filename
,并将其放在路径 app/Rules/Filename.php
.
<?php
namespace App\Rules;
use Illuminate\Contracts\Validation\Rule;
use Symfony\Component\HttpFoundation\File\UploadedFile;
class Filename implements Rule
{
protected $regex;
public function __construct(string $regex)
{
$this->regex = $regex;
}
public function passes($attribute, $value)
{
if (!($value instanceof UploadedFile) || !$value->isValid()) {
return false;
}
return preg_match($this->regex, $value->getClientOriginalName()) > 0;
}
public function message()
{
return 'The :attribute name is invalid.';
}
}
- 在您的请求规则中添加如下自定义规则:
use App\Rules\Filename;
public function store() {
$this->validate(request(), [
'heading' => 'required',
'contentbody' => 'required',
'image' => [
'required',
'image',
'mimes:jpeg,png,jpg,gif,svg',
'max:2048',
new Filename('/^[a-z0-9-_]+$/'), // This is your custom rule
],
]);
}
我有一个包含三个输入字段的表单。我想在处理输入值之前验证它们。我想在处理文件名之前验证文件名的地方。我使用正则表达式和 alpha_dash。但是我收到一个有效文件名的错误。我希望我的文件名只包含小写字母、数字、下划线和破折号。如何检查文件名的有效性?
Html
<form action="create" method="POST" enctype="multipart/form-data">
{{csrf_field()}}
<table cellpadding="2" width="20%" align="center"
cellspacing="2">
<tr>
<td colspan=2>
<center><font size=4><b>Add the iteams please</b></font></center>
</td>
</tr>
<tr>
<td>Heading</td>
<td><input type="text" name="heading" id="heading" size="30">
{!! $errors->first('heading', '<p class="red">:message</p>') !!}
</td>
</tr>
<tr>
<td>Image</td>
<td><input type="file" name="image" id="image" size="40">
{!! $errors->first('image', '<p class="red">:message</p>') !!}
</td>
</tr>
<tr>
<td></td>
<td colspan="2"><input type="submit" name="submit" value="Add Item" /></td>
</tr>
</table>
</form>
控制器部分
- 使用正则表达式格式:
- 我收到错误消息,“图像格式无效”。
public function store(){
$this->validate(request(),[
'heading'=>'required',
'contentbody'=>'required',
‘image'=>['required','image','mimes:jpeg,png,jpg,gif,svg','max:2048','regex:/^[a-z0-9-_]+$/' ]
]);
}
- 使用 Alpa_dash:
- 我收到错误消息,“图像只能包含字母、数字和破折号”。
public function store(){
$this->validate(request(),[
'heading'=>'required',
'contentbody'=>'required',
'image'=>'required|image|mimes:jpg,png,jpeg,gif,svg|max:2048|alpha_dash'
}
请帮忙, 谢谢!
我认为您需要使用自定义正则表达式
^[a-z0-9_.-]*$
并在您的验证中像这样使用
public function store(){
$this->validate(request(),[
'heading'=>'required',
'contentbody'=>'required',
‘image'=>'required|image|mimes:jpg,png,jpeg,gif,svg|max:2048|regex:/^[a-z0-9_.-]*$/'
]);
编辑 2:
我不确定,但根据文档 laravel 仅支持上述格式。然而,当我对图像使用验证时,我发现 jpg 没有问题,但仍然让这个问题出现..
编辑 3
有关自定义验证,请参阅 here
如果有人和我有同样的问题。我通过将文件名更改为当前时间戳而不是使用原始文件名来解决我的问题。这样,我就不必担心要保存在数据库中的原始文件名的验证。
public function store(Request $request)
{
$this->validate($request,[
'heading'=>'required',
'contentbody'=>'required',
'image'=>['required','image','mimes:jpg,png,jpeg,gif,svg','max:2048']
]);
if($request->hasFile('image')){
$inputimagename= time().'.'.$request->file('image')->getClientOriginalExtension();
$request->image->storeAs('public/upload', $inputimagename);
Post::create([
'heading'=>request('heading'),
'content'=>request('contentbody'),
'image'=>$inputimagename,
]);
}
return redirect('/home');
}
- 创建自定义验证规则 class,例如
Filename
,并将其放在路径app/Rules/Filename.php
.
<?php
namespace App\Rules;
use Illuminate\Contracts\Validation\Rule;
use Symfony\Component\HttpFoundation\File\UploadedFile;
class Filename implements Rule
{
protected $regex;
public function __construct(string $regex)
{
$this->regex = $regex;
}
public function passes($attribute, $value)
{
if (!($value instanceof UploadedFile) || !$value->isValid()) {
return false;
}
return preg_match($this->regex, $value->getClientOriginalName()) > 0;
}
public function message()
{
return 'The :attribute name is invalid.';
}
}
- 在您的请求规则中添加如下自定义规则:
use App\Rules\Filename;
public function store() {
$this->validate(request(), [
'heading' => 'required',
'contentbody' => 'required',
'image' => [
'required',
'image',
'mimes:jpeg,png,jpg,gif,svg',
'max:2048',
new Filename('/^[a-z0-9-_]+$/'), // This is your custom rule
],
]);
}