有时候我们在开发中需要将类库打包成nuget包供其他项目使用。这种看似很很好,那么如果类库修改了,即使代码可以运行并成功打包出了新版本,这虽然看起来一切正常,但我们没办法确保这次的修改是安全的也是兼容旧版本的。微软也意识到了这一点,因此就在.Net6中提供了包验证工具,帮我们检测包的安全性和兼容性。下面我们就来看一下怎么使用:
其实使用方式非常简单,只需在项目文件中加入```EnablePackageValidation``属性即可:
<EnablePackageValidation>true</EnablePackageValidation>
.NET6中的包验证工具提供了三种验证器:
- Baseline version validator:根据以前发布的稳定版本的软件包验证类库项目;
- Compatible framework validator: 一个框架版本编译的代码可以在包中其他框架版本上运行;
- Compatible runtime validator:特定于运行时的实现程序集是否兼容以及是否与编译时程序集兼容。
这里我们以Baseline version validator为例来讲解一下包验证该怎么用。我们的初版代码如下:
public class D { public void Demo(int one ,int two) { int sum=one+two; Console.WriteLine($"{one}+{two}={sum}"); } }
在第二版本中,我们给方法增加乘运算:
public class D { public void Demo(int one ,int two,int three) { int sum=one+two; int mul=sum * three; Console.WriteLine($"{one}+{two}={sum}"); Console.WriteLine($"{sum }*{three}={mul}"); } }
代码很简单,当我们发布新版本后,就会出现引用了这个包的项目也包含引用过1.0.0版本的其他类库,这时运行时很可能出现异常。
当我们在项目文件中加入Baseline version validator时这个问题就解决了。项目文件修改内容如下:
<Project Sdk="Microsoft.NET.Sdk"> <PropertyGroup> <TargetFramework>net6.0</TargetFramework> <PackageVersion>1.1.0</PackageVersion> <EnablePackageValidation>true</EnablePackageValidation> <PackageValidationBaselineVersion>1.0.0</PackageValidationBaselineVersion> </PropertyGroup> </Project>
文件中的PackageValidationBaselineVersion
是用于对比的基线版本。当我们使用dotnet pack打包时,将收到如下错误提示:
error CP0002: Member 'ClassLibrary1.D.Demo(int,int)' exists on [Baseline] lib/net6.0/ClassLibrary1.dll but not on lib/net6.0/ClassLibrary1.dll
按照提示的信息进行如下修改即可:
public class D { public void Demo(int one ,int two) { int sum=one+two; Console.WriteLine($"{one}+{two}={sum}"); } public void Demo(int one ,int two,int three) { int sum=one+two; int mul=sum * three; Console.WriteLine($"{one}+{two}={sum}"); Console.WriteLine($"{sum }*{three}={mul}"); } }
总结
包验证工具允许我们在开发包的程中验证包是否一致且格式良好。它允许我们根据以前的版本和框架版本以及运行时来验证包。