您的位置:首页 > 编程学习 > > 正文

laravel接口响应时间(laravel请求参数校验方法)

更多 时间:2021-10-10 00:12:17 类别:编程学习 浏览量:584

laravel接口响应时间

laravel请求参数校验方法

对于后端开发而言,前端request请求中的参数校验是一个必不可少的环节。无论传来的参数是id还是email还是其他的参数,我们都要对参数的类型、大小、格式等等做这样或者那样的校验,然后才进行逻辑处理,以确保逻辑处理时万无一失,不会出现异样。于是乎,在controller层中就会出现一大坨的校验代码,这些校验代码甚至有时候都超过了正常的逻辑代码的数量,对于程序的扩展和维护很不利的。

但是,laravel为我们提供了一个很好的服务去解决参数校验这个问题,它就是----Validate。

首先,我们需要建一个路由,暂时就叫"test"吧,然后test对应着TestController中的test方法。

  1. Route::get('test', 'TestController@test');
  2. class TestController extends Controller
  3. {
  4. public function test(Request $request)
  5. {
  6.  
  7. }
  8. }

假设请求的参数中需要id、title这两个参数,并且id必须是数字,且长度是1到10,并且是DB中的一行数据的主键、title必须是字符串,id和title都不能为空。一般的框架在写的时候就会先取到id和title,然后对取到的id和title进行“是否是空”、“是否长度在1到10之间”、“通过id能否在数据库中找到数据”等等繁琐的校验,利用laravel的“Validate”你只需要这样就可以了。

  1. public function test(Request $request)
  2. {
  3. $validate = Validator::make($request->all(), [
  4. 'id' => 'required|integer|between:1,10',
  5. 'title' => 'required|string'
  6. ]);

如果没有错误,就会继续往下进行逻辑处理。假如说校验不通过,例如id不在1和10之间,可以通过“validate”实例中的“errors()”方法,得到所有的错误,然后将错误放回给客户端,如果想返回错误队列中的头一个错误,就写$validate->errors()->first(),如果想返回所有错误列表,就写“$validate->errors()->all()”。如下:

  1. if($validate->fails())
  2. {
  3. return $validate->errors()->first();
  4. }

或者返回

  1. if($validate->fails())
  2. {
  3. return $validate->errors()->all();
  4. }

假如请求参数中的id不是一个数字,而是字符串,结果就会出现:

laravel接口响应时间(laravel请求参数校验方法)

你可能会想:返回结果能否使中文?答案当然是可以,你可以针对自己的程序,换成你任何想要的语言:

在项目中找到“resources”目录下的“lang” 中的 “en”文件夹中的“validation.php”文件,

laravel接口响应时间(laravel请求参数校验方法)

打开,然后找到这一行:

  1. 'integer' => 'The :attribute must be an integer.',

这句话除了“:attribute”是不是其他字和返回结果一模一样?或许你已经猜到了:这就是你调用的‘integer'方法的返回结果,“:attribute”是个变量,是你传的“id”!现在,你可以写成任何语言,我把它改为中文:

  1. 'integer' => ':attribute 必须是数字!'

然后我们再看返回结果:

laravel接口响应时间(laravel请求参数校验方法)

完美!只要你利用Validator的make方法,在请求参数数组中对应上‘integer'、“required”等字符串就可以利用laravel提供的服务,对请求参数进行“数字”、“判空”等校验,laravel提供的众多校验方法,可以在laravel官网查询。(ps:或者直接查询validation.php这个文件!)

你或许还会想:我现在校验了id是否为空,id是否是数字,我还想校验id对应的数据能否在数据库中查得到!这能实现吗?

答案是:完全可以!在上篇文章中我介绍了laravel核心是一个IOC容器,你可以很方便的扩展任何服务注入到容器中!自定义validate服务也不例外!

我们首先创建一个provider

  1. php artisan make:provider TestProvider

然后在boot方法里写下:

  1. public function boot()
  2. {
  3. Validator::extend('user', function($attribute, $value, $parameters) {
  4. return !is_null(User::find($value));
  5. });
  6. }

这行代码很好理解吧:1、调用“Validator”的“extend”方法。2、传给他俩个参数,一个是“user”,一个是返回值为boolen类型的callback 函数。3、函数中判断User表中是否含有$value值数据,如果有,返回true,如果没有,返回false。

然后在“config”的“app.php”中注册上这个provider。(如果不清楚,可以去看前一篇文章“三分钟学会laravel服务扩展”)

然后在validation.php中写上:

  1. 'user' => '此用户不存在!',

然后在校验方法中添上“user”

  1. $validate = Validator::make($request->all(), [
  2. 'id' => 'required|integer|between:1,10|user',
  3. 'title' => 'required|string'
  4. ]);

数据库中插入数据,开始检验:

laravel接口响应时间(laravel请求参数校验方法)

OK,大功告成!是不是很简单?laravel框架是不是很强大?

以上这篇laravel请求参数校验方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

原文链接:https://blog.csdn.net/i6448038/article/details/51246045

您可能感兴趣