[英]Error: origin_mismatch when using Google calendar API with port 444
[英]Google Calendar API javascript Error:Origin Mismatch
我正在处理一个我在此处找到的简单JavaScript代码: http : //googleappsdeveloper.blogspot.com/2011/12/using-new-js-library-to-unlock-power-of.html
它基本上获取了谷歌日历的身份验证,并检索其中包含的事件列表。 我已经注册了我的Web应用程序并获得了客户端ID和API密钥。
我正面临这样的错误:“错误:原因不匹配”,我正在使用localhost在本地运行javascript,我也将我的主页在google应用程序注册中设置为localhost。
任何帮助都会非常感激。
代码:
<html>
<body>
<div id='content'>
<h1>Events</h1>
<ul id='events'></ul>
</div>
<a href='#' id='authorize-button' onclick='handleAuthClick();'>Login</a>
<script>
var clientId = '506979856128.apps.googleusercontent.com';
var apiKey = 'AIzaSyAGbQAZQU0YNL8hK5EU69exIg7_sOg3JoA';
var scopes = 'https://www.googleapis.com/auth/calendar';
function handleClientLoad() {
gapi.client.setApiKey(apiKey);
window.setTimeout(checkAuth,1);
checkAuth();
}
function checkAuth() {
gapi.auth.authorize({client_id: clientId, scope: scopes, immediate: true},
handleAuthResult);
}
function handleAuthResult(authResult) {
var authorizeButton = document.getElementById('authorize-button');
if (authResult) {
authorizeButton.style.visibility = 'hidden';
makeApiCall();
} else {
authorizeButton.style.visibility = '';
authorizeButton.onclick = handleAuthClick;
}
}
function handleAuthClick(event) {
gapi.auth.authorize(
{client_id: clientId, scope: scopes, immediate: false},
handleAuthResult);
return false;
}
function makeApiCall() {
gapi.client.load('calendar', 'v3', function() {
var request = gapi.client.calendar.events.list({
'calendarId': 'primary'
});
request.execute(function(resp) {
for (var i = 0; i < resp.items.length; i++) {
var li = document.createElement('li');
li.appendChild(document.createTextNode(resp.items[i].summary));
document.getElementById('events').appendChild(li);
}
});
});
}
</script>
<script src="https://apis.google.com/js/client.js?onload=handleClientLoad"> </script>
</body>
</html>
我今天得到了相同的错误原因不匹配。在搜索之后,我得到了原因。
在创建Google Api Access时,我们必须指定授权重定向URI和授权重定向URI 。
现在,如果您从Authorized Redirect URIs中指定的URI之外调用Login,则会error:Unknown Origin is thrown
仅供参考 :我已经看到你使用localhost在本地运行javascript。 这意味着您尚未将localhost uri添加到授权重定向URI。
但是不要浪费你的时间去做。授权的重定向URI不接受localhost uri。这是由于Chrome的原始策略相同。如果你使用disable-web-security标志运行chrome,它也会在本地工作。
在Google Developers Console中创建客户端ID时,可以通过注意重定向URI和Javascript起源来解决原点不匹配的问题。
JavaScript源 不应该结束/
。
示例 : http://example.com/
: http://example.com/
- >正确的格式为http://example.com
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.