我在Laravel 5.4中整理了一个通过Socialite登录Twitter的网站。现在,一旦用户登录,我就会重定向到主页;但是,我希望能够将用户重定向到他激活“使用Twitter登录”链接的任何页面。我尝试使用return redirect()->back()
,但由于最后的请求是Twitter的api,这只会导致无限循环。我相信这一定是非常基本的,但我似乎无法弄明白。这是处理我的身份验证请求的控制器:
<?php
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use App\User;
use Illuminate\Support\Facades\Auth;
use Laravel\Socialite\Facades\Socialite;
class AuthController extends Controller
{
/**
* Where to redirect users after login.
*
* @var string
*/
protected $redirectPath = '/home';
/**
* Redirect user to OAuth Provider.
*
* @param $provider
* @return Response
*/
public function redirectToProvider($provider)
{
return Socialite::driver($provider)->redirect();
}
/**
* Obtain the user information from provider. check if user already
* exists in our db by looking up their provider_id in the db.
* If user exists, log them in. Otherwise, create a new user then log them in.
* After login, redirect them to the authenticated users homepage.
*
* @param $provider
* @return Response
*/
public function handleProviderCallback($provider)
{
try {
$user = Socialite::driver($provider)->user();
} catch (Exception $e) {
return redirect("auth/$provider");
}
$authUser = $this->findOrCreateUser($user, $provider);
Auth::login($authUser, true);
return redirect($this->redirectPath);
}
/**
* If a user has registered before using social auth, return the user
* else, create a new user object.
*
* @param $user Socialite user object
* @param $provider Social auth provider
* @return User
*/
public function findOrCreateUser($user, $provider)
{
$authUser = User::where('provider_id', $user->id)->first();
if ($authUser) {
return $authUser;
}
return User::create([
'name' => $user->name,
'handle' => $user->nickname,
'provider' => $provider,
'provider_id' => $user->id,
'avatar' => $user->avatar_original,
]);
}
}
你想要的是默认的Laravel
身份验证行为。
return $this->authenticated($request, $this->guard()->user())
?: redirect()->intended($this->redirectPath());
如果用户访问/privatepage
并且该页面受auth middleware
保护,则用户将被重定向到登录页面,/privatepage
将以url.intended
的形式保存到会话中。然后,在成功验证后,Laravel
会检查会话是否具有url.intended
密钥,如果是,则会重定向到会话中保存的URL。如果没有,它将重定向到您定义的任何页面,默认为/home
。
如果您想手动处理用户身份验证时发生的情况,那么您可以创建一个名为authenticated()
的函数,该函数将使用手动重定向进行调用。
要么
如果您有guest
访客和logged in
用户的共同页面,您可以将URL
存储到Session
,如下所示:
Session::flash('url',Request::server('HTTP_REFERER'));
并在操作或认证后使用此作为:
return redirect(Session::get('url'));
希望这可以解决您的问题。
return redirect() - > intention('/ home#');