2012-08-15 18 views

risposta

10

L'ho fatto un po 'di tempo fa e ho finito per scrivere una piccola libreria per farlo. Il CoffeeScript originale può essere trovato alla https://gist.github.com/fbef51815ab6f062b51a#file_signed_request.coffee, qui è una traduzione 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; 

che è possibile utilizzare in questo modo:

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

sembra buono. Molte grazie! – Droidik

+0

Con cosa si sostituisce la richiesta firmata? So che il clientSecret è fornito da facebook? Pan in ogni caso puoi mostrare come hai fatto tutto il lavoro per il lato server facebook api per afferrare l'ID utente? – Lion789

+0

@Michelle come recuperare la richiesta_segnale codificata iniziale. Per esempio 'app.post ('/ *', la funzione (req, res) { console.log ('req.signed_request'); var verificatore = new SignedRequest (app_secret_key, req.signed_request); verificatore. verify(); console.log ('verifier.data'); res.redirect ('/'); }); ' – user1371896