我是Simperium的新手并使用Javascript API。
我确实使用authorize获取了一个访问令牌,但是在创建新的Simperium(...)时遇到了'auth'错误,所以我尝试获取一个新令牌,但这会失败,返回错误代码400或401。
这是我的代码,其中KEY是api密钥,ID是应用程序ID,USER和PASS是我的用户名和密码......
授权:
var url,request,response,json,token,auth;
url="https://auth.simperium.com/1/"+appID+"/authorize/";
request=new XMLHttpRequest();
request.onreadystatechange=function() {
if(request.readyState===4) {
if(request.status===200) {
response=request.responseText;
console.log('response: '+response);
if(response.length>0) {
json=JSON.parse(response);
token=json.access_token;
...
}
}
else {
console.log('ERROR');
return null;
}
}
};
request.open("POST",url,true);
request.setRequestHeader("X-Simperium-API-Key",'"'+KEY+'"');
request.setRequestHeader("Content-type", "application/json");
auth='{"username": "'+USER+'", "password": "'+PASS+'"}';
request.send(auth);
这失败了400或401!
当我有一个ACCESS_TOKEN:
var options="{token: '"+ACCESS_TOKEN+"'}";
var simperium=new Simperium(ID,options);
var bucket=simperium.bucket('ledger');
bucket.on('notify',function(id,data) {
console.log("transaction updated: "+data);
...
});
bucket.on("error", function(error) {
console.log("Simperium error : "+error);
if (error == "auth") {
console.log("auth error, need to reauthenticate and get new access token")
...
}
});
bucket.start();
这导致“auth”错误。
答案 0 :(得分:1)
有些事情,为了在API密钥上设置请求标头,您不应该需要api密钥周围的额外引号,除非您是从模板渲染它。如果您的密钥是abcdefg,它应该如下所示:
request.setRequestHeader("X-Simperium-API-Key","abcdefg");
一旦有了访问令牌,在设置options对象时,你应该传递一个对象而不是一个字符串:
var options={token: "ACCESS_TOKEN"};