Laravel - Auth ::尝试不起作用,返回false

时间:2016-11-17 11:51:24

标签: php laravel authentication laravel-5.3

我尝试在laravel中登录,但我使用mssql和我的用户表名为us。

在config / auth.php中,我更改了提供程序以更改表名:

'providers' => [
    //'users' => [
    //    'driver' => 'eloquent',
    //    'model' => App\User::class,
    //],

    'users' => [
      'driver' => 'database',
      'table' => 'us',
    ]
],

我还创建了一个名为authenticated的中间件:

public function handle($request, Closure $next)
{
  if(Auth::check())
  {
    return $next($request);
  }
  else {
    return redirect('/login');
  }

}

现在我创建一个后期路线/登录,现在我在没有控制器的情况下完成所有路线:

 Route::post('/login', function()
{
  echo "login...";
  $username = Input::get('username')."</br>";
  $password = Input::get('password')."</br>";
  $remember = Input::get('remember')."</br>";


  $userdata = array(
    'username'  => Input::get('username'),
    'codeApp'  => Input::get('password')
  );
  $rules = array(
        'username' => 'required|exists:us,username',
        'codeApp' => 'required|exists:us,codeApp'
  );

  $validator = Validator::make($userdata, $rules);

  if ($validator->passes())
  {
    $auth = DB::table('us')->where('username', '=', Input::get('username'))
      ->where('codeApp', '=', Input::get('password'))->get()->first();
    // Try to log the user in.
    if ($auth)
    {
        // Redirect to homepage
        //Auth::login($auth);
        dd(Auth::attempt(['username' => $username, 'codeApp' => $password], $remember));
        if(Auth::attempt(['username' => $username, 'codeApp' => $password], $remember))
        {
          echo "ok";
          return Redirect::to('app/groups');
        }

    }
  }
  else
  {
    echo "error";
    return Redirect::to('login')->withErrors($validator);
  }
});

当我在表单中输入正确的数据时,$ auth会获得正确的用户,但在dd(Auth::attempt(['username' => $username, 'codeApp' => $password], $remember));中返回false并且我不知道原因。

我该如何解决?

由于

1 个答案:

答案 0 :(得分:1)

问题在于Route::post('/login', function() {} 为变量分配错误的值

$username = Input::get('username')."</br>";
$password = Input::get('password')."</br>";
$remember = Input::get('remember')."</br>";

因为您进行了."</br>"的额外连接,所以在结果中您尝试使用损坏的凭据进行身份验证。 要解决,只需删除该连接。

还有一件事 - 你不需要对数据库进行额外的查询,然后像你一样检查结果:

$auth = DB::table('us')->where('username', '=', Input::get('username'))
      ->where('codeApp', '=', Input::get('password'))->get()->first();
    // Try to log the user in.
    if ($auth)
    {}

只是因为您已经使用验证规则检查了提供者用户和appCode

$rules = array(
        'username' => 'required|exists:us,username',
        'codeApp' => 'required|exists:us,codeApp'
  );

因此,在验证后,只需创建Auth::attempt(...)即可完成。

使代码更好地用相应的变量替换所有的Input :: get('...')调用。

还有一条建议 - 不要echo调试应用程序流 - 使用\Log::debug('Whatever you want to debug')写入Laravel的日志文件,您可以使用tail -f ./storage/logs/laravel.log控制台命令跟踪