java日志记录,并将该记录输出到自定义的窗口中(二)

package logger;

import java.awt.*;
import java.awt.event.*;
import java.io.*;
import java.util.logging.*;

import javax.swing.*;

public class LoggingImageViewer {
 public static void main(String[] args) {
  if(System.getProperty("java.util.logging.config.class") == null
    && System.getProperty("java.util.logging.config.file") == null) {
   try {
    Logger.getLogger("logger").setLevel(Level.ALL);
    final int LOG_ROTATION_COUNT = 10;
    Handler handler = new FileHandler("%h/LoggingImageViewer.log", 0, LOG_ROTATION_COUNT);
    Logger.getLogger("logger").addHandler(handler);
   } catch (IOException e) {
    Logger.getLogger("logger").log(Level.SEVERE, "Can't create log file handler.", e);
   }
  }
  
  EventQueue.invokeLater(new Runnable() {
   @Override
   public void run() {
    Handler windowHandler = new WindowHandler();
    windowHandler.setLevel(Level.ALL);
    Logger.getLogger("logger").addHandler(windowHandler);
    
    JFrame frame = new ImageViewerFrame();
    frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
    
    Logger.getLogger("logger").fine("Showing frame");
    frame.setVisible(true);
   }
  });
 }
}

class WindowHandler extends StreamHandler {
 public WindowHandler() {
  frame = new JFrame();
  final JTextArea output = new JTextArea();
  output.setEditable(false);
  frame.setSize(200, 200);
  frame.add(new JScrollPane(output));
  frame.setFocusableWindowState(false);
  frame.setVisible(true);
  //安装一个流,该流的write方法将流显示输出到output
  setOutputStream(new OutputStream() {
   @Override
   public void write(int b) throws IOException {
    
   }
   
   @Override
   public void write(byte[] b, int off, int len) {
    output.append(new String(b, off, len));
   }
  });
 }
 
 //强制刷新
 @Override
 public void publish(LogRecord record) {
  if(!frame.isVisible()) {
   return;
  }
  super.publish(record);
  flush();
 }
 
 private JFrame frame;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值