Laravel多域名下字段驗證的方法

這篇文章主要給大家介紹了關於Laravel多域名下字段驗證的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用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');
}

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對神馬文庫的支持。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章