使用Laravel怎么實(shí)現(xiàn)多域名字段驗(yàn)證?相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。
在沂源等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè) 網(wǎng)站設(shè)計(jì)制作按需定制網(wǎng)站,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),成都品牌網(wǎng)站建設(shè),營(yíng)銷型網(wǎng)站,外貿(mào)營(yíng)銷網(wǎng)站建設(shè),沂源網(wǎng)站建設(shè)費(fèi)用合理。功能拆分
開始之前我們需要對(duì)系統(tǒng)各個(gè)功能點(diǎn)進(jìn)行拆分,估算受影響的點(diǎn):
登錄注冊(cè)
登錄注冊(cè)功能首當(dāng)其沖,我們需要用戶在注冊(cè)時(shí)通過訪問的域名不同,記錄的身份也不同。所以我們需要進(jìn)行如下的處理:
增加字段identity
進(jìn)行判重
進(jìn)行登錄驗(yàn)證
數(shù)據(jù)處理
這個(gè)就不進(jìn)行討論了。根據(jù)用戶所屬身份不同,調(diào)用的數(shù)據(jù)也不同就行了。
注冊(cè)判重
判重依據(jù):
我們知道使用php artisan make:auth
后,默認(rèn)使用email登錄,在表單驗(yàn)證中默認(rèn)對(duì)email進(jìn)行判重。代碼如下:
默認(rèn)表單驗(yàn)證:
// 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'], ]); }
默認(rèn)登錄驗(yàn)證字段
// Path:vendor/laravel/framework/src/Illuminate/Foundation/Auth/AuthenticatesUsers.php public function username() { return 'email'; } // 當(dāng)然可以修改驗(yàn)證字段(看過文檔的都知道),注意:登錄驗(yàn)證字段必須是在表里面的。
現(xiàn)在我們需要分析我們的需求:
在單一用戶后臺(tái)中,email判重已經(jīng)足夠了,但是對(duì)于多種用戶一起使用就不太夠了。
假設(shè):我們有A,B兩個(gè)域名,對(duì)應(yīng)a,b兩種用戶,我們需要在一張表中存儲(chǔ)a,b,首先我們判斷a,b是屬于那個(gè)域名的(站點(diǎn)),其次,看這個(gè)用戶是否重復(fù)。
下面我們用Laravel表單驗(yàn)證來實(shí)現(xiàn)一下:
1、增加字段:
為方便演示,我直接在 make auth 生成的遷移文件上直接修改,大家不要在實(shí)際項(xiàng)目中直接修改,而是通過新建遷移文件,使用修改表結(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(); }); }
注意:在這個(gè)需求中,我們對(duì)遷移文件中的email和name字段不需要進(jìn)行unique限定,因?yàn)樗麄兊男允怯幸蕾嚨?,不是?dú)立的。
2、模擬用戶注冊(cè),插入身份信息
// 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', // 模擬用戶注冊(cè)時(shí),插入身份字段值 ]); }
3、進(jìn)行判重處理
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'); })], // 這句話的意思:按照什么條件對(duì) users 表中的 email 去重,我們需要按照身份字段等于我們?cè)L問的域名對(duì) email 去重, 'password' => ['required', 'string', 'min:8', 'confirmed'], ]); }
4、測(cè)試
進(jìn)行第一次注冊(cè),數(shù)據(jù)庫(kù)截如下:
進(jìn)行第二次注冊(cè),相同郵件,不同身份:
相同身份,相同郵箱測(cè)試
登錄驗(yàn)證
覆寫credentials,傳入身份驗(yàn)證字段
// 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 是一套簡(jiǎn)潔、優(yōu)雅的PHP Web開發(fā)框架。它可以讓你從面條一樣雜亂的代碼中解脫出來;它可以幫你構(gòu)建一個(gè)完美的網(wǎng)絡(luò)APP,而且每行代碼都可以簡(jiǎn)潔、富于表達(dá)力。
看完上述內(nèi)容,你們掌握使用Laravel怎么實(shí)現(xiàn)多域名字段驗(yàn)證的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!