bur*_*rgi 5 javascript google-api google-oauth google-signin
我正在尝试为服务器端应用实施Google登录,如Google文档中所示:用于服务器端应用的Google登录,但同意窗口从不要求离线访问.选择用户后,它会关闭并调用登录处理程序功能.
因此,当我获得一次性代码并将其发送到服务器时,我无法将其替换为刷新令牌,仅用于访问和id令牌.
这是我的客户端代码:
在HTML文件中:
<script src="https://apis.google.com/js/platform.js?onload=init" async defer></script>
Run Code Online (Sandbox Code Playgroud)
Javascript代码:
var auth2;
function init() {
gapi.load('auth2', function() {
auth2 = gapi.auth2.init({
client_id: '<my client id>.apps.googleusercontent.com',
scope: 'https://www.google.com/m8/feeds https://www.googleapis.com/auth/drive https://www.googleapis.com/auth/drive.appfolder'
});
});
$('#signinButton').click(function() {
auth2.grantOfflineAccess({'redirect_uri': 'postmessage'}).then(onSignIn);
});
}
function onSignIn(authResult) {
if (authResult['code']) {
// Send the code to the server
}
}
Run Code Online (Sandbox Code Playgroud)
Google控制台中的项目包含一个Web客户端凭据,其中包含相关的javascript源,并且没有授权的重定向URI.
我该怎么做才能强制同意窗口要求离线访问?
我能够迫使提示下线,加入帕拉姆'approval_prompt' : 'force'到auth2.grantOfflineAccess函数调用.
例如
auth2.grantOfflineAccess({'redirect_uri' : 'postmessage', 'approval_prompt' : 'force'}).then(onSignIn);