yii2, google outh2 和作用域
yii2, google outh2 and scope
我正在使用 Yii2、GoogleOAuth 和 yii2-user 扩展。我想接收用户 google 圈子并将范围设置为我的配置:
'authClientCollection' => [
'class' => 'yii\authclient\Collection',
'clients' => [
'google' => [
'class' => 'yii\authclient\clients\GoogleOAuth',
'clientId' => '758709912345-p4qp4lqihit5un1u6qb75msqp5m5j6d8.apps.googleusercontent.com',
'clientSecret' => 'ZygOIi1-0asfktUQ1pKOFOo',
'scope' => 'https://www.googleapis.com/auth/plus.login https://www.googleapis.com/auth/userinfo.email https://www.googleapis.com/auth/drive',
],
],
]
当我使用 Google OAuth2 登录时出现错误:
Exception – yii\authclient\InvalidResponseException
Request failed with code: 400, message: {
"error" : "redirect_uri_mismatch"
}
Google 回复:
[
'url' => 'https://accounts.google.com/o/oauth2/token'
'content_type' => 'application/json'
'http_code' => 400
'header_size' => 435
'request_size' => 644
'filetime' => -1
'ssl_verify_result' => 0
'redirect_count' => 0
'total_time' => 0.115431
'namelookup_time' => 0.001186
'connect_time' => 0.025188
'pretransfer_time' => 0.076275
'size_upload' => 456
'size_download' => 39
'speed_download' => 337
'speed_upload' => 3950
'download_content_length' => -1
'upload_content_length' => 456
'starttransfer_time' => 0.114206
'redirect_time' => 0
'certinfo' => []
'primary_ip' => '2a00:1450:4010:c08::54'
'primary_port' => 443
'local_ip' => '2a03:6f00:1::5c35:726b'
'local_port' => 33160
'redirect_url' => ''
]
当我从配置中删除 Google+ scope(https://www.googleapis.com/auth/plus.login) 授权时没有错误并且 Google 响应是:
[
'url' => 'https://accounts.google.com/o/oauth2/token'
'content_type' => 'application/json; charset=utf-8'
'http_code' => 200
'header_size' => 522
'request_size' => 526
'filetime' => -1
'ssl_verify_result' => 0
'redirect_count' => 0
'total_time' => 0.13719
'namelookup_time' => 0.001212
'connect_time' => 0.026261
'pretransfer_time' => 0.079765
'size_upload' => 338
'size_download' => 900
'speed_download' => 6560
'speed_upload' => 2463
'download_content_length' => -1
'upload_content_length' => 338
'starttransfer_time' => 0.136241
'redirect_time' => 0
'certinfo' => []
'primary_ip' => '2a00:1450:4010:c08::54'
'primary_port' => 443
'local_ip' => '2a03:6f00:1::5c35:726b'
'local_port' => 37583
'redirect_url' => ''
]
问题仅在 https://www.googleapis.com/auth/plus.login 中。我启用的 API:http://minus.com/lJ5nw7caXJApD
您还可以在您的身份验证客户端配置中明确添加 returnUrl
。查看 docs 了解更多信息。
我也遇到了这个问题并找到了更改项目凭据中的重定向 URI 的解决方案,如下所示:
重定向 URI
http://mysiteurl.com/user/sign-in/oauth?authclient=google
http://mysiteurl.com/oauth2callback
JavaScript 起源
http://mysiteurl.com
Use return URL in main.php like
'authClientCollection' => [
'class' => 'yii\authclient\Collection',
'clients' => [
'facebook' => [
'class' => 'yii\authclient\clients\Facebook',
'authUrl' => 'https://www.facebook.com/dialog/oauth?display=popup',
'clientId' => ['FacebookClientId'],
'clientSecret' => ['FacebookClientSecret'],
'attributeNames' => ['name','first_name','last_name','email','gender','picture','age_range']
],
'google' => [
'class' => 'yii\authclient\clients\Google',
'clientId' => ['GoogleClientId'],
'clientSecret' => ['GoogleClientSecret'],
'returnUrl' => 'http://yoursite.com/site/auth?authclient=google'
],
],
],
Also set redirect_url in api credentials same as return url
It's work for me.
我正在使用 Yii2、GoogleOAuth 和 yii2-user 扩展。我想接收用户 google 圈子并将范围设置为我的配置:
'authClientCollection' => [
'class' => 'yii\authclient\Collection',
'clients' => [
'google' => [
'class' => 'yii\authclient\clients\GoogleOAuth',
'clientId' => '758709912345-p4qp4lqihit5un1u6qb75msqp5m5j6d8.apps.googleusercontent.com',
'clientSecret' => 'ZygOIi1-0asfktUQ1pKOFOo',
'scope' => 'https://www.googleapis.com/auth/plus.login https://www.googleapis.com/auth/userinfo.email https://www.googleapis.com/auth/drive',
],
],
]
当我使用 Google OAuth2 登录时出现错误:
Exception – yii\authclient\InvalidResponseException Request failed with code: 400, message: { "error" : "redirect_uri_mismatch" }
Google 回复:
[
'url' => 'https://accounts.google.com/o/oauth2/token'
'content_type' => 'application/json'
'http_code' => 400
'header_size' => 435
'request_size' => 644
'filetime' => -1
'ssl_verify_result' => 0
'redirect_count' => 0
'total_time' => 0.115431
'namelookup_time' => 0.001186
'connect_time' => 0.025188
'pretransfer_time' => 0.076275
'size_upload' => 456
'size_download' => 39
'speed_download' => 337
'speed_upload' => 3950
'download_content_length' => -1
'upload_content_length' => 456
'starttransfer_time' => 0.114206
'redirect_time' => 0
'certinfo' => []
'primary_ip' => '2a00:1450:4010:c08::54'
'primary_port' => 443
'local_ip' => '2a03:6f00:1::5c35:726b'
'local_port' => 33160
'redirect_url' => ''
]
当我从配置中删除 Google+ scope(https://www.googleapis.com/auth/plus.login) 授权时没有错误并且 Google 响应是:
[
'url' => 'https://accounts.google.com/o/oauth2/token'
'content_type' => 'application/json; charset=utf-8'
'http_code' => 200
'header_size' => 522
'request_size' => 526
'filetime' => -1
'ssl_verify_result' => 0
'redirect_count' => 0
'total_time' => 0.13719
'namelookup_time' => 0.001212
'connect_time' => 0.026261
'pretransfer_time' => 0.079765
'size_upload' => 338
'size_download' => 900
'speed_download' => 6560
'speed_upload' => 2463
'download_content_length' => -1
'upload_content_length' => 338
'starttransfer_time' => 0.136241
'redirect_time' => 0
'certinfo' => []
'primary_ip' => '2a00:1450:4010:c08::54'
'primary_port' => 443
'local_ip' => '2a03:6f00:1::5c35:726b'
'local_port' => 37583
'redirect_url' => ''
]
问题仅在 https://www.googleapis.com/auth/plus.login 中。我启用的 API:http://minus.com/lJ5nw7caXJApD
您还可以在您的身份验证客户端配置中明确添加 returnUrl
。查看 docs 了解更多信息。
我也遇到了这个问题并找到了更改项目凭据中的重定向 URI 的解决方案,如下所示:
重定向 URI
http://mysiteurl.com/user/sign-in/oauth?authclient=google
http://mysiteurl.com/oauth2callback
JavaScript 起源
http://mysiteurl.com
Use return URL in main.php like
'authClientCollection' => [
'class' => 'yii\authclient\Collection',
'clients' => [
'facebook' => [
'class' => 'yii\authclient\clients\Facebook',
'authUrl' => 'https://www.facebook.com/dialog/oauth?display=popup',
'clientId' => ['FacebookClientId'],
'clientSecret' => ['FacebookClientSecret'],
'attributeNames' => ['name','first_name','last_name','email','gender','picture','age_range']
],
'google' => [
'class' => 'yii\authclient\clients\Google',
'clientId' => ['GoogleClientId'],
'clientSecret' => ['GoogleClientSecret'],
'returnUrl' => 'http://yoursite.com/site/auth?authclient=google'
],
],
],
Also set redirect_url in api credentials same as return url
It's work for me.