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

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

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


当前回答

在调试模式下,有一个输出选项卡。

其他回答

使用控制台。Writeline并不适合我。

真正有帮助的是设置一个断点,然后在调试时运行测试。 当它到达断点时,您可以观察返回什么。

asp.net中的TraceContext对象。NET写入DefaultTraceListener,该DefaultTraceListener输出到主机进程的标准输出。如果使用Trace. write(),则不使用Console.Write()。写入后,输出会转到标准输出的进程。

您可以使用System.Diagnostics.Process对象来获取ASP. diagnostics . process对象。NET进程,并使用outputdatarecived事件监视标准输出。

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

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

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

默认情况下没有控制台监听。在调试模式下运行会附加一个控制台,但在生产环境中,正如您所怀疑的那样,消息不会去任何地方,因为没有任何东西在监听。

在调试模式下,有一个输出选项卡。