繁体   English   中英

Laravel Socialite : Laravel\\Socialite\\Two\\InvalidStateException

[英]Laravel Socialite : Laravel\Socialite\Two\InvalidStateException

我是 Laravel Socialite 的新手,从社交媒体登录重定向回来时出现此错误

Laravel\\Socialite\\Two\\InvalidStateException in/vendor/laravel/socialite/src/Two/AbstractProvider.php:209**

即使我已经尝试过这个解决方案https://stackoverflow.com/a/31738836/4428431但我仍然面临同样的错误。

这里是 Socialite 控制器的代码

// Redirect to Social provider for login
public function redirectToProvider($provider)
{
    return Socialite::driver($provider)->redirect();
}

// Handling get request from social provider
public function handleProviderCallback($provider, Request $request)
{
    $user = Socialite::driver($provider)->user();
}

实际上,该代码一开始就可以使用,但是在我将非 www 重定向到 www 后它就停止工作了。 这里是 .htaccess 文件

<IfModule mod_rewrite.c>
    <IfModule mod_negotiation.c>
        Options -MultiViews
    </IfModule>

    RewriteEngine On

    # Redirect Trailing Slashes If Not A Folder...
    RewriteCond %{REQUEST_FILENAME} !-d
    RewriteRule ^(.*)/$ /$1 [L,R=301]

    # Handle Front Controller...
    RewriteCond %{HTTP_HOST} !^www\.
    RewriteRule ^(.*)$ http://www.%{HTTP_HOST}/$1 [R=301,L]
    RewriteCond %{REQUEST_FILENAME} !-d
    RewriteCond %{REQUEST_FILENAME} !-f
    #RewriteRule ^ index.php [L]
    RewriteRule .* index.php?/$0 [PT,L] 

    # Handle Authorization Header
    RewriteCond %{HTTP:Authorization} .
    RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
    #RewriteCond %{HTTPS} !on
    #RewriteRule ^.*$ https://%{HTTP_HOST}%{REQUEST_URI} [L,R=301]
</IfModule>

我遇到了同样的问题并通过添加->stateless()

$user = Socialite::driver( $provider )->stateless()->user();

使用会话保护或无状态

1.会话守卫

你可以在 config/auth.php (drivers and providers) 中看到guard

 Route::group(['middleware' => ['web']], function () {
    Route::get('login/{provider}', 'SocialController@redirect');
    Route::get('login/{provider}/callback','SocialController@Callback');
    Route::get('login/{provider}/callback','SocialController@Callback');
});

这里网络是守卫

2.无状态使用(->无状态)

$user = Socialite::driver( $provider )->stateless()->user();

注意:无状态身份验证不适用于 Twitter 驱动程序,它使用 OAuth 1.0 进行身份验证。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM