从grandstream phone

时间:2017-06-14 11:56:50

标签: javascript node.js node-fetch

我正在尝试通过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();

1 个答案:

答案 0 :(得分:0)

使用fetch-cookienode-fetch根据网址存储和发回Cookie。

var fetch = require('fetch-cookie')(require('node-fetch'))