使用JavaScript访问Google分析数据,无需同意页面。

8
我正在使用 Atlasboard 创建一个仪表板。
我需要访问 Google Analytics 数据,例如页面浏览量等,在此我将运行一些查询,如 此处 所示。
有没有办法在不出现同意页面的情况下访问我的 Google Analytics 数据? enter image description here 我正在使用 google-api-nodejs-client API。
我发现 这篇帖子,其中有人提到使用服务帐户。但是我找不到任何在 JavaScript 中使其工作的方法。
任何帮助都将不胜感激!

1
据我所知,你不能使用服务账户来进行JavaScript编程。这很可能是由于安全问题。我建议转换为服务器端脚本语言。 - Linda Lawton - DaImTo
好的,谢谢!我会再进行一些研究,并在这里发布我的发现! - smj2393
3个回答

10

我终于成功地找到了解决这个问题的方法!!!这就是解决方案 :)

假设您已经拥有了一个Google Analytics帐户,其中包含网站数据(如浏览量),并安装了requestgoogleapis模块。

首先,您需要在console.developers.google.com上创建Google控制台帐户。

在Google控制台中:

  • 使用适当的名称创建一个项目,例如dashboard1。
  • 从左侧菜单打开API's&Auth->打开API's选项卡->打开分析API。
  • 打开凭据选项卡->创建新客户端ID->选择服务帐户
  • 应自动下载密钥->点击密钥并按照说明操作->默认密码为“notasecret”->然后将输出一个.pem文件
  • 服务帐户将具有电子邮件地址,例如123434234324f34f5fd4ww5f@developer.gserviceaccount.com

现在转到您的Google Analytics帐户www.google.com/analytics

在仪表板工作(使用nodejs的服务器端):

使用此代码:

    var fs = require('fs'),
        crypto = require('crypto'),
        request = require('request'); // This is an external module (https://github.com/mikeal/request)

    var authHeader = {
            'alg': 'RS256',
            'typ': 'JWT'
        },
        authClaimSet = {
            'iss': '#######SERVICE ACCOUNT EMAIL GOES HERE#######', // Service account email
            'scope': 'https://www.googleapis.com/auth/analytics.readonly', // We MUST tell them we just want to read data
            'aud': 'https://accounts.google.com/o/oauth2/token'
        },
        SIGNATURE_ALGORITHM = 'RSA-SHA256',
        SIGNATURE_ENCODE_METHOD = 'base64',
        GA_KEY_PATH = '#######DIRECTORY TO YOUR .PEM KEY#######', //finds current directory then appends private key to the directory
        gaKey;

    function urlEscape(source) {
        return source.replace(/\+/g, '-').replace(/\//g, '_').replace(/\=+$/, '');
    }

    function base64Encode(obj) {
        var encoded = new Buffer(JSON.stringify(obj), 'utf8').toString('base64');
        return urlEscape(encoded);
    }

    function readPrivateKey() {
        if (!gaKey) {
            gaKey = fs.readFileSync(GA_KEY_PATH, 'utf8');
        }
        return gaKey;
    }

    var authorize = function(callback) {

        var self = this,
            now = parseInt(Date.now() / 1000, 10), // Google wants us to use seconds
            cipher,
            signatureInput,
            signatureKey = readPrivateKey(),
            signature,
            jwt;

        // Setup time values
        authClaimSet.iat = now;
        authClaimSet.exp = now + 60; // Token valid for one minute

        // Setup JWT source
        signatureInput = base64Encode(authHeader) + '.' + base64Encode(authClaimSet);

        // Generate JWT
        cipher = crypto.createSign('RSA-SHA256');
        cipher.update(signatureInput);
        signature = cipher.sign(signatureKey, 'base64');
        jwt = signatureInput + '.' + urlEscape(signature);

        // Send request to authorize this application
        request({
            method: 'POST',
            headers: {
                'Content-Type': 'application/x-www-form-urlencoded'
            },
            uri: 'https://accounts.google.com/o/oauth2/token',
            body: 'grant_type=' + escape('urn:ietf:params:oauth:grant-type:jwt-bearer') +
                '&assertion=' + jwt
        }, function(error, response, body) {
            if (error) {
                console.log(error);
                callback(new Error(error));
            } else {
                var gaResult = JSON.parse(body);
                if (gaResult.error) {
                    callback(new Error(gaResult.error));
                } else {
                    callback(null, gaResult.access_token);
                    console.log(gaResult);
                    console.log("Authorized");
                    ###########IF IT REACHES THIS STAGE THE ACCOUNT HAS BEEN AUTHORIZED##############
                }
            }
        });

    };



    var request = require('request'),
        qs = require('querystring');

    authorize(function(err, token) {
        if (!err) {
            // Query the number of total visits for a month
            ############requestConfig################
            var requestConfig = {
                'ids': 'ga:#######PROJECT ID GOES HERE#######',
                'dimensions': 'ga:country',
                'metrics': 'ga:users',
                'sort': '-ga:users',
                'start-date': '2014-04-08',
                'end-date': '2014-04-22',
                'max-results': '10'
            };

            request({
                method: 'GET',
                headers: {
                    'Authorization': 'Bearer ' + token // Here is where we use the auth token
                },
                uri: 'https://www.googleapis.com/analytics/v3/data/ga?' + qs.stringify(requestConfig)
            }, function(error, resp, body) {
                console.log(body);
                var data = JSON.parse(body);
                console.log(data);
            });
        }
    });

请记得输入您自己的服务电子邮件帐户,GA_KEY_PATH和IDS

通过更改requestConfig,您可以获取Google Analytics数据。我使用了这个Google Analytics查询工具来帮助我:http://ga-dev-tools.appspot.com/explorer/

然后应该在控制台中输出数据。

希望这有所帮助 :)


4

除了smj2393的答案之外,对于那些想创建一个特定URL以检索Google Analytics API提供的JSON的人来说,这是一个Node Express路由的示例。您需要安装官方的Google API Node npm包 (https://www.npmjs.org/package/googleapis)。

var google = require('googleapis');
var analytics = google.analytics('v3');
var ENV = process.env;

//get key.p12 in Google Developer console
//Extract it with : openssl pkcs12 -in key.p12 -nodes -nocerts > key.pem
//Get GOOGLE_API_EMAIL in Google Developer console (Service Account)
//Get GOOGLE_ANALYTICS_VIEW_ID in Google Analytics Console : Admin -> View -> View Parameters -> View ID
//Add GOOGLE_API_EMAIL in the Google Analytics account users

var authClient = new google.auth.JWT(
    ENV.GOOGLE_API_EMAIL,
    './keys/googlekey.pem', //path to .pem
    null,
    // Scopes can be specified either as an array or as a single, space-delimited string
    ['https://www.googleapis.com/auth/analytics.readonly']);

module.exports = function(req, res, next) {
  var startDate = (req.query.start_date) ? req.query.start_date : '7daysAgo';
  var endDate = (req.query.end_date) ? req.query.end_date : 'yesterday';

  authClient.authorize(function(err, tokens) {
    if (err) {
      console.log(err);
      return;
    }

    // Make an authorized request to list analytics files.
    // list of dimensions and metrics : https://developers.google.com/analytics/devguides/reporting/core/dimsmets
    analytics.data.ga.get({
      auth: authClient,
      "ids":'ga:'+ENV.GOOGLE_ANALYTICS_VIEW_ID,
      "start-date":startDate,
      "end-date":endDate,
      "metrics":"ga:sessions,ga:pageviews",
      "dimensions":"ga:deviceCategory"

      }, function(err, result) {
        console.log(err);
        console.log(result);
        if(!err){
          res.json(result);
        }
        else{
          next();
        }
    });
  });
}

这条路线将展示一个JSON,其中包含按设备(桌面、移动和平板电脑)分类的会话数和页面浏览量。您可以通过GET参数传递start_date或end_date。
希望这有所帮助。

0

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接