Javascript Node.js请求承诺jar cookies不工作
我正在尝试进行两个API调用。第一个登录,最后一个执行授权操作。即使登录成功,对授权操作的调用也会产生未经授权的错误。我想这是因为我收到的饼干在上次通话中没有被退回。不过我看到饼干是储存在罐子里的。我和邮递员试过了,效果很好 这是我的密码:Javascript Node.js请求承诺jar cookies不工作,javascript,node.js,http,cookies,request,Javascript,Node.js,Http,Cookies,Request,我正在尝试进行两个API调用。第一个登录,最后一个执行授权操作。即使登录成功,对授权操作的调用也会产生未经授权的错误。我想这是因为我收到的饼干在上次通话中没有被退回。不过我看到饼干是储存在罐子里的。我和邮递员试过了,效果很好 这是我的密码: const request = require('request-promise'); const jar = request.jar(); const loginOptions = () => ({ method: 'POST',
const request = require('request-promise');
const jar = request.jar();
const loginOptions = () => ({
method: 'POST',
url: 'https://www.some-api.com/login',
jar,
headers:
{
'content-type': 'application/json'
},
body: {
username: "username",
password: "password"
},
json: true
});
const authorizedOperationOptions = (param) => ({
method: 'GET',
url: 'https://www.some-api.com/authorized-operation?param=' + param
timeout: 1000000,
jar,
headers:
{
'content-type': 'application/json'
},
json: true
});
export default async (date) => {
await request(loginOptions());
await request(authorizedOperationOptions("value"));
};
我很想知道我做错了什么,但我也会接受另一种方法,通过一个工作示例代码使用不同的库来实现
请注意,该服务设计为仅支持web浏览器,因此可能与该问题有关
对于那些不熟悉wait的人来说,它可以确保代码阻塞,直到承诺实现为止,并在拒绝时抛出。由于该服务定义为仅支持web浏览器,因此我不得不模拟web浏览器。我通过添加用户代理标题来管理它:
headers:
{
'User-Agent': 'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.6) Gecko/20070725 Firefox/2.0.0.6'
},
我想这是因为我收到的饼干在上次通话中没有被送回。-你能在一个简单的模拟服务器上试试吗?这样就可以清楚地知道这是客户机问题还是服务器问题。@shaochuancs我和Postman一起试过,结果成功了well@shaochuancs我的意思是我试着让邮递员去真正的服务器,但我认为这是一个很好的证据,不是吗?你能不能在第一次呼叫后检查一下罐子里有没有东西?@robertklep是的,我刚刚检查了一下,发现饼干是放在罐子里的