久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

通過修改Laravel Auth使用salt和password進行認證用戶詳解

這篇文章主要給大家介紹了關(guān)于通過修改Laravel Auth使用salt和password進行認證用戶的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要

前言

本文主要給大家介紹了通過修改Laravel Auth用salt和password進行認證用戶的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面話不多說了,來一起看看詳細的介紹:

Laraval自帶的用戶認證系統(tǒng)Auth非常強大易用,不過在Laravel的用戶認證系統(tǒng)中用戶注冊、登錄、找回密碼這些模塊中用到密碼加密和認證算法時使用的都是bcrypt,而很多之前做的項目用戶表里都是采用存儲salt + password加密字符串的方式來記錄用戶的密碼的,這就給使用Laravel框架來重構(gòu)之前的項目帶來了很大的阻力,不過最近自己通過在網(wǎng)上找資料、看社區(qū)論壇、看源碼等方式完成了對Laravel Auth的修改,在這里分享出來希望能對其他人有所幫助。 開篇之前需要再說明下如果是新項目應(yīng)用Laravel框架,那么不需要對Auth進行任何修改,默認的bcrypt加密算法是比salt + password更安全更高效的加密算法。

修改用戶注冊

首先,在laravel 里啟用驗證是用的artisan命令

php artisan make:auth

執(zhí)行完命令后在routes文件(位置:app/Http/routes.php)會多一條靜態(tài)方法調(diào)用

Route::auth();

這個Route是Laravel的一個Facade (位于Illuminate\Support\Facades\Route), 調(diào)用的auth方法定義在Illuminate\Routing\Router類里, 如下可以看到auth方法里就是定義了一些Auth相關(guān)的路由規(guī)則

/**
 * Register the typical authentication routes for an application.
 *
 * @return void
 */
public function auth()
{
 // Authentication Routes...
 $this->get('login', 'Auth\AuthController@showLoginForm');
 $this->post('login', 'Auth\AuthController@login');
 $this->get('logout', 'Auth\AuthController@logout');

 // Registration Routes...
 $this->get('register', 'Auth\AuthController@showRegistrationForm');
 $this->post('register', 'Auth\AuthController@register');

 // Password Reset Routes...
 $this->get('password/reset/{token?}', 'Auth\PasswordController@showResetForm');
 $this->post('password/email', 'Auth\PasswordController@sendResetLinkEmail');
 $this->post('password/reset', 'Auth\PasswordController@reset');
}

通過路由規(guī)則可以看到注冊時請求的控制器方法是AuthController的register方法, 該方法定義在\Illuminate\Foundation\Auth\RegistersUsers這個traits里,AuthController在類定義里引入了這個traits.

/**
 * Handle a registration request for the application.
 *
 * @param \Illuminate\Http\Request $request
 * @return \Illuminate\Http\Response
 */
public function register(Request $request)
{
 $validator = $this->validator($request->all());

 if ($validator->fails()) {
 $this->throwValidationException(
  $request, $validator
 );
 }

 Auth::guard($this->getGuard())->login($this->create($request->all()));

 return redirect($this->redirectPath());
}

在register方法里首先會對request里的用戶輸入數(shù)據(jù)進行驗證,你只需要在AuthController的validator方法里定義自己的每個輸入字段的驗證規(guī)則就可以

protected function validator(array $data)
{
 return Validator::make($data, [
 'name' => 'required|max:255',
 'email' => 'required|email|max:255|unique:user',
 'password' => 'required|size:40|confirmed',
 ]);
}

接著往下看驗證通過后,Laravel會掉用AuthController的create方法來生成新用戶,然后拿著新用戶的數(shù)據(jù)去登錄Auth::guard($this->getGuard())->login($this->create($request->all()));

所以我們要自定義用戶注冊時生成用戶密碼的加密方式只需要修改AuthController的create方法即可。

比如:

/**
 * Create a new user instance after a valid registration.
 *
 * @param array $data
 * @return User
 */
protected function create(array $data)
{
 $salt = Str::random(6);
 return User::create([
 'nickname' => $data['name'],
 'email' => $data['email'],
 'password' => sha1($salt . $data['password']),
 'register_time' => time(),
 'register_ip' => ip2long(request()->ip()),
 'salt' => $salt
 ]);
}

修改用戶登錄

修改登錄前我們需要先通過路由規(guī)則看一下登錄請求的具體控制器和方法,在上文提到的auth方法定義里可以看到

 $this->get('login', 'Auth\AuthController@showLoginForm');
 $this->post('login', 'Auth\AuthController@login');
 $this->get('logout', 'Auth\AuthController@logout');
【網(wǎng)站聲明】本站除付費源碼經(jīng)過測試外,其他素材未做測試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請勿用于商業(yè)用途。如損害你的權(quán)益請聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

下面小編就為大家分享一篇laravel ORM 只開啟created_at的幾種方法總結(jié),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
這篇文章主要給大家介紹了如何通過源碼解析Laravel的依賴注入的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著
這篇文章主要給大家介紹了關(guān)于Laravel中unique和exists驗證規(guī)則的優(yōu)化的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面
最近在使用laravel5.5,利用其實現(xiàn)了一個功能,下面分享給大家,這篇文章主要給大家介紹了關(guān)于Laravel 5.5基于內(nèi)置的Auth模塊如何實現(xiàn)前后臺登陸的相關(guān)資料,文中通過示例代碼介紹的非
laravel 的隊列服務(wù)對各種不同的后臺隊列服務(wù)提供了統(tǒng)一的 API,下面這篇文章通過源碼分析給大家介紹了關(guān)于 Laravel 重復(fù)執(zhí)行同一個隊列任務(wù)的原因,文中通過示例代碼介紹的非常詳細
這篇文章主要給大家介紹了關(guān)于 Laravel Redis 多個進程同時取隊列問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考學(xué)習(xí)價值,需要的朋友下面來
主站蜘蛛池模板: 日韩视频 中文字幕 | 亚洲自拍一区在线观看 | 欧美一级久久 | 午夜av一区二区 | 精品在线一区 | 天堂一区二区三区 | 国产成人99久久亚洲综合精品 | 五月激情综合网 | 九九热国产视频 | 日韩在线观看中文字幕 | av一区在线观看 | 精品免费av | 欧美不卡一区二区三区 | 黑人性hd| 麻豆精品国产91久久久久久 | 亚洲精品自在在线观看 | 国产一区二区三区久久久久久久久 | 日韩欧美三级 | heyzo在线| 亚洲综合二区 | 成年人精品视频在线观看 | 美女久久视频 | 久久91av| 国产99久久 | 欧美日韩国产中文字幕 | 亚洲国产精品久久久 | 久草福利| a级大毛片| 日韩精品一区二区三区视频播放 | 伊人精品在线 | 国产黄色大片在线免费观看 | 午夜寂寞影院在线观看 | 久久免费精品 | 国产乱码精品一区二区三区中文 | 国产精品久久久久久婷婷天堂 | 国产一区二区影院 | 天天看天天干 | 自拍偷拍第一页 | 伊人狠狠干 | 国产成人精品一区二 | 一区二区三区视频在线免费观看 |