我正在尝试验证 Last.fm 会话并且在正确签署会话密钥的请求时遇到了困难。
我一直收到“提供了无效的方法签名”错误。但是当我在 JS 之外对我认为查询应该包含的内容进行 MD5 哈希处理时,我得到了相同的签名。 我想我可能在字符串中包含了错误的数据,但是找不出哪里错了。
我知道还有其他一些问题,我已经查看了所有这些问题,以查明出了什么问题,但我��誓它看起来对我来说是正确的。
这是签名算法和 Ajax 调用。我尝试留出足够的示例数据。
// Set elsewhere but hacked into this example:
var last_fm_data = {
'last_token':'TOKEN876234876',
'user': 'bob',
'secret': 'SECRET348264386'
};
// Kick it off.
last_fm_call('auth.getSession', {'token': last_fm_data['last_token']});
// Low level API call, purely builds a POSTable object and calls it.
function last_fm_call(method, data){
// param data - dictionary.
last_fm_data[method] = false;
// Somewhere to put the result after callback.
// Append some static variables
data['api_key'] = "APIKEY1323454";
data['format'] = 'json';
data['method'] = method;
post_data = last_fm_sign(data);
$.ajax({
type: "post",
url: last_url,
data: post_data,
success: function(res){
last_fm_data[method] = res;
console.log(res['key'])// Should return session key.
},
dataType: 'json'
});
}
function last_fm_sign(params){
ss = "";
st = [];
so = {};
Object.keys(params).forEach(function(key){
st.push(key); // Get list of object keys
});
st.sort(); // Alphabetise it
st.forEach(function(std){
ss = ss + std + params[std]; // build string
so[std] = params[std]; // return object in exact same order JIC
});
// console.log(ss + last_fm_data['secret']);
// api_keyAPIKEY1323454formatjsonmethodauth.getSessiontokenTOKEN876234876SECRET348264386
hashed_sec = unescape(encodeURIComponent($.md5(ss + last_fm_data['secret'])));
so['signature'] = hashed_sec; // Correct when calculated elsewhere.
return so; // Returns signed POSTable object
}
有什么我漏掉的吗?我完全被卡住了,不知道为什么不能返回一个按请求格式正确签名的POSTable对象 在这里。谢谢你的时间。
编辑:如果我没有得到任何建议,我就无法感谢任何人的时间!没有人有使用last.fm的经验吗?
data['format'] = 'json';
。 - George