我正在尝试将范围界定的包发布到私有的Azure devops工件提要。我按照说明here。我有一个项目.npmrc,其中包含以下条目:

@my-scope:registry=https://pkgs.dev.azure.com/my-org/_packaging/my-feed/npm/registry/
@my-scope:always-auth=true


在我的全局用户.npmrc中,我具有以下条目:

prefix=/usr/local
strict-ssl=false
unsafe-perm=true
//registry.npmjs.org/:_authToken="my-real-token"
//pkgs.dev.azure.com/my-org/_packaging/my-feed/npm/registry/:username=${NPM_USERNAME}
//pkgs.dev.azure.com/my-org/_packaging/my-feed/npm registry/:_password="my-real-base64-token"
//pkgs.dev.azure.com/my-org/_packaging/my-feed/npm/registry/:email=${NPM_EMAIL}
//pkgs.dev.azure.com/my-org/_packaging/my-feed/npm/registry/:always-auth=true
@my-scope:registry=https://pkgs.dev.azure.com/my-org/_packaging/my-feed/npm/registry/
//pkgs.dev.azure.com/my-org/_packaging/my-feed/npm registry/:_authToken="my-real-base64-token"
cafile=${NPM_CERT_LOCATION}


当我尝试:npm publish时,出现以下错误:

Unable to authenticate, need: Bearer authorization_uri=https://login.windows.net/some-guid, Basic realm="https://pkgsprodcus1.pkgs.visualstudio.com/", TFS-Federated


根据以前的帖子,我看到我可能需要进行npm登录。执行npm登录会给我这个错误:

npm verb node v6.9.2
npm verb npm  v6.8.0
npm ERR! code E400
npm ERR! 400 Bad Request - PUT https://pkgs.dev.azure.com/my-org/_packaging/my-feed/npm/registry/-/user/org.couchdb.user:my-username


似乎相关的I looked at thisthis。但是,它们都不起作用。
我试过了:curl和curl -u这给了我以下错误:

{"$id":"1","innerException":null,"message":"TF400813: Resource not available for anonymous access. Client authentication required.","typeName":"Microsoft.TeamFoundation.Framework.Server.UnauthorizedRequestException, Microsoft.TeamFoundation.Framework.Server","typeKey":"UnauthorizedRequestException","errorCode":0,"eventId":3000}%


我也尝试使用代理和证书。但是,结果相同。

最佳答案

这有点旧,不确定是否仍然卡住,但是对于Windows,可以使用以下npm软件包:https://www.npmjs.com/package/vsts-npm-auth

npm install -g vsts-npm-auth
vsts-npm-auth -config path-to-your\.npmrc


这是来自Azure DevOps的更完整的文章,它引导您完成安装,.npmrc和身份验证以及发布:https://docs.microsoft.com/en-us/azure/devops/artifacts/npm/npmrc?view=azure-devops&tabs=windows

如果您是在Linux或Mac上进行开发,则不支持vsts-npm-auth,我们建议按以下方式为$ HOME / .npmrc生成令牌。
“连接到提要”对话框将生成格式正确的令牌,您可以将其放入.npmrc文件中,使用寿命为90天。


在Azure Artifacts中,选择“连接到源”。
选择npm。
选择生成npm凭据。复制凭据以将其手动添加到用户.npmrc文件中。对于Windows,它位于%USERPROFILE%.npmrc中,如果上述方法不起作用,则可能很有用。对于Linux,它位于$ HOME / .npmrc中。

08-27 07:38