我正在使用PostSharp 6.4.5。我需要为现有项目添加方法级跟踪。我想记录何时输入和退出方法以及参数类型和值。我只能重建项目/解决方案,不能对代码进行任何更改。我遇到了一种通过使用XML添加方面来实现此目的的方法。
https://doc.postsharp.net/xml-multicasting
https://doc.postsharp.net/configuration-system
https://doc.postsharp.net/logging-customizing
使用这种方法,并遵循PostSharp的其他一些配置,我创建了一个postsharp.config,如下所示。
<Project xmlns="http://schemas.postsharp.org/1.0/configuration">
<Logging xmlns="clr-namespace:PostSharp.Patterns.Diagnostics;assembly:PostSharp.Patterns.Diagnostics">
<Profiles>
<LoggingProfile Name="detailed" IncludeSourceLineInfo="True" IncludeExecutionTime="True" IncludeAwaitedTask="True">
<DefaultOptions>
<LoggingOptions IncludeParameterType="True" IncludeThisValue="True" Level="Trace"/>
</DefaultOptions>
</LoggingProfile>
</Profiles>
</Logging>
</Project>
我还在 csproj 所在的同一目录中创建了一个 psproj 文件。以下是 psproj 文件的内容。
<Project xmlns="http://schemas.postsharp.org/1.0/configuration">
<Property Name="LoggingBackend" Value="console" />
<Using File=" absolute path to viewer dll PostSharp.Patterns.Diagnostics.Weaver.dll"/>
<Multicast>
<LogAttribute xmlns="clr-namespace:PostSharp.Patterns.Diagnostics;assembly:PostSharp.Patterns.Diagnostics" ProfileName="Default" AttributeTargetTypes="Mynamepace.*" />
</Multicast>
</Project>
然后,我重新生成项目并运行应用程序,但看不到任何跟踪信息。 如果我错过了什么,请告诉我。
第 1 步:我们构建了一个库,该库将使用 Postsharp 记录方法的进入和退出。例如:名称 -->程序集1。命名空间 --> PostSharp.Samples.CustomLogging
第 2 步:我们将此库引用添加到需要跟踪的所有项目中。我们还添加了后锐依赖项。所有这些更改都是以编程方式对 csproj 文件进行的。我们还在csproj文件中添加了对PostShrap.targets的引用,如下所示。
<Import Project="path to PostSharp.targets" />
第 3 步:在与 csproj 文件相同的目录中创建一个与 csproj 文件同名的 *.psproj 文件。该文件的内容如下所示。 程序集名称和命名空间从步骤 1 引用。 在 AttributeTargetTypes 中,可以指定正则表达式。所有与正则表达式匹配的方法都将在进入和退出时进行日志记录
<?xml version="1.0" encoding="utf-8"?>
<Project xmlns="http://schemas.postsharp.org/1.0/configuration">
<Multicast xmlns:my="clr-namespace:PostSharp.Samples.CustomLogging;assembly:Assembly1">
<my:LogMethodAttribute AttributeTargetTypes="*" />
</Multicast>
</Project>
步骤 4:重新生成项目。
对于许可证,需要创建一个包含许可证密钥的postsharp.config文件。此文件必须与 csproj 和 psproj 文件位于同一目录中。
现在,所有方法都将具有跟踪功能,而无需对源文件进行任何更改。 所做的所有更改都将在 csproj 文件上。
希望这有帮助。