log 4 jログを切り取ってGUIコンポーネントに出力
ここ数日、自分が書いたネットワークワームにUI制御インタフェースを追加し、以前のワームコアはコマンドラインで起動していたので、ログ情報はlog 4 jから直接出力されたコンソールですが、UIがあれば、ログ情報をコンソールに出力することはできません.ログ情報を何らかの方法で切り取ってインタフェースに出力しなければなりません.
ネット上で関連コードを探してみると、確かに少なくありませんが、実践的な検証を経て、コードが多すぎて面倒なのか、性能が悪いのか(爬虫類の実行時に毎秒100行以上のログ情報が発生するのは勝手です)、ほとんど適用されません.仕方なく、自分で頭を絞って、やっとやっと使えるものを作った.今コードを貼って、勉強のために交流して、レンガを撮ることを歓迎します!
くだらないことは言わないで、コードを見てください.
このクラスはベースクラスであり、実際には直接使用できません.そのサブクラスがコンソールからのログ情報をUIコンポーネントに出力する責任を負います.
たとえば、ログ情報を切り取ってJLabelコンポーネントに出力する必要があります.コードは次のとおりです.
実際には、JTextAreaやMyEclipseやNetBeansなどのIDEなどの他のマルチテキストコンポーネントにログ情報を出力するのが一般的です.次のコードでは、ログを切り取ってJTextAreaコンポーネントに出力し、垂直スクロールバーを自動的に追従させる方法を示します.コードを参照してください:
上記のように封転した後、彼らの使用は非常に簡単です.フォームコンポーネントの描画が完了すると、次の操作を開始できます.
とても簡単な1つのDemo、ただ参考に供します.
以下は私のログ4 jログ構成情報です.
上記の方法に鑑みて、さらにカスタムlog 4 jログ出力機能を実現することができ、ここでは後述しない.
オリジナルの文章、転載は出典を明記してください:http://www.yshjava.cn/post/322.html
ネット上で関連コードを探してみると、確かに少なくありませんが、実践的な検証を経て、コードが多すぎて面倒なのか、性能が悪いのか(爬虫類の実行時に毎秒100行以上のログ情報が発生するのは勝手です)、ほとんど適用されません.仕方なく、自分で頭を絞って、やっとやっと使えるものを作った.今コードを貼って、勉強のために交流して、レンガを撮ることを歓迎します!
くだらないことは言わないで、コードを見てください.
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package cn.ysh.studio.gui.log;
import java.io.IOException;
import java.io.PipedReader;
import java.io.PipedWriter;
import java.io.Writer;
import org.apache.log4j.Logger;
import org.apache.log4j.Appender;
import org.apache.log4j.WriterAppender;
/**
*
* :
* log4j Appender Writer
* @author
* @date 2011-12-20
* @version 1.0
*/
public abstract class LogAppender extends Thread {
protected PipedReader reader;
public LogAppender(String appenderName) throws IOException {
Logger root = Logger.getRootLogger();
//
Appender appender = root.getAppender(appenderName);
//
reader = new PipedReader();
// , reader
Writer writer = new PipedWriter(reader);
// appender
((WriterAppender) appender).setWriter(writer);
}
}
このクラスはベースクラスであり、実際には直接使用できません.そのサブクラスがコンソールからのログ情報をUIコンポーネントに出力する責任を負います.
たとえば、ログ情報を切り取ってJLabelコンポーネントに出力する必要があります.コードは次のとおりです.
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package cn.ysh.studio.gui.log;
import java.io.IOException;
import java.util.Scanner;
import javax.swing.JLabel;
/**
*
* :
*
* JLabel
* @author
* @date 2011-12-20
* @version 1.0
*/
public class LabelLogAppender extends LogAppender {
private JLabel label;
/**
*
* @param label , JLabel
* @throws IOException
*/
public LabelLogAppender(JLabel label) throws IOException {
super("label");
this.label = label;
}
@Override
public void run() {
//
Scanner scanner = new Scanner(reader);
// JLabel
while (scanner.hasNextLine()) {
try {
//
Thread.sleep(100);
String line = scanner.nextLine();
label.setText(line);
line = null;
} catch (Exception ex) {
//
}
}
}
}
実際には、JTextAreaやMyEclipseやNetBeansなどのIDEなどの他のマルチテキストコンポーネントにログ情報を出力するのが一般的です.次のコードでは、ログを切り取ってJTextAreaコンポーネントに出力し、垂直スクロールバーを自動的に追従させる方法を示します.コードを参照してください:
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package cn.ysh.studio.gui.log;
import java.io.IOException;
import java.util.Scanner;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
/**
*
* :
*
* JTextArea
* @author
* @date 2011-12-20
* @version 1.0
*/
public class TextAreaLogAppender extends LogAppender {
private JTextArea textArea;
private JScrollPane scroll;
/**
*
* @param textArea , JTextArea
* @param scroll JTextArea , JTextArea , , ,
* @throws IOException
*/
public TextAreaLogAppender(JTextArea textArea, JScrollPane scroll) throws IOException {
super("textArea");
this.textArea = textArea;
this.scroll = scroll;
}
@Override
public void run() {
//
Scanner scanner = new Scanner(reader);
// JTextArea
while (scanner.hasNextLine()) {
try {
//
Thread.sleep(100);
String line = scanner.nextLine();
textArea.append(line);
textArea.append("
");
line = null;
//
scroll.getVerticalScrollBar().setValue(scroll.getVerticalScrollBar().getMaximum());
} catch (Exception ex) {
//
}
}
}
}
上記のように封転した後、彼らの使用は非常に簡単です.フォームコンポーネントの描画が完了すると、次の操作を開始できます.
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package cn.ysh.studio.gui.test;
import cn.ysh.studio.gui.log.LabelLogAppender;
import cn.ysh.studio.gui.log.TextAreaLogAppender;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
/**
*
* :
* UI
* @author
* @date 2011-12-24
* @version 1.0
*/
public class LogDemoJFrame extends JFrame {
private JLabel logLabel;
private JScrollPane logScrollPane;
private JTextArea logTextArea;
private final static Log log = LogFactory.getLog(LogDemoJFrame.class);
public LogDemoJFrame() {
logLabel = new javax.swing.JLabel();
logScrollPane = new javax.swing.JScrollPane();
logTextArea = new javax.swing.JTextArea();
setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
logLabel.setText(" ");
logTextArea.setColumns(20);
logTextArea.setRows(5);
logScrollPane.setViewportView(logTextArea);
javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
getContentPane().setLayout(layout);
layout.setHorizontalGroup(
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING).addGroup(layout.createSequentialGroup().addContainerGap().addComponent(logLabel, javax.swing.GroupLayout.DEFAULT_SIZE, 610, Short.MAX_VALUE).addContainerGap()).addComponent(logScrollPane, javax.swing.GroupLayout.Alignment.TRAILING, javax.swing.GroupLayout.DEFAULT_SIZE, 630, Short.MAX_VALUE));
layout.setVerticalGroup(
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING).addGroup(layout.createSequentialGroup().addContainerGap().addComponent(logLabel).addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED).addComponent(logScrollPane, javax.swing.GroupLayout.DEFAULT_SIZE, 305, Short.MAX_VALUE)));
pack();
}
public void initLog() {
try {
Thread t1, t2;
t1 = new LabelLogAppender(logLabel);
t2 = new TextAreaLogAppender(logTextArea, logScrollPane);
t1.start();
t2.start();
} catch (Exception e) {
JOptionPane.showMessageDialog(this, e, " ", JOptionPane.ERROR_MESSAGE);
}
}
public static void main(String[] s) {
LogDemoJFrame logDemoFrame = new LogDemoJFrame();
logDemoFrame.initLog();
logDemoFrame.setVisible(true);
for (int i = 0; i < 1000; i++) {
log.info(" :" + i);
}
}
}
とても簡単な1つのDemo、ただ参考に供します.
以下は私のログ4 jログ構成情報です.
log4j.appender.label=org.apache.log4j.ConsoleAppender
log4j.appender.label.layout=org.apache.log4j.PatternLayout
log4j.appender.label.layout.ConversionPattern=%m%n
log4j.appender.textArea=org.apache.log4j.ConsoleAppender
log4j.appender.textArea.layout=org.apache.log4j.PatternLayout
log4j.appender.textArea.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [ %p ] %m%n
log4j.rootLogger=INFO,label,textArea
上記の方法に鑑みて、さらにカスタムlog 4 jログ出力機能を実現することができ、ここでは後述しない.
オリジナルの文章、転載は出典を明記してください:http://www.yshjava.cn/post/322.html