首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >以windows AD用户身份运行脚本

以windows AD用户身份运行脚本
EN

Stack Overflow用户
提问于 2018-04-03 16:50:38
回答 1查看 60关注 0票数 0

我使用node myscript.js在Windows命令提示符下运行以下脚本。该脚本请求使用Windows身份验证的web应用程序。我希望收到状态码200。但是该脚本返回一个401 Unauthenticated

代码语言:javascript
运行
复制
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应用程序的最佳实践是什么?

EN

回答 1

Stack Overflow用户

发布于 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实现的示例

代码语言:javascript
运行
复制
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中这样做过,所以这就是我所能提供的所有帮助。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49625869

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档