Nuget web.config.transform奇怪地合并dependentAssembly部分

时间:2012-11-07 17:05:17

标签: .net asp.net-mvc-3 web-config nuget

我刚创建了一个自定义nuget包,其目标是打包我们的Devart dlls s.t.我们在所有项目中都有适当的版本控制和更新机制。

Nuget包的结构是根据offical wiki上的说明,如下所示:

  • DevartOracle
    • 内容
      • web.config.transform
    • LIB
      • Devart.Data.Oracle.dll
      • ...
    • DevartOracle.nuspec

nuspec文件的内容或多或少如下:

<?xml version="1.0"?>
<package >
  <metadata>
    <id>DevartOracle</id>
    <version>6.70.311-pre6</version>
    <title>Devart Oracle dotConnect</title>
    ...
    <requireLicenseAcceptance>false</requireLicenseAcceptance>
    <description>Drivers from Devart for Oracle and Entity Framework</description>
    <releaseNotes></releaseNotes>
    <copyright>Copyright 2012</copyright>
    <tags></tags>
    <dependencies>
    </dependencies>
  </metadata>
</package>

实际上没什么特别的。我使用以下命令将nuget包发布到local repository

nuget pack DevartOracle.nuspec

dll的安装很好,但是我也想创建一个web.config合并。因此,我再次添加了文档中指定的web.config.transform文件,其中包含以下内容:

 <?xml version="1.0" encoding="utf-8"?>
  <configuration>
    <runtime>
      <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
        <dependentAssembly>
          <assemblyIdentity name="Devart.Data.Oracle" publicKeyToken="09af7300eec23701" culture="neutral" />
          <bindingRedirect oldVersion="0.0.0.0-6.70.311.0" newVersion="6.70.311.0" />
        </dependentAssembly>
      </assemblyBinding>
    </runtime>
    <system.data>
      <DbProviderFactories>
        <remove invariant="Devart.Data.Oracle" />
        <add name="dotConnect for Oracle" invariant="Devart.Data.Oracle" description="Devart dotConnect for Oracle" type="Devart.Data.Oracle.OracleProviderFactory, Devart.Data.Oracle, Version=6.70.311.0, Culture=neutral, PublicKeyToken=09af7300eec23701" />
      </DbProviderFactories>
    </system.data>
  </configuration>

问题

当我使用不存在或空<assemblyBinding>部分执行合并到web.config时,一切都按预期工作,但是当我有 - 比如说 - 已经存在以下内容时:

<runtime>
  <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
    <dependentAssembly>
      <assemblyIdentity name="EntityFramework" publicKeyToken="b77a5c561934e089" culture="neutral" />
      <bindingRedirect oldVersion="0.0.0.0-4.3.0.0" newVersion="4.3.0.0" />
    </dependentAssembly>
  </assemblyBinding>
</runtime>

然后合并的结果就是这个奇怪的结果:

<runtime>
  <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
    <dependentAssembly>
      <assemblyIdentity name="EntityFramework" publicKeyToken="b77a5c561934e089" culture="neutral" />
      <bindingRedirect oldVersion="0.0.0.0-4.3.0.0" newVersion="4.3.0.0" />
      <assemblyIdentity name="Devart.Data.Oracle" publicKeyToken="09af7300eec23701" culture="neutral" />
      <bindingRedirect oldVersion="0.0.0.0-6.70.311.0" newVersion="6.70.311.0" />
    </dependentAssembly>
  </assemblyBinding>
</runtime>

任何想法??


更新

微软员工和活跃的NuGet开发者在Twitter上发布了一个更新,可能值得在这里分享信息: https://twitter.com/dotnetjunky/status/266533404143656960

1 个答案:

答案 0 :(得分:2)

根据设计,NuGet只允许对现有XML文件附加更改(合并适用于任何XML类型的文件,无论扩展名是什么,只要您要合并的文件使用{filename}的惯例。{extension} .transform)。

这是因为NuGet还需要能够卸载包安装所做的更改(除非您在安装后手动修改了更改的文件,在这种情况下NuGet将保持不变卸载)。

这与您对XML Config Transforms的期望大不相同,这可能会引起混淆。

如果您希望在目标文件上进行真实转换,则必须执行PowerShell路由,并通过在程序包的tools文件夹中编写install.ps1和uninstall.ps1文件脚本来执行此操作。 / p>