Laravel框架表单验证格式化输出的方法


Posted in Python onSeptember 25, 2019

最近在公司的项目开发中使用到了 laravel 框架,采用的是前后端开发的模式。接触过前后端开发模式的小伙伴应该都知道,后端返回的数据格式需要尽可能搞得保证一致性,这样前端在处理时也方便处理。我们先通过观看下面的两张接口返回的效果图吧,这样或许会更加的直观一些。

Laravel框架表单验证格式化输出的方法

laravel默认的输出格式(图一)

Laravel框架表单验证格式化输出的方法

修改后的输出格式(图二)

或许通过上面两张图,你还是未看出有什么区别的话。这里我用文字描述一下吧。 这种情况是发生在laravel做表单验证的情况下发生的。前端向我后端接口发送一个POST请求时,发送了一个title和body的字段。我后端需要对两个字段做一些非空验证。按照框架手册来进行的话,输出的格式就是图一的格式。然后后端统一的输出格式是图二中的格式,如果按照图一的格式输出肯定是不行,这样就需要我们做一个特殊处理。

问题排查

首先我们可以通过文档参看到如下信息。下面划线的部分,提到的返回信息是将所有未验证通过的数据都返回给前端,就如图一中的数据格式。

Laravel框架表单验证格式化输出的方法

laravel默认的输出格式(图三)

预期效果

通过图三我们知道了 laravel 默认的是返回一个带 422 的 http 状态码并且将所有的验证错误信息都返回。

然而我们需要的只是如图二的格式,单个的输出错误信息。大致的解决思路就是在输出的时候,我们去默认显示第一个未通过的验证信息,当通过之后,之前第二个未严重通过的就变成了第一个,这样依次循环下去,我们的每个数据就得到了验证。验证的地方我们选择框架异常统一处理的地方,这样每次验证都自动的进行处理。

解决方案

该框架是 laravel5.8 的情况下进行编写,如果版本不同,或许还需要特殊的处理,不过处理的思路可以参考下面的。

1.创建一个表单验证器。执行下面的命令之后,我们在php app/Http/Requests目录下面就可以看到该类文件了。

php artisan make:request ProjectValidate

2.定义验证规则。rules 方法是定义验证规则,而 messages 方法则是定义返回的错误信息,该方法也可以省略掉,这样提示的信息就是英文而不是图一或图二看到的中文了。

namespace App\Http\Requests;
use Illuminate\Foundation\Http\FormRequest;
class ProjectValidate extends FormRequest
{
  /**
   * Determine if the user is authorized to make this request.
   *
   * @return bool
   */
  public function authorize()
  {
    return true;
  }
  /**
   * Get the validation rules that apply to the request.
   *
   * @return array
   */
  public function rules()
  {
    return [
      'title' => 'bail|required',
      'body' => 'required',
    ];
  }
  /**
   * define the validation message
   *
   * @return array
   */
  public function messages()
  {
    return [
      'title.required' => '文章标题必填',
      'body.required' => '文章内容必填',
    ];
  }
}

3.使用验证器。这里我定义了一个控制器,在 addData 方法中,使用依赖注入的方式去实现数据的验证。记住,该方法体在未通过数据验证的情况下是不会去执行的。

namespace App\Http\Controllers\Backend\Project;

use App\Http\Requests\ProjectValidate;
use App\Http\Controllers\Backend\UCenter;

class Index extends UCenter
{
  public function index()
  {
    return success();
  }
  public function addData(ProjectValidate $request)
  {
    $validated = $request->validated();
    return success($validated);
  }
}

4.统一处理数据格式。找到php App\Exceptions\Handler.php文件,找到下面的方法,修改为如下内容。这时候在做表单验证就会显示图二的格式信息了。

public function render($request, Exception $exception)
  {
    if ($exception instanceof ValidationException) {
      // 只读取错误中的第一个错误信息
      $errors = $exception->errors();
      $message = '';
      // 框架返回的是二维数组,因此需要去循环读取第一个数据
      foreach ($errors as $key => $val) {
        $keys  = array_key_first($val);
        $message = $val[$keys];
        break;
      }
      return response()->json(['code' => 1001, 'message' => $message, 'data' => []], 422);
    }
    return parent::render($request, $exception);
  }

总结

1.优势

输出固定的格式,前端在处理数据的时候,不需要做特别的格式上面调整。

2.劣势

这样的方式验证,每验证一次,就会向后端发送一个 http 请求。

以上所述是小编给大家介绍的Laravel框架表单验证格式化输出的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
Python的Django框架使用入门指引
Apr 15 Python
Python之Web框架Django项目搭建全过程
May 02 Python
微信跳一跳小游戏python脚本
Jan 05 Python
高效使用Python字典的清单
Apr 04 Python
pandas ix &iloc &loc的区别
Jan 10 Python
浅析Python与Mongodb数据库之间的操作方法
Jul 01 Python
Python 多个图同时在不同窗口显示的实现方法
Jul 07 Python
搭建python django虚拟环境完整步骤详解
Jul 08 Python
python打印异常信息的两种实现方式
Dec 24 Python
如何在 Django 模板中输出 "{{"
Jan 24 Python
Python安装OpenCV的示例代码
Mar 05 Python
Python 批量下载阴阳师网站壁纸
May 19 Python
pyqt5 QScrollArea设置在自定义侧(任何位置)
Sep 25 #Python
python 用户交互输入input的4种用法详解
Sep 24 #Python
python getpass实现密文实例详解
Sep 24 #Python
使用Python的turtle模块画国旗
Sep 24 #Python
给你一面国旗 教你用python画中国国旗
Sep 24 #Python
Python MongoDB 插入数据时已存在则不执行,不存在则插入的解决方法
Sep 24 #Python
Python获取时间戳代码实例
Sep 24 #Python
You might like
2020年4月放送!《Princess Connect Re:Dive》制作组 & 角色声优公开!
2020/03/06 日漫
浅析PHP水印技术
2007/02/14 PHP
晋城吧对DiscuzX进行的前端优化要点
2010/09/05 PHP
PHP源代码数组统计count分析
2011/08/02 PHP
php中的登陆login实例代码
2016/06/20 PHP
让焦点自动跳转
2006/07/01 Javascript
JavaScript国旗变换效果代码
2008/08/13 Javascript
小型js框架veryide.librar源代码
2009/03/05 Javascript
JS拖动技术 关于setCapture使用
2010/12/09 Javascript
js操作CheckBoxList实现全选/反选(在客服端完成)
2013/02/02 Javascript
JQuery打造省市下拉框联动效果
2014/05/18 Javascript
JS控制输入框内字符串长度
2014/05/21 Javascript
nodejs中的fiber(纤程)库详解
2015/03/24 NodeJs
jQuery中使用each处理json数据
2015/04/23 Javascript
JavaScript获取两个数组交集的方法
2015/06/09 Javascript
微信小程序前端源码逻辑和工作流
2016/09/25 Javascript
JavaScript中关于iframe滚动条的去除和保留
2016/11/17 Javascript
利用Bootstrap实现表格复选框checkbox全选
2016/12/21 Javascript
jQuery插件FusionCharts实现的MSBar3D图效果示例【附demo源码】
2017/03/23 jQuery
JS实现获取汉字首字母拼音、全拼音及混拼音的方法
2017/11/14 Javascript
vue父组件向子组件(props)传递数据的方法
2018/01/02 Javascript
Vue2.0 ES6语法降级ES5的操作
2020/10/30 Javascript
python操作日期和时间的方法
2014/03/11 Python
Python模拟自动存取款机的查询、存取款、修改密码等操作
2018/09/02 Python
Python实现登陆文件验证方法
2018/10/06 Python
12个Python程序员面试必备问题与答案(小结)
2019/06/24 Python
Keras 加载已经训练好的模型进行预测操作
2020/06/17 Python
为什么相对PHP黑python的更少
2020/06/21 Python
Python利用myqr库创建自己的二维码
2020/11/24 Python
利用指针变量实现队列的入队操作
2012/04/07 面试题
设备动力科岗位职责范本
2014/02/23 职场文书
优秀学生干部先进事迹材料
2014/05/26 职场文书
政风行风整改方案
2014/10/25 职场文书
会计工作检讨书
2015/02/19 职场文书
2015年汽车销售工作总结
2015/04/07 职场文书
mysql分组后合并显示一个字段的多条数据方式
2022/01/22 MySQL