如何在MS构建任务中使用NewtonSoft.json?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在MS构建任务中使用NewtonSoft.json?相关的知识,希望对你有一定的参考价值。

我有一个构建任务,我想在其中使用newtonsoft.json进行一些json序列化/反序列化,如下所示:

<UsingTask TaskName="ReplaceFileText" TaskFactory="CodeTaskFactory" AssemblyFile="$(MSBuildToolsPath)Microsoft.Build.Tasks.v4.0.dll">
    <ParameterGroup>
      <TargetFilename ParameterType="System.String" Required="true" />
      <SourceFilename ParameterType="System.String" Required="true" />
    </ParameterGroup>
    <Task>
      <Reference Include="System.Core" />

      <Using Namespace="System" />
      <Using Namespace="System.IO" />

      <Code Type="Fragment" Language="cs">
        <![CDATA[

            string sourceJsonString = File.ReadAllText(SourceFilename);
            string targetJsonString = File.ReadAllText(TargetFilename);

            dynamic sourceJson = JsonConvert.DeserializeObject(sourceJsonString);
            dynamic targetJson = JsonConvert.DeserializeObject(targetJsonString);

            targetJson.firstProperty = sourceJson.firstProperty;
            targetJson.secondProperty = sourceJson.secondProperty;


            targetJsonString = JsonConvert.SerializeObject(targetJson, Formatting.Indented);

            File.WriteAllText(targetFilename, targetJsonString);

          ]]>
      </Code>
    </Task>
  </UsingTask>

  <Target Name="TransformsWithStaging" BeforeTargets="Build">
    <ReplaceFileText TargetFilename="$(ProjectDir)appsettings.json" SourceFilename="$(ProjectDir)appsettings.Staging.json" />
  </Target>

上面的代码不起作用,因为我在上面的任务中使用了NewtonSoft.Json,这个任务没有引用。

如何在构建任务中导入或引用NewtonSoft.Json。我使用的是Visual Studio 2017 Professional,.NET Core 2.0,该项目是WebApi应用程序吗?

答案

如何在构建任务中导入或引用NewtonSoft.Json。

由于您使用的是Visual Studio 2017 Professional,.NET Core 2.0且该项目是WebApi应用程序,因此您可以在.csproj文件中找到以下代码段:

  <ItemGroup>
    <PackageReference Include="Microsoft.AspNetCore.All" Version="2.0.3" />
    <PackageReference Include="Newtonsoft.Json" Version="10.0.3" />
  </ItemGroup>

所以参考NewtonSoft.Json被添加到项目中。但是我们无法在任务中引用它。因为任务dll不能引用任何包 - 它们被加载到正在运行的msbuild实例中,并且只能引用托管msbuild实例可用的dll。有关详细信息,请参阅this thread

作为解决方法,您可以尝试直接从packages文件夹中引用dll文件:

    <Task>
        <Reference Include="C:Users<UseraName>.nugetpackages
ewtonsoft.json10.0.3lib
etstandard1.3Newtonsoft.Json.dll" />
        <Code Type="Fragment" Language="cs">...working fine...</Code>
    </Task>

希望这可以帮助。

另一答案

使用以下内容:

<UsingTask TaskName="ReplaceFileText" TaskFactory="CodeTaskFactory" AssemblyFile="$(MSBuildToolsPath)Microsoft.Build.Tasks.v4.0.dll">
    <ParameterGroup>
      <TargetFilename ParameterType="System.String" Required="true" />
      <SourceFilename ParameterType="System.String" Required="true" />
    </ParameterGroup>
    <Task>
      <Reference Include="System.Core" />
      <Reference Include="System.Runtime" />
      <Reference Include="System.Dynamic.Runtime" />
      <Reference Include="$(USERPROFILE).nugetpackagesmicrosoft.netcore.app2.0.0
ef
etcoreapp2.0System.ObjectModel.dll" />
      <Reference Include="$(USERPROFILE).nugetpackages
ewtonsoft.json10.0.3lib
etstandard1.3Newtonsoft.Json.dll" />
      <Reference Include="$(USERPROFILE).nugetpackagessystem.runtime.serialization.primitives4.1.1lib
etstandard1.3System.Runtime.Serialization.Primitives.dll" />

      <Using Namespace="System" />
      <Using Namespace="System.IO" />
      <Using Namespace="System.Collections.Specialized" />
      <Using Namespace="Newtonsoft.Json" />
      <Using Namespace="Newtonsoft.Json.Linq" />

      <Code Type="Fragment" Language="cs">
        <![CDATA[

            string sourceJsonString = File.ReadAllText(SourceFilename);
            string targetJsonString = File.ReadAllText(TargetFilename);

            JObject sourceJsonObject = JObject.Parse(sourceJsonString);
            JObject targetJsonObject = JObject.Parse(targetJsonString);

            targetJsonObject["someProperty"] = sourceJsonObject["someProperty"];

            File.WriteAllText(TargetFilename, targetJsonObject.ToString());

          ]]>
      </Code>
    </Task>
  </UsingTask>

  <Target Name="TransformsWithDevelopment" Condition="'$(Configuration)'=='Development'" BeforeTargets="Build">
    <ReplaceFileText TargetFilename="$(ProjectDir)appsettings.json" SourceFilename="$(ProjectDir)appsettings.Development.json" />
  </Target>

  <Target Name="TransformsWithStaging" Condition="'$(Configuration)'=='Staging'" BeforeTargets="Build">
    <ReplaceFileText TargetFilename="$(ProjectDir)appsettings.json" SourceFilename="$(ProjectDir)appsettings.Staging.json" />
  </Target>

  <Target Name="TransformsWithProduction" Condition="'$(Configuration)'=='Production'" BeforeTargets="Build">
    <ReplaceFileText TargetFilename="$(ProjectDir)appsettings.json" SourceFilename="$(ProjectDir)appsettings.Production.json" />
  </Target>

以上是关于如何在MS构建任务中使用NewtonSoft.json?的主要内容,如果未能解决你的问题,请参考以下文章

如何在线获取静态 MS-Access DB 并使用 PHP 连接到它?

如何使用 ms vc++ 编译器在 netbeans 中构建 dll 文件?

MS Access VBA - 在数据表子窗体中显示动态构建的 SQL 结果

如何设置验证规则:MS 访问中的“任务开始日期 >= 项目开始日期”

MS Access 报告 - 多个分组问题

如何在 Ant 构建任务中使用 -Xlint:unchecked 重新编译?