我的javascript应用尝试访问我的Google云端点时出现401错误

时间:2017-02-06 21:29:59

标签: javascript python google-app-engine google-cloud-endpoints

该项目位于Google Appengine云端点框架上。 Python在后端。 我还使用了endpoints_proto_datastore(不确定这是否有所不同)

这是我的html文件 -

<html>
<body>

<script>

clientId = 'myclientid-something-something-something.apps.googleusercontent.com'
loginScope = 'https://www.googleapis.com/auth/userinfo.email https://www.googleapis.com/auth/admin.directory.user.readonly https://www.googleapis.com/auth/admin.directory.customer.readonly https://www.googleapis.com/auth/gmail.settings.basic';        
apiKey = 'my-api-key-from-cloud-console';

doSignIn = function() {
  console.log("calling doSignIn");
  gapi.client.init({apiKey: apiKey, clientId: clientId,scope: loginScope}).then(renderSignIn);
}

renderSignIn = function(){
              gapi.signin2.render('my-signin', {
                'scope': loginScope,
                'width': 'inherit',
                'height': 50,
                'longtitle': true,
                'theme': 'light',
                'onsuccess': getOfflineAccess,
                'onfailure': function(){console.log("error")}
             });
};

getOfflineAccess =function(){
  console.log("calling getOfflineAccess");
  gapi.auth2.getAuthInstance().grantOfflineAccess({'redirect_uri': 'postmessage'}).then(getApiAuthorization);
}
getApiAuthorization = function(){
  console.log("calling getApiAuthorization");
  gapi.auth.authorize({client_id: clientId,scope: loginScope, immediate: false},singedInCallback);
};
singedInCallback = function(authResponse) {
    console.log("calling signInCallback");
    gapi.client.endpointsapp.userOfflineAccessCode.insert({'auth_code':authResponse.code})
           .then(   function(){console.log("success");},  
                    function(){console.log("error");}
                ); 
};



init = function() {
  console.log("calling init");
  var apisToLoad;
  var callback = function() {
    if (--apisToLoad == 0) {
      doSignIn();
    }
  }
  apisToLoad = 2; 
  gapi.client.load('endpointsapp','v1',callback,"https://endpointsapp.appspot.com/_ah/api"); //dummy name for app
  gapi.load('client:auth2', callback);
};

</script>
<div id="my-signin"></div>

    <script src="https://apis.google.com/js/api.js?onload=init"></script>  
    <script src="https://apis.google.com/js/client.js?onload=init"></script>  
    <script src="https://apis.google.com/js/platform.js"></script>

</body>
</html>

一开始一切顺利。 我得到一个谷歌签名按钮。 我点击它然后授予所有必需的权限。 当实际的API命中时。这给了我一个401。

我从API获得的响应(gapi.client.endpointsapp.userOfflineAccessCode.insert)是:

{
 "error": {
  "code": 401, 
  "errors": [
   {
    "domain": "global", 
    "message": "Invalid token.", 
    "reason": "required"
   }
  ], 
  "message": "Invalid token."
 }
}

当我使用google api资源管理器尝试相同的api端点时,如果我通过身份验证,一切正常,没有任何问题。

我一直试图调试这一整天,但却无法弄清楚我做错了什么。

非常感谢任何帮助。

1 个答案:

答案 0 :(得分:1)

确定发现了这个问题。非常基本的错误。

根据https://cloud.google.com/endpoints/docs/frameworks/python/create_api,如果API使用身份验证,则allowed_client_ids是必填字段。我没有提供此参数,并且期望默认情况下API可用于所有client_ids。