如何在node.js中使用身份验证处理重定向响应?

时间:2011-12-11 02:27:34

标签: javascript http node.js

出于学习目的我没有使用外部模块,所以我正在尝试向服务器发出身份验证请求。它适用于卷曲:

curl -L -u user:password http://webpage/email

[已解决,thansk ...]但是在node.js中我遇到了问题,这是我的代码:

var http = require("http");
var options = {
  hostname : 'webpage',
  port : '80',
  path : '/email',
  method : 'GET',
  headers : {
       "Connection" : "keep-alive",
       "User-Agent" : "Mozilla/5.0 (X11; Linux x86_64)"
  },
  auth : "username:password"
}

options.agent = new http.Agent(options);

var req = http.request(options, function(res) {
 // The authentication works fine, like curl without -L parameter
 // STATUS 302
 res.setEncoding('utf8');
 res.on('data',function(chunk){
  console.log(chunk);

 // SOLVED ! 

  var opts = {
   host : 'webpage',
   port : '80',
   path : '/email/',
   location : res.headers.location,
   auth : "user:password"
 }

 var require = http.request(opts,function(resp){
  resp.setEnconding("utf8");
  resp.on('data',function(chk){
   console.log(chk);
  });
 });

 require.end();
 // --------------

  // I got the same without -L parameter in curl
  // <head><title>Document Moved</title></head>
  // <body><h1>Object Moved</h1>This document may be found <a href="http://webpage/email/">here</a></body> <-- The 'Location' is the same

 });
});

req.on('error',function(e){
 console.log('Problem with request : ' + e.message);
}

req.end()

我尝试再次使用标题中的“位置”请求,但我得到了相同的结果。

感谢您的帮助。

1 个答案:

答案 0 :(得分:1)

curl中的-u允许您传递Authentication头的值。在节点中,您可以手动执行此操作。基本身份验证的规范(我假设您正在使用)表示以基本64编码格式传递凭据。在节点中手动执行此操作看起来像这样。

headers = {
  'Authorization': 'Basic ' + (new Buffer(user + ':' + pass)).toString('base64')
}