前言
正在開發(fā)一個統(tǒng)一作者后臺,用來讓作者給網(wǎng)站提交軟件。我們已經(jīng)對其中一個網(wǎng)站開發(fā)了作者后臺,現(xiàn)在我們打算將這一個后臺提供給其他網(wǎng)站。它具備如下的一些特點:
- 我們訪問的域名是不一致的,解決方案見我的一篇文章,Laravel 路由研究之domain 解決多域名問題
- 其次各個站點對后臺的要求都是一致的,也就是說,一個后臺N各站去用。
功能拆分
開始之前我們需要對系統(tǒng)各個功能點進行拆分,估算受影響的點:
登錄注冊
登錄注冊功能首當(dāng)其沖,我們需要用戶在注冊時通過訪問的域名不同,記錄的身份也不同。所以我們需要進行如下的處理:
數(shù)據(jù)處理
- 這個就不進行討論了。根據(jù)用戶所屬身份不同,調(diào)用的數(shù)據(jù)也不同就行了。
注冊判重
判重依據(jù):
我們知道使用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';
}
// 當(dāng)然可以修改驗證字段(看過文檔的都知道),注意:登錄驗證字段必須是在表里面唯一的。
現(xiàn)在我們需要分析我們的需求:
在單一用戶后臺中,email判重已經(jīng)足夠了,但是對于多種用戶一起使用就不太夠了。
假設(shè):我們有A,B兩個域名,對應(yīng)a,b兩種用戶,我們需要在一張表中存儲a,b,首先我們判斷a,b是屬于那個域名的(站點),其次,看這個用戶是否重復(fù)。
下面我們用Laravel表單驗證來實現(xiàn)一下:
1、增加字段:
為方便演示,我直接在 make auth 生成的遷移文件上直接修改,大家不要在實際項目中直接修改,而是通過新建遷移文件,使用修改表結(jié)構(gòu)的方式增加字段
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、測試
進行第一次注冊,數(shù)據(jù)庫截如下:
進行第二次注冊,相同郵件,不同身份:
相同身份,相同郵箱測試
登錄驗證
覆寫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');
}
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。
您可能感興趣的文章:- laravel5.2表單驗證,并顯示錯誤信息的實例
- laravel 驗證錯誤信息到 blade模板的方法
- Laravel框架表單驗證格式化輸出的方法
- Laravel框架驗證碼類用法實例分析
- Laravel框架自定義驗證過程實例分析
- laravel http 自定義公共驗證和響應(yīng)的方法