您好,登錄后才能下訂單哦!
使用Laravel怎么實現多域名字段驗證?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
功能拆分
開始之前我們需要對系統各個功能點進行拆分,估算受影響的點:
登錄注冊
登錄注冊功能首當其沖,我們需要用戶在注冊時通過訪問的域名不同,記錄的身份也不同。所以我們需要進行如下的處理:
增加字段identity
進行判重
進行登錄驗證
數據處理
這個就不進行討論了。根據用戶所屬身份不同,調用的數據也不同就行了。
注冊判重
判重依據:
我們知道使用php artisan make:auth
后,默認使用email登錄,在表單驗證中默認對email進行判重。代碼如下:
默認表單驗證:
// Path:app/Http/Controllers/Auth/RegisterController.php protected function validator(array $data) { return Validator::make($data, [ 'name' => ['required', 'string', 'max:255'], 'email' => ['required', 'string', 'email', 'max:255', 'unique:users'], 'password' => ['required', 'string', 'min:8', 'confirmed'], ]); }
默認登錄驗證字段
// Path:vendor/laravel/framework/src/Illuminate/Foundation/Auth/AuthenticatesUsers.php public function username() { return 'email'; } // 當然可以修改驗證字段(看過文檔的都知道),注意:登錄驗證字段必須是在表里面唯一的。
現在我們需要分析我們的需求:
在單一用戶后臺中,email判重已經足夠了,但是對于多種用戶一起使用就不太夠了。
假設:我們有A,B兩個域名,對應a,b兩種用戶,我們需要在一張表中存儲a,b,首先我們判斷a,b是屬于那個域名的(站點),其次,看這個用戶是否重復。
下面我們用Laravel表單驗證來實現一下:
1、增加字段:
為方便演示,我直接在 make auth 生成的遷移文件上直接修改,大家不要在實際項目中直接修改,而是通過新建遷移文件,使用修改表結構的方式增加字段
public function up() { Schema::create('users', function (Blueprint $table) { $table->bigIncrements('id'); $table->string('name'); $table->string('email'); // 去掉原來的unique $table->string('identity'); // 增加的字段 $table->timestamp('email_verified_at')->nullable(); $table->string('password'); $table->rememberToken(); $table->timestamps(); }); }
注意: 在這個需求中,我們對遷移文件中的email和name字段不需要進行unique限定,因為他們的唯一性是有依賴的,不是獨立的。
2、模擬用戶注冊,插入身份信息
// Path: app/Http/Controllers/Auth/RegisterController.php protected function create(array $data) { return User::create([ 'name' => $data['name'], 'email' => $data['email'], 'password' => Hash::make($data['password']), 'identity' => 'pcsoft', // 模擬用戶注冊時,插入身份字段值 ]); }
3、進行判重處理
protected function validator(array $data) { return Validator::make($data, [ 'name' => ['required', 'string', 'max:255'], 'email' => ['required', 'string', 'email', 'max:255', Rule::unique('users')->where(function ($query) { $query->where('identity', '=', 'onlinedown'); })], // 這句話的意思:按照什么條件對 users 表中的 email 去重,我們需要按照身份字段等于我們訪問的域名對 email 去重, 'password' => ['required', 'string', 'min:8', 'confirmed'], ]); }
4、測試
進行第一次注冊,數據庫截如下:
進行第二次注冊,相同郵件,不同身份:
相同身份,相同郵箱測試
登錄驗證
覆寫credentials,傳入身份驗證字段
// Path:app/Http/Controllers/Auth/LoginController.php protected function credentials(Request $request) { $request->merge(['identity' => Controller::getWebPrefix()]); return $request->only($this->username(), 'password', 'identity'); }
Laravel 是一套簡潔、優雅的PHP Web開發框架。它可以讓你從面條一樣雜亂的代碼中解脫出來;它可以幫你構建一個完美的網絡APP,而且每行代碼都可以簡潔、富于表達力。
看完上述內容,你們掌握使用Laravel怎么實現多域名字段驗證的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。