我使用node myscript.js在Windows命令提示符下运行以下脚本。该脚本请求使用Windows身份验证的web应用程序。我希望收到状态码200。但是该脚本返回一个401 Unauthenticated。
let request = require('request');
console.log(process.env.USERDOMAIN);
console.log(process.env.USERNAME);
request('http://internalurl',
function (error, response, body){
if (!error && response.statusCode == 200){
console.log('request successful!');
var input = JSON.parse(body);
}
console.log(response);
});process.env.USERNAME显示我的当前用户名,该用户名应该可以访问web应用程序。因此,我假设脚本是在正确的用户帐户下运行的。登录web应用程序的最佳实践是什么?
发布于 2018-04-03 20:34:04
使用Windows身份验证时收到401消息是正常的-这是Windows身份验证过程的第一步。然后,401响应中的WWW-Authenticate标头会告诉您可用的身份验证机制( NTLM或协商)。
这个问题的公认答案更详细地描述了这个过程:https://stackoverflow.com/a/13960538/1202807
但是,答案并不能为节点客户端提供解决方案。但是the last answer to that question确实给出了一个使用node-libcurl实现的示例
var endpoint = urlString;
var url = require("url");
var endpointUrl = url.parse(endpoint);
var Curl = require( 'node-libcurl' ).Curl;
var curl = new Curl();
curl.setOpt( 'USERNAME', '' );
//curl.setOpt( 'VERBOSE', 1 );
curl.setOpt( 'URL', endpoint );
curl.setOpt( 'HTTPAUTH', Curl.auth.NEGOTIATE );
curl.setOpt( 'NOPROXY', endpointUrl.hostname );
curl.on( 'end', function( statusCode, body, headers ) {
if (statusCode === 200) {
console.log(body);
cb(null, { statusCode, body, headers } );
} else {
cb(new Error(), { statusCode, body, headers } );
}
this.close();
});
curl.on( 'error', curl.close.bind( curl ) );
curl.perform();不过,我自己从来没有在node中这样做过,所以这就是我所能提供的所有帮助。
https://stackoverflow.com/questions/49625869
复制相似问题