摘要:在或自定義一個中寫上是表示所有的,即任何一個的寫操作都會觸發該事件。這里業務不同,不同,不做過多解釋。這個的目的主要是從邏輯上校驗輸入數據的合法性。,總之一般情況下,在寫數據庫前都需要做,避免無效。
在對database進行寫操作前,需要對數據進行validation,如type-check 每一個 model column 的定義("type" 這個column必須是enum("card","loan")),這里使用model event來做。
在EventServiceProvider(或自定義一個ValidationServiceProvider)中寫上:
public function boot() { /** * Inspired by @see IlluminateFoundationProvidersFormRequestServiceProvider::boot() * * Note: saving event is always triggered before creating and updating events */ $this->app["events"]->listen("eloquent.saving: *", function (string $event_name, array $data): void { /** @var AppExtensionsIlluminateDatabaseEloquentModel $object */ $object = $data[0]; $object->validate(); }); }
"eloquent.saving: *"是表示listen所有model的saving,即任何一個model的寫操作都會觸發該事件。
然后寫一個abstract model extends EloquentModel:
// AppExtensionsIlluminateDatabaseEloquentModel use IlluminateDatabaseEloquentModel as EloquentModel; use IlluminateValidationValidationException; abstract class Model extends EloquentModel { public function validate():void { // 1. validate type rules (type-check) $validator = $this->getTypeValidator(); if ($validator->fails()) { throw new ValidationException($validator); } // $validator = $this->getConstraintValidator(); // 2. validate constraint rules (sanity-check) } protected function getTypeValidator() { return $this->getValidationFactory()->make($this->attributes, static::COLUMN_TYPE_RULES); } protected function getValidationFactory() { return app(Factory::class); } protected function getConstraintValidator() { // return $this->getValidationFactory()->make($attributes, static::COLUMN_CONSTRAINT_RULES); } }
這樣,在每一個繼承abstract model的子類中,定義const COLUMN_TYPE_RULES就行,如:
class Account extends Model { public const COLUMN_TYPE_RULES = [ "id" => "integer|between:0,4294967295", "source" => "nullable|in:schwab,orion,yodlee", "type" => "required|in:bank,card,loan", ]; }
在寫操作時,提前對每一個 model 的 schema definition進行type-check,避免無效碰撞 database。這個feature的目的是從model schema去校驗輸入數據的字段定義是否合法。
另外一般除了type-check schema definition 外,還得根據業務需要進行邏輯校驗sanity-check constraint rules,如當創建一個account時,輸入inputs里的字段person_id不能是child未成年人,等等。這里業務不同,constraint rules不同,不做過多解釋。這個feature的目的主要是從邏輯上校驗輸入數據的合法性。
OK,總之一般情況下,在寫數據庫前都需要做 model validation,避免無效hit db。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/30694.html
摘要:對于這樣嵌套的,使用來校驗對象間關系很重要,可以看做是進入核心業務邏輯前的初步校驗。。當然最后寫表時還有,避免壞數據進入。,總之,在寫程序時,很重要,需要去寫,包括和。。。 在用laravel寫api時,當前端傳進來的request是POST/PUT/PATH等method時,那需要做request validation,盡管對于前后端分離程序,前端程序Angular/Vue已經做了v...
摘要:說明本文主要學習下的模型觀察者,把一點點經驗分享出來希望對別人能有幫助。模型觀察者這個功能能做很多事情,比如模型更新時發個通知。總結本篇文章主要學了下的模型觀察者,發現這個功能也能使代碼結構更清晰,覺得挺好的。 說明:本文主要學習下Laravel的Model Observer模型觀察者,把一點點經驗分享出來希望對別人能有幫助。同時,作者會將開發過程中的一些截圖和代碼黏上去,提高閱讀效率...
摘要:可以使用來做,也是作者開發的,可靠性也有保證。不管怎樣,總會遇到很多不僅僅一個需要的,這個具有公用性的就可以做成一個放在公司內部搭建的鏡像上,這也極大提高整體的開發效率。 隨著業務越來越復雜,有些service具有通用性,即Repo A中的某一service其他的幾個Repo都會不同程度的需要,如果能把該service作為一個獨立的package,這樣其他的Repo可以composer...
摘要:而且,與是一對多關系一個分類下有很多,一個只能歸屬于一個與是一對多關系一篇博客下有很多,一條只能歸屬于一篇與是多對多關系一篇有很多,一個下有很多。 說明:本文主要聊一聊Laravel測試數據填充器Seeder的小技巧,同時介紹下Laravel開發插件三件套,這三個插件挺好用哦。同時,作者會將開發過程中的一些截圖和代碼黏上去,提高閱讀效率。 備注:在設計個人博客軟件時,總會碰到有分類Ca...
摘要:抱歉,最近忙,本篇等有時間更新。引言本文基于框架做的一個生成和存儲,主要目的是學習使用框架。書籍基于的,學習時使用框架開發。開發環境備注一直想把這本書的個作為系列分享出來,供初學者學習玩玩。 抱歉,最近忙,本篇等有時間更新。 引言 本文基于Laravel框架做的一個URL生成和存儲demo,主要目的是學習使用Laravel框架。內容基于英文書籍《Packt.Laravel.Applic...
閱讀 2007·2021-11-15 18:09
閱讀 899·2021-09-06 15:13
閱讀 2643·2021-08-23 09:43
閱讀 2024·2019-08-30 15:54
閱讀 2218·2019-08-30 13:56
閱讀 2484·2019-08-26 11:31
閱讀 3078·2019-08-26 10:56
閱讀 700·2019-08-26 10:28