这类似于过滤掉损坏的管道错误,但有一些复杂性 - 当用户在执行模板(html/template.Execute 或 text/template.Execute)时按下浏览器上的“停止”按钮时,会发生损坏的管道错误.
但是,我相信 text/template 包返回的错误只是 *errors.errorString 类型,因为损坏的管道消息似乎包含在其他一些信息文本中,因此无法对 net.OpErr 进行类型断言以进行比较目的。
例如,一个典型的破管错误字符串看起来像
write tcp 127.0.0.1:60739: broken pipe
执行模板返回的损坏管道错误字符串如下所示:
template: header.html:1:0: executing "header.html" at <div id="header...>: write tcp 127.0.0.1:60739: broken pipe
我有一个用 Go 编写的生产 Web 应用程序,并且厌倦了在我的其余错误日志中直观地过滤掉损坏的管道错误,但是现在我不知道如何过滤掉损坏的管道,而不是使用像 strings.Contains 这样的脏东西。