MSBUILD 发布 ERROR_USER_UNAUTHORIZED
Posted
技术标签:
【中文标题】MSBUILD 发布 ERROR_USER_UNAUTHORIZED【英文标题】:MSBUILD publish ERROR_USER_UNAUTHORIZED 【发布时间】:2017-06-16 13:31:24 【问题描述】:总结
我在 Windows Server 2016 上使用 9.2.0 Gitlab 的 CI 多运行程序。在通过 MSBUILD 发布 ASP.NET 项目的步骤中,我遇到了来自 IIS 的身份验证错误 ERROR_USER_UNAUTHORIZED
。但是当我在构建机器上使用CMD
窗口时,我会运行相同的发布命令——所有内容都已发布。不管我使用的是SYSTEM
还是ADMINISTRATOR
帐户。
重现步骤
-
设置 IIS 发布。
设置 Gitlab 的构建代理。
创建 Gitlab 的 YAML 构建脚本(见下文)。
运行构建。
实际行为
在发布步骤中,我遇到了 ERROR_USER_UNAUTHORIZED
错误。
预期行为
在发布步骤中,我已将 ASP.NET 发布到服务器。
相关日志和/或截图
C:\Program Files (x86)\Microsoft Visual Studio\2017\BuildTools\MSBuild\Microsoft\VisualStudio\v15.0\Web\Microsoft.Web.Publishing.targets(4292,5): msdeploy error ERROR_USER_UNAUTHORIZED: Не удалось выполнить задачу Web Deploy. (Выполнено подключение к удаленному компьютеру ("192.168.1.66") с использованием службы веб-управления, но не удалось авторизовать. Убедитесь, что вы используете правильные имя пользователя и пароль, что существует сайт, к которому выполняется подключение, и что учетные данные представляют пользователя, у которого есть разрешения на доступ к сайту. Дополнительные сведения: http://go.microsoft.com/fwlink/?LinkId=221672#ERROR_USER_UNAUTHORIZED.) [C:\Gitlab_Build_Agents\1\builds\2378ccf8\0\rushydro\aisa\Sources\Mvc\Mvc.csproj]
环境描述
我在 Windows 2016 上使用共享 Runner(gitlab-ci-multi-runner-windows-386,版本 9.2.0)。MSBUILD 是 Microsoft Visual Studio 2017 的一部分。
YAML 脚本
variables:
solution: Sources\Faso.sln
msbuild: C:\Program Files (x86)\Microsoft Visual Studio\2017\BuildTools\MSBuild\15.0\Bin\MSBuild.exe
nunit: C:\NUnit\NUnit.Framework-3.7.0\bin\net-4.5\nunitlite-runner.exe
nuget: C:\NuGet\nuget.exe
before_script:
- echo Setting encoding...
- echo %solution%
- echo Restoring NuGet packages...
- '"%nuget%" restore "%solution%"'
stages:
- build-test
- deploy-5023
build-test:
stage: build-test
script:
- chcp 65001
- echo Building...
- '"%msbuild%" "%solution%" /t:Build /p:Configuration=Release /p:TargetFramework=v4.5.2'
- echo Testing...
- dir /s /b *.Tests.dll | findstr /r Tests\\*\\bin\\ > testcontainers.txt
- 'for /f %%f in (testcontainers.txt) do "%nunit%" "%%f"'
except:
- tags
deploy-5023:
stage: deploy-5023
script:
- chcp 65001
- echo Deploying...
- '"%msbuild%" "%solution%" /p:DeployOnBuild=True /p:DeployTarget=MSDeployPublish /p:MsDeployServiceUrl=https://192.168.1.66:8172/msdeploy.axd /p:username=user /p:password=password /p:Configuration=Release /p:TargetFramework=v4.5.2 /p:AllowUntrustedCertificate=True /p:DeployIisAppPath=Faso /p:MSDeployPublishMethod=WMSVC /p:SkipExtraFilesOnServer=True /p:ExcludeFilesFromDeployment="Web.config;ConnectionStrings.config;system.config"'
when: manual
except:
- tags
artifacts:
expire_in: 1 week
paths:
- Sources\Mvc\App_Data\
- Sources\Mvc\bin\
- Sources\Mvc\Content\
- Sources\Mvc\favicon.ico
- Sources\Mvc\Global.asax
- Sources\Mvc\Web.config
【问题讨论】:
【参考方案1】:通过更改 MSBUILD 的参数顺序和格式来解决。
- '"%msbuild%" "%solution%" /p:DeployOnBuild=True;Username=username;Password=password;DeployTarget=MSDeployPublish;MsDeployServiceUrl=https://192.168.1.66:8172/msdeploy.axd;Configuration=Release;TargetFramework=v4.5.2;AllowUntrustedCertificate=True;DeployIisAppPath=Faso;MSDeployPublishMethod=WMSVC;SkipExtraFilesOnServer=True;ExcludeFilesFromDeployment="Web.config;ConnectionStrings.config;system.config"'
【讨论】:
在拉了很多头发之后(在 IDE 中发布工作,但不是在命令行中发布),我复制粘贴了您的命令,替换了参数,它就可以工作了。 @nurettin 另一个问题是我的密码。它包含一个感叹号 (!),它没有被 CMD 正确翻译并破坏了命令。 我也有一个带感叹号的密码,但它不会破坏命令行(我不使用 powershell 或 bash)。虽然我知道由于过去使用 bash 的经验,密码字符可能会破坏命令。以上是关于MSBUILD 发布 ERROR_USER_UNAUTHORIZED的主要内容,如果未能解决你的问题,请参考以下文章
使用 CruiseControl.NET 和 MSBuild 发布网站