私のAuthControllerがほとんど条件をチェックしないようにして、それに従って適切なルートにリダイレクトするようにします。私は、ログインしているユーザーのDBに特定の列が空でないかどうかを確認したい。空ではない場合はホームページにリダイレクトしていますが、別のルートにリダイレクトしています。私はpostLoginメソッドを使用しました。ここでの問題は、条件を一切チェックせず、条件が満たされなくても家に直接リダイレクトすることです。私はDBの詳細が満たされていない新しいユーザーでログインしようとした後、ホームページにリダイレクトされ、DBに個人情報が入力されているユーザーにも同じように起こった。postLogin()Laravel 5.2でのログイン後のメソッドのリダイレクト
ここはAuthControllerのコード
<?php
namespace App\Http\Controllers\Auth;
use App\User;
use Validator;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\ThrottlesLogins;
use Illuminate\Foundation\Auth\AuthenticatesAndRegistersUsers;
class AuthController extends Controller
{
/*
|--------------------------------------------------------------------------
| Registration & Login Controller
|--------------------------------------------------------------------------
|
| This controller handles the registration of new users, as well as the
| authentication of existing users. By default, this controller uses
| a simple trait to add these behaviors. Why don't you explore it?
|
*/
use AuthenticatesAndRegistersUsers, ThrottlesLogins;
/**
* Where to redirect users after login/registration.
*
* @var string
*/
//protected $redirectTo = '/user-prof';
public function postLogin(Request $request)
{
$email = $request->email;
$user = \Auth::user();
if(($user->username && $user->phone && $user->bio && $user->dobday && $user->dobmonth && $user->dobyear && $user->firstname
&& $user->lastname && $user->topics && $user->nationality)!= NULL)
{
redirect('home');
}
else
{
redirect('/user-prof');
}
return $this->login($request);
}
/**
* Create a new authentication controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware($this->guestMiddleware(), ['except' => 'logout']);
}
/**
* Get a validator for an incoming registration request.
*
* @param array $data
* @return \Illuminate\Contracts\Validation\Validator
*/
protected function validator(array $data)
{
return Validator::make($data, [
'name' => 'required|max:255',
'email' => 'required|email|max:255|unique:users',
'password' => 'required|min:6|confirmed',
]);
}
/**
* Create a new user instance after a valid registration.
*
* @param array $data
* @return User
*/
protected function create(array $data)
{
return User::create([
'name' => $data['name'],
'email' => $data['email'],
'password' => bcrypt($data['password']),
]);
}
}
また、私はpostLogin()
メソッド内のIF条件に正しい方法でDB列のデータをチェックしていますかどうかを知りたいです。
これらのアトリビュートをチェックし、条件内で呼び出すモデルで関数を作成します。 –
あなたはリダイレクトを 'リターン 'していないので、リダイレクトレスポンスを作成しているだけで何もしません。あなたのpostLoginルートが現在の認証ユーザーを取得しようとしている理由はわかりませんが、現時点ではないはずです。私は 'handleUserWasAuthenticated'によって成功した認証の後に呼び出される' authenticated'をチェックインしなければならないものだと感じています – lagbox