Laravel學(xué)習(xí)教程之request validation的編寫
前言
本文主要給大家介紹了關(guān)于Laravel之request validation編寫的相關(guān)內(nèi)容,在用laravel寫api時(shí),當(dāng)前端傳進(jìn)來的request是POST/PUT/PATH等method時(shí),那需要做request validation,盡管對于前后端分離程序,前端程序Angular/Vue已經(jīng)做了validation,但是ajax傳過來的json input,在后端也需要做validation。
那該如何優(yōu)雅的編寫request validation呢?laravel官方文檔已經(jīng)包含了這個(gè)feature: Form Request Validation
實(shí)現(xiàn)方法如下
這里可以寫一個(gè)JsonRequest:
class JsonRequest extends Illuminate\Foundation\Http\FormRequest { public function rules() { $method = $this->method(); assert(in_array($method, [static::METHOD_POST, static::METHOD_PUT, static::METHOD_PATCH], true)); $controller = $this->route()->getController(); $rules = $controller::RULES; return ($rules[$this->method()] ?? []) + ($rules['*'] ?? []); } public function authorize() { return true; } }
這樣就可以在眾多Model Controller里使用JsonRequest就行,如:
use Illuminate\Http\Request; final class AccountController extends \App\Http\Controllers\Controller { public const RULES = [ Request::METHOD_POST => [ 'bank_account' => 'required_if:type,bank', 'loan_account' => 'required_if:type,loan', ], Request::METHOD_PUT => [ // ... ], '*' => [ // ... ], ]; }
這樣就可以校驗(yàn)前端傳進(jìn)來的json input是否合法。
(1)如果前端傳進(jìn)來的json input是:
{ "name": "lx1036", "type": "loan", "bank_account": { "source": "bank", } }
那就validation失敗,不合法。
(2) 如果前端傳進(jìn)來的json input是:
{ "name": "lx1036", "type": "bank", "loan_account": { "source": "loan", } }
那就validation失敗,不合法。
這樣就可以校驗(yàn)json input,不合法就直接彈回throw 一個(gè)HttpException,不再用在進(jìn)入下一步邏輯。對于這樣嵌套的json input,使用request validation來校驗(yàn)對象間關(guān)系很重要,可以看做是進(jìn)入核心業(yè)務(wù)邏輯前的初步校驗(yàn)。。當(dāng)然最后寫表時(shí)還有model validation,避免壞數(shù)據(jù)進(jìn)入db。
最后一點(diǎn),laravel文檔只是說了用法,沒有說明原理。代碼在\Illuminate\Foundation\Providers\FormRequestServiceProvider::class:
public function boot() { // \Illuminate\Foundation\Http\FormRequest use 了 ValidatesWhenResolvedTrait,extends 了 \Illuminate\Contracts\Validation\ValidatesWhenResolved $this->app->afterResolving(ValidatesWhenResolved::class, function ($resolved) { $resolved->validate(); }); // ... }
所以當(dāng)從容器中resolve完\Illuminate\Foundation\Http\FormRequest后就會(huì)立即執(zhí)行\(zhòng)Illuminate\Foundation\Http\FormRequest::validate()方法,具體不詳述,可看laravel源碼。
OK,總之,在寫程序時(shí),validation很重要,需要去寫,包括request validation和model validation。。。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
- 跟我學(xué)Laravel之請求(Request)的生命周期
- 三個(gè)思路解決laravel上傳文件報(bào)錯(cuò):413 Request Entity Too Large問題
- 跟我學(xué)Laravel之視圖 & Response
- 關(guān)于擴(kuò)展 Laravel 默認(rèn) Session 中間件導(dǎo)致的 Session 寫入失效問題分析
- Laravel中的Sessionid處理機(jī)制詳解
- Laravel5.2使用Captcha生成驗(yàn)證碼實(shí)現(xiàn)登錄(session巨坑)
- laravel獲取不到session的三種解決辦法【推薦】
- Laravel如何使用Redis共享Session
- Laravel 5.4.36中session沒有保存成功問題的解決
- Laravel框架Request、Response及Session操作示例
相關(guān)文章
PHP框架Laravel學(xué)習(xí)心得體會(huì)
Laravel是一套簡潔、優(yōu)雅的PHP Web開發(fā)框架 (PHP Web Framework) 。在世界(不含中國)PHP框架的占有率超過40%。下面通過本文給大家分享我的PHP框架Laravel學(xué)習(xí)心得體會(huì),歡迎大家給我留言2015-10-10php如何修改SESSION的生存存儲時(shí)間的實(shí)例代碼
本篇文章主要介紹了php如何修改SESSION的生存時(shí)間的實(shí)例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07Laravel 實(shí)現(xiàn)Controller向blade前臺模板賦值的四種方式小結(jié)
今天小編就為大家分享一篇Laravel 實(shí)現(xiàn)Controller向blade前臺模板賦值的四種方式小結(jié),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10PHP獲取當(dāng)前日期和時(shí)間及格式化方法參數(shù)
這篇文章主要介紹了PHP獲取當(dāng)前日期和時(shí)間及格式化方法參數(shù),本文先是講解了獲取當(dāng)前日期時(shí)間的方法,其后總結(jié)了格式化參數(shù),需要的朋友可以參考下2015-05-05laravel ORM 只開啟created_at的幾種方法總結(jié)
下面小編就為大家分享一篇laravel ORM 只開啟created_at的幾種方法總結(jié),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01ThinkPHP水印功能實(shí)現(xiàn)修復(fù)PNG透明水印并增加JPEG圖片質(zhì)量可調(diào)整
這篇文章主要介紹了ThinkPHP水印功能實(shí)現(xiàn)修復(fù)PNG透明水印并增加JPEG圖片質(zhì)量可調(diào)整,包含了對多層水印設(shè)置代碼的修改,修改的部分在注釋里有較為詳細(xì)的說明,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-11-11