在J2EE应用程序(例如在WebSphere中运行的应用程序)中,当我使用System.out.println()时,我的文本将转换为标准输出,由WebSphere管理控制台映射到一个文件。

在ASP中。NET应用程序(像一个运行在IIS), Console.WriteLine()的输出去哪里?IIS进程必须有一个stdin, stdout和stderr;但是stdout映射到/dev/null的Windows版本还是我在这里错过了一个关键的概念?

我不是问我是否应该在那里记录日志(我使用log4net),而是问输出到哪里?我最好的信息来自于这个讨论,他们说Console. setout()可以改变TextWriter,但它仍然没有回答控制台的初始值是什么,或者如何在配置/运行时代码之外设置它的问题。


当前回答

通过尝试将DataContext的Log输出更改为输出窗口,我发现了这个问题。所以对于其他想做同样事情的人,我所做的就是创建这个:

class DebugTextWriter : System.IO.TextWriter {
   public override void Write(char[] buffer, int index, int count) {
       System.Diagnostics.Debug.Write(new String(buffer, index, count));
   }

   public override void Write(string value) {
       System.Diagnostics.Debug.Write(value);
   }

   public override Encoding Encoding {
       get { return System.Text.Encoding.Default; }
   }
}

之后:dc. log = new DebugTextWriter(),我可以在输出窗口中看到所有的查询(dc是DataContext)。

看看这个,了解更多信息:http://damieng.com/blog/2008/07/30/linq-to-sql-log-to-debug-window-file-memory-or-multiple-writers

其他回答

除非你在一个严格的控制台应用程序中,否则我不会使用它,因为你无法真正看到它。我将使用Trace.WriteLine()用于调试类型的信息,这些信息可以在生产环境中打开和关闭。

当提到IISExpress时,每个人都感到困惑。没有什么可以读取控制台消息。例如,在ASPCORE MVC应用中,它使用appsettings进行配置。json,如果你正在使用IISExpress,它什么都不做。

现在你可以添加loggerFactory.AddDebug(LogLevel.Debug);在你的配置部分,它至少会显示你的日志在调试输出窗口。

好消息是CORE 2.0这一切都将改变:https://github.com/aspnet/Announcements/issues/255

在ASP中。NET应用程序,我认为它会转到输出或控制台窗口,在调试期间是可见的。

如果你使用System.Diagnostics.Debug.WriteLine(…)而不是Console.WriteLine(),那么你可以在Visual Studio的输出窗口中看到结果。

尝试附加一些“后端调试器”来记录您的msg或数据到控制台或输出窗口,就像我们在节点控制台中所做的那样。

System.Diagnostics.Debug。WriteLine("Message" +变量)代替Console.WriteLine()

这样你就可以在Visual Studio的输出窗口(控制台)中看到结果。