【问题标题】:Get signed_request in Node.js (Express) Facebook canvas app在 Node.js (Express) Facebook 画布应用中获取 signed_request
【发布时间】:2016-09-09 14:55:23
【问题描述】:

有什么方法可以在 Node.js Facebook 页面标签应用程序中获取和解析 signed_request 吗?我需要知道页面 id 以及用户是否喜欢该页面...

【问题讨论】:

    标签: javascript facebook node.js express


    【解决方案1】:

    我不久前做了这个,最后写了一个小库来做。原始 CoffeeScript 可以在 https://gist.github.com/fbef51815ab6f062b51a#file_signed_request.coffee 找到,这里是 JavaScript 翻译:

    var crypto = require('crypto');
    
    SignedRequest = (function() {
    
      function SignedRequest(secret, request) {
        this.secret = secret;
        this.request = request;
        this.verify = this.verify.bind(this);
    
        var parts = this.request.split('.');
        this.encodedSignature = parts[0];
        this.encoded = parts[1];
        this.signature = this.base64decode(this.encodedSignature);
        this.decoded = this.base64decode(this.encoded);
        this.data = JSON.parse(this.decoded);
      }
    
      SignedRequest.prototype.verify = function() {
        if (this.data.algorithm !== 'HMAC-SHA256') {
          return false;
        }
        var hmac = crypto.createHmac('SHA256', this.secret);
        hmac.update(this.encoded);
        var result = hmac.digest('base64').replace(/\//g, '_').replace(/\+/g, '-').replace(/\=/g, '');
        return result === this.encodedSignature;
      };
    
      SignedRequest.prototype.base64encode = function(data) {
        return new Buffer(data, 'utf8').toString('base64').replace(/\//g, '_').replace(/\+/g, '-').replace(/\=/g, '');
      };
    
      SignedRequest.prototype.base64decode = function(data) {
        while (data.length % 4 !== 0) {
          data += '=';
        }
        data = data.replace(/-/g, '+').replace(/_/g, '/');
        return new Buffer(data, 'base64').toString('utf-8');
      };
    
      return SignedRequest;
    
    })();
    
    module.exports = SignedRequest;
    

    你可以这样使用:

    var verifier = new SignedRequest(clientSecret, signedRequest);
    verifier.verify() // whether or not the signed request verifies
    verifier.data // the data from the signed request
    

    【讨论】:

    • 你用什么替换signedRequest?我知道 clientSecret 是由 facebook 提供的?无论如何,潘你可以展示你是如何让整个事情为 facebook api 服务器端获取用户 ID 的?
    • @Michelle 如何获取初始编码的签名请求。例如app.post('/*', function(req, res) { console.log('req.signed_request'); var verifier = new SignedRequest(app_secret_key, req.signed_request); verifier.verify() ; console.log('verifier.data'); res.redirect('/'); });
    猜你喜欢
    • 2012-01-08
    • 2011-08-05
    • 1970-01-01
    • 1970-01-01
    • 2011-11-20
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多