Google AnalyticsAPI Javascript:403禁止错误

时间:2011-12-11 19:05:52

标签: javascript api google-analytics

为了鲍勃的爱,有人请帮帮我......

我正在尝试使用Google AnalyticsAPI(Javascript库)来获取一些Google Analytics信息。我已经注册了我的应用程序并设置了oauth2的东西。我可以返回访问令牌jsut,但是当我尝试发送实际抓取Google Analytics信息的请求时,它会返回403禁止错误。这是我的代码:

function auth() {
    var config = {
        'client_id': '[my_client_id]',
        'scope': 'https://www.googleapis.com/auth/analytics.readonly'
    };
    gapi.auth.authorize(config, function() {
        var retObj = gapi.auth.getToken();
        makeRequest(retObj.access_token);
    });
}

function makeRequest(accessToken) {
    var restRequest = gapi.client.request({
        'path': '/analytics/v3/data/ga',
        'params': {
            'access_token': accessToken,
            'ids': 'ga:[table_number]',
            'metrics': 'ga:pageviews,ga:uniquePageviews',
            'start-date': '2011-11-01',
            'end-date' : '2011-12-01'               
        }
    });
    restRequest.execute(function(resp) { console.log(resp); });
}

通过按钮点击执行auth()函数,就像我说的那样,获取访问令牌不是问题。当我执行makeRequest函数时,我得到403错误。任何人都知道这笔交易是什么?

感谢任何提前回答的人!!

2 个答案:

答案 0 :(得分:2)

在我的情况下,我获得了403 Forbidden,因为在我的浏览器中,我使用的帐户登录了Google,该帐户未获得我尝试访问的GA个人资料的权限。在发现这个问题之前,我遇到了Aksival发布上述解决方案的tableID问题。

以下是我的工作代码供您参考:

<script type="text/javascript">
    //GET THESE HERE https://code.google.com/apis/console/
    var clientId = 'YOURCLIENTIDHERE';
    var apiKey = 'YOURAPIKEYHERE';

    //GET THIS HERE http://code.google.com/apis/analytics/docs/gdata/v3/gdataAuthorization.html
    var scopes = 'https://www.googleapis.com/auth/analytics.readonly';

    //INITIALIZE
    function handleClientLoad() {
        gapi.client.setApiKey(apiKey);
        window.setTimeout(checkAuth,1);
    }

    function checkAuth() {
        gapi.auth.authorize({client_id: clientId, scope: scopes, immediate: true}, handleAuthResult);
    }

    function handleAuthResult(authResult) {
        if (authResult) {
            makeApiCall();
        } else {            
            requestAuth();
        }
    }

    function requestAuth() {
        gapi.auth.authorize({client_id: clientId, scope: scopes, immediate: false}, handleAuthResult);
    }

    function makeApiCall() {
        gapi.client.load('analytics', 'v3', function() {
            var request = gapi.client.analytics.data.ga.get({
                'ids':'ga:YOURTABLEIDHERE', 'start-date':'2012-01-01', 'end-date':'2012-02-01', 'metrics':'ga:visits', 'metrics':'ga:visits', 'start-index':1, 'max-results':1000
            });
            request.execute(function(resp) { console.log(resp.totalsForAllResults); });
        });
    }
</script>
<script src="https://apis.google.com/js/client.js?onload=handleClientLoad"></script>

答案 1 :(得分:1)

我有同样的问题。结果我错了[table_number]。

您需要查询

accounts/[account-id]/webproperties/[webproperties-id]/profiles

并使用相应属性的“id”字段。 (我最初使用webproperties查询中的internalWebPropertyId,这就是失败的原因。)

现在就像魅力一样。