【发布时间】:2017-01-07 22:28:26
【问题描述】:
我想在 JavaFX 的 TextArea 中显示 SLF4J 记录的错误。到目前为止,我在 logback-test.xml 中有一个appender:
<appender name="err" class="logtest.AppTA">
<filter class="logtest.ErrFilter" />
<encoder>
<pattern>%-4relative [%thread] %-5level %logger{35} - %msg%n</pattern>
</encoder>
</appender>
TextArea准备接收流:
public class Output extends OutputStream{
private final TextArea ta;
public Output(TextArea ta) {
this.ta = ta;
}
@Override
public void write(int b) throws IOException {
if (ta!=null) {
ta.appendText(String.valueOf((char) b));
}
}
}
和一个处理追加的类:
public class AppTA extends AppenderBase<ILoggingEvent> {
PatternLayoutEncoder encoder;
OutputStream os;
@Override
protected void append(ILoggingEvent event) {
try {
if (isEncoderInitialized) {
this.encoder.doEncode(event);
}
} catch (IOException e) {
}
}
@Override
public void start() {
if (this.encoder == null) {
addError("No encoder set for the appender named [" + name + "].");
return;
}
try {
encoder.init(os);
} catch (IOException ex) {
Logger.getLogger(AppTA.class.getName()).log(Level.SEVERE, null, ex);
}
super.start();
}
public PatternLayoutEncoder getEncoder() {
return encoder;
}
public void setEncoder(PatternLayoutEncoder encoder) {
this.encoder = encoder;
}
}
现在我遇到的问题是我的TextArea 在控制器类中,我不知道如何将它们链接在一起。特别是当 SLF4J 自己创建 AppTA 实例时 - 我真的没有办法将我的 TextArea 传递给记录器使用的 AppTA。
我该如何解决这个问题?
【问题讨论】:
标签: java javafx stream textarea slf4j