6

我正在尝试使用 node.js 制作 Facebook 应用程序,但是在检查签名请求时遇到了麻烦。每次我发出请求时,程序都会抛出SyntaxError: Unexpected token ILLEGAL,如下所示:

undefined:1
":"721599476"}
              ^^
SyntaxError: Unexpected token ILLEGAL

罪魁祸首功能如下:

function parse_signed_request(signed_request, secret) {
    encoded_data = signed_request.split('.',2);
    // decode the data
    sig = encoded_data[0];
    json = base64url.decode(encoded_data[1]);
    data = JSON.parse(json); // ERROR Occurs Here!

    // check algorithm - not relevant to error
    if (!data.algorithm || data.algorithm.toUpperCase() != 'HMAC-SHA256') {
        console.error('Unknown algorithm. Expected HMAC-SHA256');
        return null;
    }

    // check sig - not relevant to error
    expected_sig = crypto.createHmac('sha256',secret).update(encoded_data[1]).digest('base64').replace(/\+/g,'-').replace(/\//g,'_').replace('=','');
    if (sig !== expected_sig) {
        console.error('Bad signed JSON Signature!');
        return null;
    }

    return data;
}

仅用于测试,有效的 signed_request 将是

WGvK-mUKB_Utg0l8gSPvf6smzacp46977pTtcRx0puE.eyJhbGdvcml0aG0iOiJITUFDLVNIQTI1NiIsImV4cGlyZXMiOjEyOTI4MjEyMDAsImlzc3VlZF9hdCI6MTI5MjgxNDgyMCwib2F1dGhfdG9rZW4iOiIxNTI1NDk2ODQ3NzczMDJ8Mi5ZV2NxV2k2T0k0U0h4Y2JwTWJRaDdBX18uMzYwMC4xMjkyODIxMjAwLTcyMTU5OTQ3NnxQaDRmb2t6S1IyamozQWlxVldqNXp2cTBmeFEiLCJ1c2VyIjp7ImxvY2FsZSI6ImVuX0dCIiwiY291bnRyeSI6ImF1In0sInVzZXJfaWQiOiI3MjE1OTk0NzYifQ

为什么当它是有效的 JSON 并且简单地使用 JSON 的静态字符串时我会收到此错误,并且有任何提示可以解决此问题?

谢谢。

4

1 回答 1

1

好的,经过一些测试,我自己解决了这个问题,很抱歉浪费了这个问题。

我的 base64 库中的某些东西没有正确解码字符串(尽管它看起来是 - 所以它一定是一个不显示的字符或填充等)

我已更改为适合我的目的的https://github.com/kriszyp/commonjs-utils/blob/master/lib/base64.js,尽管需要进行修改以支持 base64url 解码而不是普通的 base64,并且它现在似乎工作正常。

于 2010-12-20T03:38:46.653 回答