一.Laravel表单验证
创建控制器并在添加方法shore()中编写验证
public function store(Request $request)
{
// 验证以及保存提交的数据...
}
编写验证逻辑
validate 方法会接收 HTTP 传入的请求以及验证的规则。如果验证通过,你的代码就可以正常的运行。若验证失败,则会抛出异常错误消息并自动将其返回给用户。在一般的 HTTP 请求下,都会生成一个重定向响应,对于 AJAX 请求则会发送 JSON 响应
public function store(Request $request)
{
$this->validate($request, [
'title' => 'required|unique:posts|max:255',//标题不为空,post提交,最长255
'body' => 'required',//主要内容不为空
]);
//成功上传新数据,将其保存到数据库...
}
嵌套属性
$this->validate($request, [
'title' => 'required|unique:posts|max:255',
'author.name' => 'required',//在验证规则中使用「点」语法来指定他们
'author.description' => 'required',
]);
显示验证错误
Laravel 会自动把用户重定向到先前的位置。另外,所有的验证错误会被自动 闪存至 session
$errors 变量在每次请求的所有视图中都可以被使用,你可以很方便的假设 $errors 变量已被定义且进行安全地使用
if (count($errors) > 0)
<div class="alert alert-danger">
<ul>
@foreach ($errors->all() as $error)
<li>{{ $error }}</li>//在视图中显示错误的消息
@endforeach
</ul>
</div>
@endif
自定义闪存的错误消息格式
在控制器中重写 formatValidationErrors。别忘了将 Illuminate\Contracts\Validation\Validator 类引入到文件上方
<?php
namespace App\Http\Controllers;
use Illuminate\Foundation\Bus\DispatchesJobs;
use Illuminate\Contracts\Validation\Validator;
use Illuminate\Routing\Controller as BaseController;
use Illuminate\Foundation\Validation\ValidatesRequests;
abstract class Controller extends BaseController
{
use DispatchesJobs, ValidatesRequests;
/**
* {@inheritdoc}
*/
protected function formatValidationErrors(Validator $validator)
{
return $validator->errors()->all();
}
}
表单请求验证
表单请求是一个自定义的请求类,里面包含着验证逻辑。要创建一个表单请求类,可使用 Artisan 命令行命令 make:request
php artisan make:request StoreBlogPostRequest
新生成的类文件会被放在 app/Http/Requests 目录下
public function rules() { return [ 'title' => 'required|unique:posts|max:255', 'body' => 'required', ]; }
在控制器方法中利用类型提示传入请求。传入的请求会在控制器方法被调用前进行验证,意思就是说你不会因为验证逻辑而把控制器弄得一团糟
/**
* 保存传入的博客文章。
*
* @param StoreBlogPostRequest $request
* @return Response
*/
public function store(StoreBlogPostRequest $request)
{
// 传入的请求是有效的...
}
如果验证失败,就会生成一个重定向响应把用户返回到先前的位置。这些错误会被闪存到 session,所以这些错误都可以被显示
授权表单请求
表单的请求类内包含了 authorize 方法。在这个方法中,你可以确认用户是否真的通过了授权,以便更新指定数据
/**
* 判断用户是否有权限做出此请求。
*
* @return bool
*/
public function authorize()
{
$commentId = $this->route('comment');
return Comment::where('id', $commentId)
->where('user_id', Auth::id())->exists();
}
自定义闪存的错误消息格式
自定义验证失败时闪存到 session 的验证错误格式,可在你的基底请求 (App\Http\Requests\Request) 中重写 formatErrors,文件上方引入 Illuminate\Contracts\Validation\Validator 类
/**
* {@inheritdoc}
*/
protected function formatErrors(Validator $validator)
{
return $validator->errors()->all();
}
自定义错误消息
(你可以通过重写表单请求的 messages 方法来自定义错误消息。此方法必须返回一个数组,其中含有成对的属性或规则以及对应的错误消息)
/**
* 获取已定义验证规则的错误消息。
*
* @return array
*/
public function messages()
{
return [
'title.required' => '标题是必填的',
'body.required' => '消息是必填的',
];
}
处理错误消息
调用一个 Validator 实例的 errors 方法,会得到一个 Illuminate\Support\MessageBag 的实例,里面有许多可让你操作错误消息的便利方法
$messages = $validator->errors(); echo $messages->first('email')//查看特定字段的第一个错误消息
foreach ($messages->get('email') as $message) { //查看特定字段的所有错误消息,取所有消息中的一个数组,可以使用 get 方法 }
foreach ($messages->all() as $message) { //查看所有字段的所有错误消息 }
if ($messages->has('email')) { //判断特定字段是否含有错误消息 }
echo $messages->first('email', '<p>:message</p>');//获取格式化后的错误消息
foreach ($messages->all('<li>:message</li>') as $message) { //获取所有格式化后的错误消息 }
自定义错误消息
通过传递三个参数到 Validator::make 方法来自定义验证消息
$messages = [
'required' => ':attribute 的字段是必要的。',//:attribute 占位符会被通过验证的字段实际名称所取代
];
$validator = Validator::make($input, $rules, $messages);
指定自定义消息到特定的属性
$messages = [ 'email.required' => '我们需要知道你的 e-mail 地址!',//属性名称后加上「.」符号和指定验证的规则 ];
可用的验证规则<----#---->点我
二.重要知识点
1.随机数(PHP7)
random_bytes 函数返回 string 类型,并接受一个 int 类型为参数,该参数规定了所返回字符串的字节长度
$bytes = random_bytes('10'); var_dump(bin2hex($bytes));//bin2hex() 函数把 ASCII 字符的字符串转换为十六进制值。字符串可通过使用 pack() 函数再转换回去 //possible ouput: string(20) "7dfab0af960d359388e6"
random_int 函数返回给定范围内的整型数
var_dump(random_int(1, 100)); //possible output: 27
2.毫秒级时间戳
<?php
function getMillisecond() {
list($t1, $t2) = explode(' ', microtime());//microtime() 函数返回当前 Unix 时间戳的微秒数,explode() 函数把字符串打散为数组,list() 函数用于在一次操作中给一组变量赋值
return (float)sprintf('%.0f',(floatval($t1)+floatval($t2))*1000);//sprintf() 函数把格式化的字符串写入变量中,floatval ()获取变量的浮点值,(float)获取变量的浮点值
}
echo getMillisecond();
3.UUID(唯一识别码)
//www.greatytc.com/p/792c2bbe107e
4.动态获取文件后缀
$ext = $file->getClientOriginalExtension();
5.文件类型表单验证
self::validate($request, [
'img' => 'required|mimes:jpeg,bmp,png,gif,jpg',
'photoName' => 'required|string|min:6|max:10'
]);
6.更换中文错误提示信息
复制resources/lang/en/validation.php
文件到自己新建的zh-cn
目录
然后替换其中的内容https://laravel-china.org/articles/5840/validation-validation-in-laravel-returns-chinese-prompt
'attributes' => [
'name' => '名字',
'age' => '年龄',
'img' => '图片',
'photoName' => '图片名称',
'user_name' => '姓名',
'pwd' => '密码',
'sex' => '性别',//添加自定义字段
],
7.Laravel时间区修改
在config/app.php修改该字段
'timezone' => 'PRC',//把原来的TRC改为PRC
8.自定义配置使用
在config下新建一个存放配置的PHP文件
<?php
return [
'upload_dir' => public_path() . '/uploads',//上传图片的路径
];
在页面中调用:
config('sys.upload_dir')