TraceSource и ASP.NET: работает для веб-приложений, а не для веб-сайтов - PullRequest
3 голосов
/ 17 марта 2011

Я добавляю функцию трассировки на веб-сайт ASP.NET, поэтому я решил исследовать TraceSource , создав пару прототипов; проект веб-приложения и проект веб-сайта.

Я использую аналогичный файл Web.config для каждого проекта для записи трассировок в журнал событий Windows:

<configuration>
    <system.web>
        <compilation debug="true" strict="false" explicit="true" targetFramework="4.0"/>
    </system.web>    
    <system.diagnostics>
        <trace autoflush="true" />
        <sources>
            <source name="HelloWorld">
                <listeners>
                    <add name="eventlogListener" />
                </listeners>
            </source>
        </sources>    
        <sharedListeners>
            <add name="eventlogListener" type="System.Diagnostics.EventLogTraceListener" initializeData="My Source" />
        </sharedListeners>
    </system.diagnostics>
</configuration>

Я просто начинаю со следующей базовой трассировки:

private static TraceSource _ts = new TraceSource("HelloWorld", SourceLevels.All);

protected override void OnLoad(EventArgs e)
{
    base.OnLoad(e);

    _ts.TraceEvent(TraceEventType.Information, 10, "Greetings from OnLoad.");
}

В проекте веб-приложения я вижу трассировку, созданную в журнале событий. Однако с проектом Веб-сайта я не могу.

Требуются ли дополнительные шаги (например, настройки web.config, разрешения и т. Д.) В проектах веб-сайта для использования TraceSource?

Ответы [ 2 ]

7 голосов
/ 10 мая 2011

Причина этого в том, что методы Trace компилируются .Net, только если константа TRACE определена как часть компиляции. В проекте веб-сайта способ сделать это - включить конфигурацию компилятора в ваш файл web.config, например:

  <system.codedom>
    <compilers>
      <compiler
         language="c#;cs;csharp"
         extension=".cs"
         type="Microsoft.CSharp.CSharpCodeProvider, System, Version=2.0.50727.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
         compilerOptions="/d:TRACE"
         warningLevel="1" />
    </compilers>
  </system.codedom>

Обратите внимание на параметр компилятора "/ d: TRACE", который включает константу TRACE при компиляции вашего кода (C # в этом примере).

0 голосов
/ 17 марта 2011

После некоторых проб и ошибок, по-видимому, в web.config требуется узел system.codedom \ compilers, но я не совсем уверен, почему.

...