我正在尝试通过nodejs脚本获取grandstream手机的通话状态。但是我遇到了麻烦。第一个请求一切正常,并返回我的身份验证。第二个请求进展顺利,它表示我没有通过身份验证。
如何在第二个请求中设置第一个请求的凭据或cookie,以便它知道我已登录?
首次请求回复:
Response=Success
Message=Authentication accepted
Needchange=0
Ver=1.0.3.92
第一个请求响应标头:
{
'status': '200',
'content-length': '79',
'content-location': 'http://192.168.0.1/manager?action=login&username=XXXXXX&secret=XXXXXX',
'set-cookie': 'phonecookie="XXXXXX";HttpOnly, type=admin;, Version="1";, Max-Age=900',
'server': 'Enterprise Phone',
'pragma': 'no-cache',
'cache-control': 'no-cache',
'date': 'Wed, 14 Jun 2017 10:22:29 GMT',
'content-type': 'text/plain'
}
第二次请求回复:
Response=Error
Message=Authentication Required
App.js脚本:
var fetch = require('node-fetch');
var host = '192.168.0.1';
var loginUrl = "/manager?action=login&username=XXXXXX&secret=XXXXXX";
var statusUrl = "/manager?action=lineStatus&line=0";
function makeRequest(url)
{
fetch("http://" + host + loginUrl).then(function(resultLogin) {
var resultAuth = result.body();
fetch("http://" + host + statusUrl, {method: 'GET').then(function(resultStatus) {
var resultStatus = resultStatus.body();
});
});
}
makeRequest();
答案 0 :(得分:0)
使用fetch-cookie让node-fetch
根据网址存储和发回Cookie。
var fetch = require('fetch-cookie')(require('node-fetch'))