這篇文章主要介紹了關於Laravel註冊重構的解析,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下
有時候需要使用laravel搭建一個後台內容管理系統,但是laravel預設的登陸註冊不能滿足目前的需求,所以這就需要Laravel註冊重構了,下面跟著小編一起看看如何進行註冊重構。
1. 首先確定使用者註冊的路由
我們在安裝好laravel的時候預設產生的註冊是用郵箱進行註冊的,並且有些選項不需要,有些還需要加一些表單選項
我們註冊的話,並不是可以隨便註冊的,只有一些超級管理員才能進行註冊
首先我們使用上次建立的UserController進行配置,如果沒有的話,可以使用php artisan make:controller UserController建立一個控制器類
然後建立兩條路由Route::get('register', 'UserController@getRegister')和Route::post('register', 'UserController@postRegister')
前者是顯示一個註冊的頁面get請求,後面是註冊帳號的post請求。
2. 顯示註冊帳號頁面
這個使用的是getRegister這個方法,這個方法只需要顯示一個視圖所以並沒有特別的邏輯
public function getRegister(){ return view('auth.register');}
3. 請求註冊帳號
這個使用的是postRegister這個方法
註冊帳號的話和重設密碼一樣,而且比註冊帳號還要簡單點。
我們在往資料庫裡插入一條使用者紀錄的時候,可以使用User::create($data)進行插入。
$data是個數組,裡面存放了每個欄位的鍵和值
public function postRegister(Request $request){ $rules = [ 'username'=>'required|unique:finance_enewsuser', 'password' => 'required|between:6,20|confirmed' ]; $messages = [ 'required'=>':attribute不可為空', 'unique'=>'使用者名稱已被註冊', 'between' => '密碼必須是6~20位之間', 'confirmed' => '新密碼和確認密碼不匹配' ]; $username = $request->input('username'); $password = $request->input('password'); $group = $request->input('group'); $data = $request->all(); $validator = Validator::make($data, $rules, $messages); if ($validator->fails()) { return back()->withErrors($validator); } $data = [ 'username' => $username, 'password' => bcrypt($password), 'groupid' => $group, 'checked' => 0, 'styleid' => 1, 'filelevel' => 0, 'loginnum' => 0, 'lasttime' => time(), 'lastip' => '127.0.0.1', 'truename' => '', 'email' => '', 'pretime' => time(), 'preip' => '127.0.0.1', ]; User::create($data); //插入一條新紀錄,並返回儲存後的模型執行個體 //如果註冊後還想立即登入的話,可以使用$user = User::create($data); Auth::login($user); 進行認證 return redirect('/');}
4. 完成後的樣本
UserController
public function getRegister(){ return view('auth.register');}public function postRegister(Request $request){ $rules = [ 'username'=>'required|unique:finance_enewsuser', 'password' => 'required|between:6,20|confirmed' ]; $messages = [ 'required'=>':attribute不可為空', 'unique'=>'使用者名稱已被註冊', 'between' => '密碼必須是6~20位之間', 'confirmed' => '新密碼和確認密碼不匹配' ]; $username = $request->input('username'); $password = $request->input('password'); $group = $request->input('group'); $data = $request->all(); $validator = Validator::make($data, $rules, $messages); if ($validator->fails()) { return back()->withErrors($validator); } $data = [ 'username' => $username, 'password' => bcrypt($password), 'groupid' => $group, 'checked' => 0, 'styleid' => 1, 'filelevel' => 0, 'loginnum' => 0, 'lasttime' => time(), 'lastip' => '127.0.0.1', 'truename' => '', 'email' => '', 'pretime' => time(), 'preip' => '127.0.0.1', ]; User::create($data); //插入一條新紀錄,並返回儲存後的模型執行個體 return redirect('/');}
register.blade
<form class="login-form" action="" method="post"> {!! csrf_field() !!} <h3 class="font-green">Sign Up</h3> @if(count($errors) > 0) <p class="alert alert-danger display-hide" style="display: block;"> <button class="close" data-close="alert"></button> <span> </span> </p> @endif <p class="form-group"> <label class="control-label visible-ie8 visible-ie9">使用者名稱</label> <input class="form-control placeholder-no-fix" type="text" autocomplete="off" placeholder="Username" name="username"> </p> <p class="form-group"> <label class="control-label visible-ie8 visible-ie9">密碼</label> <input class="form-control placeholder-no-fix" type="password" autocomplete="off" id="register_password" placeholder="Password" name="password"> </p> <p class="form-group"> <label class="control-label visible-ie8 visible-ie9">重複密碼</label> <input class="form-control placeholder-no-fix" type="password" autocomplete="off" placeholder="Repeat password" name="password_confirmation"> </p> <p class="form-group"> <label class="control-label visible-ie8 visible-ie9">使用者組</label> <select name="group" class="form-control"> <option value="1"> 超級管理員 </option> <option value="2"> 管理員 </option> <option value="3"> 編輯 </option> </select> </p> <p class="form-actions"> <button type="submit" id="register-submit-btn" class="btn btn-success uppercase pull-right">註冊</button> </p></form>
5. 中介軟體–使用者必須登入
現在註冊都完成了,我們就差使用者的判斷了。 需求註冊帳號必須只能是有超級管理員權限的帳號才可以註冊。
這種情況下按照我們一般的步驟就是在postRegister方法裡直接查出使用者的資訊,然後查看使用者是否滿足這個許可權,不滿足的情況下就跳轉到其它頁面。
這種方法可以,但是,我們既然有超級管理員和管理員這些許可權區分,肯定不止一個地方使用,其它地方也會用到。
然後會有人想到在model裡寫個方法,以後有需要都可以直接調用。
這個方法也可以,不過,我們推薦使用laravel提供的中介軟體這個功能,這個功能非常強大,也非常好用。現在我們就使用中介軟體這個功能。
因為我們是後台內容管理系統,所以,我們首先建立一個中介軟體,功能是,所有頁面進入前,必須是登入狀態,否則跳到登入頁。
查看手冊發現可以使用php artisan make:middleware CheckLoginMiddleware命令建立一個中介軟體,當然複製一個差不多的檔案,改下也是一樣的。
然後會在app/Http/Middleware/目錄下建立了一個CheckLoginMiddleware中介軟體檔案,裡面只有一個handle()方法,我們直接在裡面增加我們的功能
<?phpnamespace App\Http\Middleware;use Closure;use Auth;class CheckLoginMiddleware{ public function handle($request, Closure $next) { //使用Auth方法,需要引入use Auth;方法 //$request->is('login')表示請求的URL是否是登入頁 //因為我們打算使用全域的,所以,需要把登入頁排除,不然會無限重新導向 //如果你的登入頁不是/login,而是/auth/login的話,就寫$request->is('auth/login') //並且我們要在請求處理後執行其任務,因為我們需要擷取到使用者的登入資訊 $response = $next($request); if (!Auth::check() && !$request->is('login')) { return redirect('/login'); } return $response; }}
這個中介軟體的功能是,如果有路由產生,首先使用Auth::check()判斷使用者是否登入,如果沒有登入的跳轉到登入頁。
方法寫好了,但是還不能使用,我們需要註冊下這個中介軟體,告訴架構我們這個中介軟體寫好了,可以使用了,使用的範圍是哪裡。
在app/Http/目錄下有個Kernel.php檔案是註冊這個中介軟體的,也就是告訴架構,我們寫好了這個中介軟體。
而Kernel.php檔案裡有兩個數組屬性,一個$middleware表示全域使用,一個$routeMiddleware表示可以選擇使用。
全域使用的意思是,不管你請求哪個頁面,都會先執行這個中介軟體。
選擇使用表示,需要哪個HTTP請求,要求執行中介軟體,就在哪個地方執行。
這裡每個頁面都要求必須登入的話,可定是註冊一個全域的,在$middleware數組屬性裡加入一條
\App\Http\Middleware\CheckLoginMiddleware::class
註冊下,就可以使用了
>注意:請記住,如果定義全域的要格外小心,比如上面我們要排除登入頁,不然因為使用者沒有登入,所以在哪個頁面都會重新導向到登入頁,當然也包括登陸頁
6. 中介軟體–特殊頁面需要驗證使用者組
現在是進行使用者權限頁面的限制,同樣我們也要重新建立一個中介軟體
使用php artisan make:middleware CheckGroupMiddleware建立一個新的中介軟體,用來判斷這個使用者是否滿足這個許可權
<?phpnamespace App\Http\Middleware;use Closure;use Auth;class CheckGroupMiddleware{ public function handle($request, Closure $next) { $user = Auth::user(); if ($user->groupid != 1) { return redirect('/'); } return $next($request); }}
這裡我們還是通過Auth::user()來擷取到使用者的資訊,然後判斷使用者的組,不屬於超級管理員就跳到首頁。
然後我們在到app/Http/目錄下有個Kernel.php檔案是註冊這個中介軟體的,這次我們註冊為可以選擇的中介軟體。
這個中介軟體因為是可以選擇的,所以我們還需要給它起個別名,在$routeMiddleware數組屬性裡加如一條
'user.group' => \App\Http\Middleware\CheckGroupMiddleware::class
建立一個可以使用usergroup這個名字使用的中介軟體。
建立好後,我們可以選擇在哪裡使用,一個是在router.php的路由檔案裡加入,一個是在controller裡使用
在router.php檔案裡使用
Route::get('/', ['middleware' => ['user.group'], function () { //}]);
在控制器內使用
$this->middleware('user.group');
這裡我們選擇在路由裡添加中介軟體。讓註冊頁面只能是超級管理員才可以註冊
Route::get('register', 'UserController@getRegister')->middleware('user.group');Route::post('register', 'UserController@postRegister')->middleware('user.group');
我們目前只有兩個路由要判斷許可權,所以使用了鏈式的寫法,當然你也可以按照手冊裡上使用組的方式,組的方式更為優雅。
當然如果你的整個控制器內的方法都需要中介軟體進行驗證過濾的話,你也可以建立組的形式,也可以直接在控制器內使用__construct方法,讓每次請求這個控制器時,先執行中介軟體
class MyController extends Controller{ public function __construct() { $this->middleware('user.group'); } public function index() { return view('my.index'); }}
以上就是本文的全部內容,希望對大家的學習有所協助,更多相關內容請關注topic.alibabacloud.com!