Laravel 多域名下的字段驗證

前言

正在開發一個統一做者後臺,用來讓做者給網站提交軟件。咱們已經對其中一個網站開發了做者後臺,如今咱們打算將這一個後臺提供給其餘網站。它具有以下的一些特色:php

功能拆分

開始以前咱們須要對系統各個功能點進行拆分,估算受影響的點:laravel

  • 登陸註冊
    登陸註冊功能首當其衝,咱們須要用戶在註冊時經過訪問的域名不一樣,記錄的身份也不一樣。因此咱們須要進行以下的處理:數據庫

    • 增長字段identity
    • 進行判重
    • 進行登陸驗證
  • 數據處理
    這個就不進行討論了。根據用戶所屬身份不一樣,調用的數據也不一樣就好了。

註冊判重

判重依據:
咱們知道使用php artisan make:auth 後,默認使用email登陸,在表單驗證中默認對email進行判重。代碼以下:segmentfault

  • 默認表單驗證:app

    // 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'],
        ]);
    }
  • 默認登陸驗證字段dom

    // 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表單驗證來實現一下:ide

  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. 模擬用戶註冊,插入身份信息ui

    // 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');
}
相關文章
相關標籤/搜索