3

私は現在、PostSharp 機能を追加したいプロジェクトに取り組んでいます。

Postsharp属性を次のように設定しました

[Serializable]
public class NLogTraceAttribute : OnMethodBoundaryAspect
{
    private readonly string _logLevel;
    ILogger logger;

    public NLogTraceAttribute(string logLevel)
    {
        _logLevel = logLevel;

        logger = new Logger("TraceAttribute");
    }

    public override void OnEntry(MethodExecutionArgs args)
    {
        LogAction("Enter", args);
    }

    public override void OnExit(MethodExecutionArgs args)
    {
        LogAction("Leave", args);
    }

    private void LogAction(string action, MethodExecutionArgs args)
    {
        var argumentsInfo = args.GetArgumentsInfo();

        logger.Log(_logLevel, "{0}: {1}.{2}{3}", action, args.Method.DeclaringType.Name, args.Method.Name, argumentsInfo);
    }
}

そしてそれを次のように使用しようとしています

    [NLogTrace(NLogLevel.Debug)]

ただし、プロジェクトをコンパイルすると、次のエラーが発生します。

    Error   26  Cannot serialize the aspects: Type 'NLog.Logger' in Assembly 
    'NLog, Version=2.0.0.0, Culture=neutral, PublicKeyToken=5120e14c03d0593c' 
    is not marked as serializable.. 

どんな助けでもいただければ幸いです

4

1 に答える 1

5
[NonSerialized]
public Logger logger;

上記のようにロガーを宣言すると、私が抱えていた問題が解決しました

于 2012-11-01T12:10:04.317 に答える