• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    laravel请求参数校验方法

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

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

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

    Route::get('test', 'TestController@test');
    class TestController extends Controller
    {
     public function test(Request $request)
     {
    
     }
    }
    

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

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

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

    if($validate->fails())
    {
     return $validate->errors()->first();
    }

    或者返回

    if($validate->fails())
    {
     return $validate->errors()->all();
    }

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

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

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

    打开,然后找到这一行:

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

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

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

    然后我们再看返回结果:

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

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

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

    我们首先创建一个provider

    php artisan make:provider TestProvider

    然后在boot方法里写下:

    public function boot()
    {
     Validator::extend('user', function($attribute, $value, $parameters) {
      return !is_null(User::find($value));
     });
    }

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

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

    然后在validation.php中写上:

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

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

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

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

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

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

    您可能感兴趣的文章:
    • Laravel 5.5中为响应请求提供的可响应接口详解
    • 让Laravel API永远返回JSON格式响应的方法示例
    • Laravel+Dingo/Api 自定义响应的实现
    • laravel http 自定义公共验证和响应的方法
    • Laravel5.1 框架Request请求操作常见用法实例分析
    • 跟我学Laravel之请求与输入
    • 跟我学Laravel之请求(Request)的生命周期
    • 解决laravel 出现ajax请求419(unknown status)的问题
    • Laravel获取当前请求的控制器和方法以及中间件的例子
    • Laravel框架处理用户的请求操作详解
    • Laravel5.1 框架响应基本用法实例分析
    上一篇:Laravel获取所有的数据库表及结构的方法
    下一篇:laravel 关联关系遍历数组的例子
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    laravel请求参数校验方法 laravel,请求,参数,校验,方法,