本篇文章給大家分享的是有關(guān)Laravel中怎么實現(xiàn)表單驗證分層設(shè)計,小編覺得挺實用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
白沙黎族ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!
composer require w7/engine-validate
首先此驗證器也是基于illuminate/validation
的,關(guān)于它的詳細(xì)說明可以直接查看它的文檔,這里就不過多說明了。
首先我們建立一個和控制器相對應(yīng)的驗證層
app ├── Http │ ├── Controllers │ │ └── UserController.php │ └── Validate │ └── UserValidate.php
驗證器代碼:
class UserValidate extends Validate{ protected $rule = [ 'user' => 'required|email', 'pass' => 'required|alpha_num' ]; protected $message = [ 'user.required' => '賬號不可為空', 'pass.required' => '密碼不可為空', ]; protected $customAttributes = [ 'user' => '賬號', 'pass' => '密碼', ];}
控制器代碼:
class UserController extends BaseController{ use AuthorizesRequests, DispatchesJobs, ValidatesRequests; public function login(Request $request) { $data = UserValidate::make()->check($request->all()); }}
這個時候,如果值不符合要求,會拋出一個ValidateException
異常,我們可以選擇手動捕獲,也可以選擇在異常捕獲類里面做一個全局的處理:
public function render($request, Throwable $e) { if ($e instanceof ValidateException) { return response()->json([ 'code' => -1, 'message' => $e->getMessage() ]); } return parent::render($request, $e); }
這樣我們就不需要再控制器里面管理任何的驗證異常了。
此時,控制器中的$data
一定是符合我們需求的數(shù)據(jù),然后可以緊接著做對應(yīng)的業(yè)務(wù)處理
這個時候,如果我們的UserController
控制器中又添加了一個register
方法,在以上兩個字段的需求同時增加了name
,應(yīng)該如何處理呢?
我們可以使用類的$scene
屬性來指定某一場景下需要驗證的字段
驗證器代碼修改如下:
class UserValidate extends Validate{ protected $rule = [ 'user' => 'required|email', 'pass' => 'required|alpha_num', 'name' => 'required|alpha' ]; protected $message = [ 'user.required' => '賬號不可為空', 'pass.required' => '密碼不可為空', ]; protected $customAttributes = [ 'user' => '賬號', 'pass' => '密碼', 'name' => '用戶名稱', ]; protected $scene = [ 'login' => ['user', 'pass'], 'register' => ['user', 'pass', 'name'] ];}
此時:login
場景對應(yīng)的驗證user
和pass
字段,而register
場景對應(yīng)的驗證user
,pass
,name
字段
控制器代碼修改如下:
class UserController extends BaseController{ use AuthorizesRequests, DispatchesJobs, ValidatesRequests; public function login(Request $request) { $data = UserValidate::make()->scene('login')->check($request->all()); } public function register(Request $request) { $data = UserValidate::make()->scene('register')->check($request->all()); }}
使用驗證器的scene
方法來指定當(dāng)前需要驗證的場景名稱
默認(rèn)我們一個控制器對應(yīng)一個驗證器,一個方法對應(yīng)一個場景名稱,基于此特點,我們可以編寫一些更為簡易的方法來解決驗證,我們可以編寫一個中間件來解決此問題,點擊查看文檔說明,中間件完整命名空間為:Itwmw\Validate\Middleware\Laravel\ValidateMiddleware
首先我們需要為他指定控制器和驗證器的對應(yīng)關(guān)系,在app/Providers
目錄下新建一個ValidateServiceProvider.php
文件,寫入如下代碼:
<?php namespace App\Providers; use Illuminate\Support\ServiceProvider; use Itwmw\Validate\Middleware\ValidateMiddlewareConfig; class ValidateServiceProvider extends ServiceProvider{ public function register() { ValidateMiddlewareConfig::instance() ->setAutoValidatePath('App\\Http\\Controllers\\', 'App\\Http\\Validate\\'); }}
其中setAutoValidatePath
為指定控制器和驗證器的對應(yīng)關(guān)系,可以設(shè)定多個,不限制數(shù)量,然后我們將ValidateServiceProvider
注冊一下,在config/app.php
文件中找到providers
,在其中添加App\Providers\ValidateServiceProvider::class
注意:不可以放在
Illuminate\Validation\ValidationServiceProvider::class
之前
這個時候,我們可以將中間件注冊為全局中間件,也可以不注冊,注冊方法:中間件《Laravel 7 中文文檔》
定義路由:
Route::middleware(ValidateMiddleware::class)->group(function () { Route::any('/login', [\App\Http\Controllers\UserController::class, 'login']); Route::any('/register', [\App\Http\Controllers\UserController::class, 'register']);});
控制器代碼修改如下:
class UserController extends BaseController{ use AuthorizesRequests, DispatchesJobs, ValidatesRequests; public function login(Request $request) { $data = get_validate_data($request); } public function register(Request $request) { $data = get_validate_data($request); }}
以上就是Laravel中怎么實現(xiàn)表單驗證分層設(shè)計,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
網(wǎng)站標(biāo)題:Laravel中怎么實現(xiàn)表單驗證分層設(shè)計
鏈接分享:http://muchs.cn/article6/ipgcig.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計公司、網(wǎng)站改版、網(wǎng)站收錄、軟件開發(fā)、虛擬主機(jī)、電子商務(wù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)