2017-02-26 99 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.', 
];