10

我们正在尝试使用 AOP(顺便说一下 PostSharp,但这个问题与任何 AOP 框架有关)在我们的应用程序中实现日志记录。

我们面临的问题是我们得到的信息是这样的:

输入带有参数的方法 XXX:

  • 参数内容,如果它是一个值类型。
  • 如果完成,则 ToString() 中的任何内容都会覆盖。
  • 如果 ToString() 未被覆盖,则为类名。

这个信息不是很有用,因为通常我们得到的是第三种情况。我们也在创造大量无用的信息。

如果您使用 AOP 登录任何产品,您是如何解决这个问题的?

提前致谢。

4

2 回答 2

6

几种方法:

  • 在要记录的类型上放置一个通用接口。(例如 ILoggable)。实现该接口将使您的方面能够准确记录您想要的内容。缺点是您必须为可能记录的每个对象实现/维护 ILoggable。

  • 使用反射(这是我在博客上的这个审计示例中所做的。它使用 MVC ActionFilter,但原理相同)。博文中详细说明了权衡取舍,但基本上它是使用反射和性能问题的复杂性,具体取决于您记录的数量和频率。

  • 使用序列化。给定一个对象,将其序列化为 Json 或 XML 或其他格式,并记录该字符串。根据您对日志的处理方式,这可能从完美到毫无价值,并且取决于序列化的工作方式和对象的复杂程度,这也可能是一个性能问题。

于 2014-01-30T22:25:03.227 回答
1

我致力于一种新型的 AOP 框架,以应对现有 AOP 框架缺失的特性。你可以在这里找到我的开源项目:NConcern .NET AOP Framework

与其他人的区别之一是允许您使用 System.Linq.Expression 开发您的建议,以避免基于类型的装箱/拆箱、反射和哈希跳转。对于初学者来说使用 Expression 进行开发有点困难,但对于高级开发人员来说却很容易。

Example 一个简单的日志记录示例(进入控制台),无需重写您的业务、反射和装箱。

一个企业:计算器

public class Calculator
{
    public int Add(int a, int b)
    {
        return a + b;
    }
}

您的日志记录方面由 linq 表达式实现,以描述 Advice 必须如何工作。

public class Logging : IAspect
{
    //this is not an advice, this method is called to produce advices
    public IEnumerable<IAdvice> Advise(MethodInfo method)
    {
        //generic presentation method
        var presentation = typeof(Presentation). GetMethod("Of");

        //example log on exception
        //instance, arguments and exception are Expressions
        yield return Advice.Linq.After.Throwing((instance, arguments, exception) =>
        {
            Expression.Call
            (
                typeof(Console).GetMethod("WriteLine",...),
                Expression.Call
                (
                    typeof(string).GetMethod("Concat", new Type[] { typeof(string[]) }),
                    Expression.NewArrayInit(typeof(string), arguments.Select(argument => argument.Type == typeof(string) ? argument : ...).ToArray())
                )
            )
        }
    }
}
于 2016-12-13T10:33:21.243 回答