2017-02-26 97 views
0

林建設AUTH過程laravel 5.4,我的計劃是我要檢查一些附加條件「用戶的電子郵件必須激活」登錄前,Laravel 5.4,顯示錯誤消息AUTH登錄時,用戶使用缺省auth不活躍

我試圖重寫方法attempLogin我的LoginController這樣

protected function attemptLogin(Request $request) 
{     
    $qLogin = [ 
     'user_email'  => $this->credentials($request)[$this->username()], 
     'password'   => $this->credentials($request)[$this->password()], 
     'active'   => 1 
    ];   


    return $this->guard()->attempt(
     $qLogin, $request->has('remember') 
    ); 
} 

代碼驗證爲我的願望,但我想顯示告訴用戶一些錯誤的信息,他/她必須主動/如果確認他們的Email想要登錄

對不起我爲laravel新,你的幫助將是美好的

+0

我有同樣的問題。 –

回答

0

你可以添加憑證功能來檢查用戶是否被激活。你可以修改sendFailedLoginResponse函數來定製你的錯誤信息。

路徑:程序\ HTTP \ \控制器的LoginController

記得導入照亮\ HTTP \請求和App \用戶(這是應用程序\型號\用戶,因爲我感動我的用戶模型應用程序\型號);

<?php 

namespace App\Http\Controllers\Auth; 

use App\Http\Controllers\Controller; 
use Illuminate\Foundation\Auth\AuthenticatesUsers; 
use Illuminate\Http\Request; 
use App\Models\User; 


class LoginController extends Controller 
{ 
    /* 
    |-------------------------------------------------------------------------- 
    | Login Controller 
    |-------------------------------------------------------------------------- 
    | 
    | This controller handles authenticating users for the application and 
    | redirecting them to your home screen. The controller uses a trait 
    | to conveniently provide its functionality to your applications. 
    | 
    */ 

    use AuthenticatesUsers; 

    /** 
    * Where to redirect users after login. 
    * 
    * @var string 
    */ 
    protected $redirectTo = '/home'; 

    /** 
    * Create a new controller instance. 
    * 
    * @return void 
    */ 
    public function __construct() 
    { 
     $this->middleware('guest')->except('logout'); 
    } 

    protected function credentials(Request $request) { 
     return array_merge($request->only($this->username(), 'password'), ['active' => 1]); 
    } 

    /** 
    * Get the failed login response instance. 
    * 
    * @param \Illuminate\Http\Request $request 
    * @return \Illuminate\Http\RedirectResponse 
    */ 
    protected function sendFailedLoginResponse(Request $request) 
    { 
     $errors = [$this->username() => trans('auth.failed')]; 

     // Load user from database 
     $user = User::where($this->username(), $request->{$this->username()})->first(); 

     // Check if user was successfully loaded, that the password matches 
     // and active is not 1. If so, override the default error message. 
     if ($user && \Hash::check($request->password, $user->password) && $user->active != 1) { 
      $errors = [$this->username() => trans('auth.noactive')]; 
     } 

     if ($request->expectsJson()) { 
      return response()->json($errors, 422); 
     } 
     return redirect()->back() 
      ->withInput($request->only($this->username(), 'remember')) 
      ->withErrors($errors); 
    } 
} 

順便說一句,我想補充的資源目錄\ lang線\ EN \ auth.php這樣我就可以使用反式(「auth.notactivated」)作爲我的錯誤信息。

<?php 

return [ 
    'failed' => 'These credentials do not match our records.', 
    'throttle' => 'Too many login attempts. Please try again in :seconds seconds.', 
    'notactivated' => 'This account has not been activated yet.', 
];