【问题标题】:Dotnet commands fail when restoring Nuget packages in shell script在 shell 脚本中还原 Nuget 包时,Dotnet 命令失败
【发布时间】:2020-12-02 19:00:42
【问题描述】:

上下文

我目前正在扩展我公司的 shell 脚本以在构建服务器上构建 .net 解决方案。 该解决方案由多个项目组成,有些项目需要构建和发布,有些则不需要。 这些项目的框架也各不相同,因为有些是用 .net Framework 编写的,而最新的是 .net Core 编写的。 我已将 shell 脚本扩展为以下内容:

msbuild.exe VirtualLaundry.sln

#Build .net framework projects 

for project in Planbord Webportal WebportalCentraal RFIDReader
do
    mkdir -pv publish/$project
    msbuild.exe /t:"Build" /p:PipelineDependsOnBuild=False /p:UseWPP_CopyWebApplication=True /p:PrecompileBeforePublish=True /p:OutDir="$(cygpath -aw $project/bin)" /p:WebProjectOutputDir="$(cygpath -aw publish/$project)" $project/$project.csproj
    rm -rf publish/$project/App_GlobalResources
    rm -f $project.zip
    
    mkdir -pv publish/$project/Config
    cp -v source/$project/Web.config publish/$project/Config

    echo "test" > publish/$project/versie.txt
    if [[ ${shortversion:0:1} == [0-9] ]]
    then
            echo ${shortversion} > publish/$project/versie.txt
    fi
    
    (cd publish/$project && zip -r ../../$project.zip .)
done

# Build .net Core projects
echo Building .Net Core projects
for project in VL.API
do
    echo $PWD
    dotnet publish $project/$project.csproj -o publish 
done

# Zip .net Core projects and remove old build output
for project in VL.API
do
    echo $PWD
    cd publish
    zip -r ../VL.API.zip ./
    cd ..
rm -r publish
done

问题

执行此shell时,它会返回以下错误:

+ echo Building .Net Core projects
Building .Net Core projects
+ for project in VL.API
+ echo /home/90105-091/build/p-019-220/release/source
/home/90105-091/build/p-019-220/release/source
+ dotnet publish VL.API/VL.API.csproj -o publish
Microsoft (R) Build Engine version 16.7.0+7fb82e5b2 for .NET
Copyright (C) Microsoft Corporation. All rights reserved.

  Determining projects to restore...
C:\Program Files\dotnet\sdk\3.1.403\NuGet.targets(128,5): error : Unable to load the service index for source https://api.nuget.org/v3/index.json. [C:\home\90105-091\build\p-019-220\release\source\VL.API\VL.API.csproj]
C:\Program Files\dotnet\sdk\3.1.403\NuGet.targets(128,5): error :   Value cannot be null. (Parameter 'path1') [C:\home\90105-091\build\p-019-220\release\source\VL.API\VL.API.csproj]

起初我认为 Nuget API 地址 (https://api.nuget.org/v3/index.json) 被服务器阻止了,但我已经解决了这个问题。 我已经在堆栈溢出和互联网的其他地方搜索了解决方案,但这些解决方案不起作用或不适用于我的问题。

参考:

我怀疑可能存在 CLI 未显示的其他问题,但坦率地说,我不确定。

但我的问题是(可能)导致此问题的原因是什么?

【问题讨论】:

    标签: shell nuget-package-restore dotnet-cli


    【解决方案1】:

    经过一番折腾,我发现脚本中抛出的错误是由对 NuGetScratch 文件夹的访问权限引起的,我的 Windows 帐户无权访问该文件夹。由于 Nuget 从该锁定文件夹恢复它的包,它无法恢复任何包,因此构建失败。更改访问权限后,错误消失了,所以我唯一的猜测是“值不能为空。(参数'path1')”错误是一个有点通用的错误,并没有真正显示潜在的问题。

    【讨论】:

      猜你喜欢
      • 2018-12-17
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2018-12-07
      相关资源
      最近更新 更多