如何将调试信息输出到富文本框

本文关键字:文本 输出 信息 调试 | 更新日期: 2023-09-27 18:33:38

我正在创建一个FTP客户端,我希望通过输出调试信息将响应输出到RichTextBox。

有人能帮助如何做到这一点吗?谢谢

public FileARK()
{
    InitializeComponent();
    hostAddress.Text = "host";
    UserName.Text = "foo";
    Password.Text = "bar";
    //FtpTrace.AddListener(new TextWriterTraceListener(responseWindow.Text));
   // Debug.WriteLine(responseWindow.Text);
}
private void Connect_Click(object sender, EventArgs e)
{
    conn = new FtpClient();
    conn.Host = hostAddress.Text;
    conn.Credentials = new NetworkCredential(UserName.Text, Password.Text);
    conn.Connect();

}
private void Disconnect_Click(object sender, EventArgs e)
{
    conn.Disconnect();
}
private void responseWindow_TextChanged(object sender, EventArgs e)
{
}

如何将调试信息输出到富文本框

您可以实现自己的TraceListener,该在 app.config 中配置,并动态尝试查找与配置中的名称匹配的富文本框。

您的类可能如下所示:

public class TextBoxListener : TraceListener
{
    RichTextBox _box;
    string _data;
    public TextBoxListener(string initializeData)
    {
        _data = initializeData;
    }
    private bool Init()
    {
        if (_box != null && _box.IsDisposed )
        {
            // back to null if the control is disposed
            _box = null;
        }
        // find the logger text box
        if (_box == null)
        {
            // open forms
            foreach (Form f in Application.OpenForms)
            {
                // controls on those forms
                foreach (Control c in f.Controls)
                {
                    // does the name match 
                    if (c.Name == _data && c is RichTextBox)
                    {
                        // found one!
                        _box = (RichTextBox) c;
                        break;
                    }
                }
            }
        }
        return _box != null && !_box.IsDisposed;
    }
    public override void WriteLine(string message)
    {
        if (Init())
        {
            _box.Text = _box.Text + message + "'r'n";
        }
    }
    public override void Write(string message)
    {
        if (Init())
        {
            _box.Text = _box.Text + message;
        }
    }
}

此类最重要的部分是 Init 方法,该方法循环访问所有 openforms 和所有控件,以查找与 app.config 中配置的名称匹配的富文本框控件。

若要使用此类,请在 app.config 中配置跟踪并添加侦听器

<system.diagnostics>
    <trace>
      <listeners>
        <add name="box" 
             type="WindowsFormsApplication1.TextBoxListener, WindowsFormsApplication1" 
             initializeData="loggerRTB" />
      </listeners>
    </trace>
  </system.diagnostics>

该类型是类的完全限定类型名(Namespace.Classname、AssemblyName(,在 initializeData 中,您将在窗体上添加富文本框控件的名称。在我的示例应用程序中,它是记录器RTB

在您的应用程序中,您现在可以使用标准Trace类:

Trace.WriteLine("Hello world");

请注意,TextBoxListener仅在第一次调用 Trace.WriteLine 时实例化。

此方法的好处之一是可以添加多个侦听器,这些侦听器写入不同的 RichTextBox 控件,即使在单独的窗体上也是如此(假设这些窗体是打开的(。