Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/tfs/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Express 使用快速ntlm身份验证对TFS api进行身份验证_Express_Tfs_Ntlm_Express Ntlm - Fatal编程技术网

Express 使用快速ntlm身份验证对TFS api进行身份验证

Express 使用快速ntlm身份验证对TFS api进行身份验证,express,tfs,ntlm,express-ntlm,Express,Tfs,Ntlm,Express Ntlm,使用express和express ntlm,如何创建http://localhost:3000/api/bug/通过点击TFS api在TFS中为我创建错误的端点 我现在可以使用request ntlm promise实现这一点,我就是这样做的 const ntlm = require('request-ntlm-promise'); const ntlmOptions = { username: 'myUserName', password: 'myPassword', url

使用
express
express ntlm
,如何创建
http://localhost:3000/api/bug/
通过点击TFS api在TFS中为我创建错误的端点

我现在可以使用
request ntlm promise
实现这一点,我就是这样做的

const ntlm = require('request-ntlm-promise');

const ntlmOptions = {
  username: 'myUserName',
  password: 'myPassword',
  url: 'http://tfsinstance/collection/project/_apis/wit/workitems/$bug?api-version=4.1',
  headers: {
    'Content-Type': 'application/json-patch+json'
  }
};

const tfsBugObject =[{
  'op': 'add',
  'path': '/fields/System.Title',
  'value': 'Test title'
}, {
  'op': 'add',
  'path': '/fields/Microsoft.VSTS.TCM.SystemInfo',
  'value': 'Test system info'
}, {
  'op': 'add',
  'path': '/fields/Microsoft.VSTS.TCM.ReproSteps',
  'value': 'test reproduction steps'
}];

ntlm.post(ntlmOptions, tfsBugObject).then((response) => { return res.send(response); });
问题是我必须在
ntlmOptions
对象中提供用户名和密码。这样做不会因为当前用户点击express API而在TFS中创建bug,而是因为用户“myUserName”而创建bug

使用
expressntlm
包,是否可以执行
http.post
http://tfsinstance/collection/project/...
是否使用从该软件包返回的NTLM凭据

TFS需要身份验证才能使用API

使用
expressntlm
我希望我能做到以下几点

const express = require('express');
const ntlm = require('express-ntlm');
const http = require('http');
const app = express();

app.use(ntlm({ domain: 'mydomain', domaincontroller: 'ldap://domaincontroller' });
然后


express ntlm
充当客户端和域控制器之间的代理。因此,域控制器将处理与客户端的身份验证,而代码> Express NTLM 只是充当中间人,直到验证成功。
如果您可以使用某种API用户并使用
express ntlm
获取正确的用户名并将其传递给TFS API,这将是最简单的方法,否则,我建议您在客户端和TFS API之间创建自己的代理。

express ntlm
充当客户端和域控制器之间的代理。因此,域控制器将处理与客户端的身份验证,而代码> Express NTLM 只是充当中间人,直到验证成功。 如果您可以使用某种API用户并使用
express ntlm
来获取正确的用户名并将其传递给TFS API,这将是最简单的方法,否则我建议您在客户端和TFS API之间创建自己的代理

httpOptions = {
    protocol: 'http',
    hostname: 'tfsinstance',
    pathname: '/collection/project/_apis/wit/workitems/$bug?api-version=4.1',
    port: 8080,
    method: 'POST',
    headers: {
        'Content-Type': 'application/json-patch+json'
    }
};

app.post('/report/bug', (req, res, next) => {
    const request = http.request(httpOptions, (response => {
        response.on('data', data => {
            // return response from TFS through express to user
        });
    }));
});