我已经在网站中使用javascript-sdk登录了google plus。不到两天就开始工作了。但现在不起作用了,因为gap.client.load('oauth2','v2',function());未加载,即不工作。请帮忙。
以下是我的代码:
(function() {
var po = document.createElement('script');
po.type = 'text/javascript'; po.async = true;
po.src = 'https://apis.google.com/js/client:plusone.js?';
var s = document.getElementsByTagName('script')[0];
s.parentNode.insertBefore(po, s);
})();
gapi.signin.render('customBtn', {
'callback': 'signinCallback',
'clientid': '<client ID>',
'cookiepolicy': 'single_host_origin',
'requestvisibleactions': 'http://schemas.google.com/AddActivity',
'scope': 'https://www.googleapis.com/auth/plus.login https://www.googleapis.com /auth/userinfo.email'
});
function signinCallback(authResult) {
if (authResult['access_token']) {
gapi.auth.setToken(authResult);
getEmail();
} else if (authResult['error']) {
alert('Please try again');
// alert('There was an error: ' + authResult['error']);
}
}
function getEmail(){
// Load the oauth2 libraries to enable the userinfo methods.
try
{
gapi.client.load('oauth2', 'v2', function() {
var request_mail = gapi.client.oauth2.userinfo.get();
request_mail.execute(getEmailCallback);
});
}
catch(err)
{
alert( "onLoadCallback error: " + err.message );
}
}
function getEmailCallback(obj){
if (obj['email']) {
$('login:email').value = obj['email'];
checkout.setMethod();
}
}
以下代码对我有效,所以您使用的特定代码似乎没有任何问题:
gapi.client.load('oauth2', 'v2',
function(){
console.log('loaded');
});
脚本可能加载成功,但其他东西正在破坏它。放入console.log
调用可能有助于隔离是否是加载调用破坏了它。
检查Chrome JavaScript控制台,查看您的JavaScript中是否存在错误。如果出现错误,例如gapi is undefined
,那么您应该能够更好地诊断故障的原因。
如果还没有,请尝试在加载plusone:client.js
脚本时将client.load调用放入回调中。如果异步加载脚本,则脚本加载的竞争条件可能会阻止Google API JavaScript客户端初始化OAuth 2.0客户端。以下代码将在脚本中设置回调,以便在加载后执行客户端初始化:
<script type="text/javascript">
(function() {
var po = document.createElement('script'); po.type = 'text/javascript'; po.async = true;
po.src = 'https://apis.google.com/js/client:plusone.js?onload=onLoadCallback';
var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(po, s);
})();
</script>
一旦初始化了client.js和plusone.js,就会触发函数onLoadCallback
。