2017-06-14 48 views
0

我试图通过nodejs脚本获取grandstream手机的呼叫状态。但我遇到了一些麻烦。第一个请求一切正常,并返回认证。第二个请求不好,它说我没有通过身份验证。从grandstream手机获取nodejs的呼叫状态

如何在第二个请求中从第一个请求中设置凭据或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

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

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

工程就像一个魅力! –