亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? logger.java

?? 這是基于 XLoadTree 的一個強大功能的展示的例子, 文件個頭也不大, 主要功能集中在 Web 前臺. 最終目標是實現一個易于使用的像 Windows 資源管理器那樣管理遠程 JSP
?? JAVA
字號:
/*
 * @(#)Logger 1.01 2005-4-9
 *
 * Copyright 2005 BeanSoft Studio. All rights reserved.
 * PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
 */

package beansoft.util.logging;

import java.io.Serializable;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.*;

/**
 * Logger, provides simple logging control function, only support log to console.
 * Because log4j is too big(larger than 300 KB) to use, so i decide not use it.
 * See static factory methods for details.
 * You might to change the log.properties file for log levels.
 * eg:
 * Logger.getLogger().debug("This is a debug");
 * studio.beansoft.util.logging.Logger.getLogger(this.getClass()).debug("something");
 * 
 * The log level is:
 * 
 * NONE>FATAL>ERROR>WARN>INFO>DEBUG>ALL
 * Chinese documents:
 * 日志記錄類, 提供簡單的日志控制宮女嘎, 只支持輸出日志到控制臺. 因為 log4j 用起來個頭太大
 * (大于 300 KB), 所以我決定不再使用它.
 * 請參閱那些靜態的工廠方法來獲取詳細信息.
 * 您可以修改 log.log.properties 文件來更改調試等級.
 * 
 * 無信息 > 致命 > 錯誤 > 警告 > 信息 > 調試 > 所有信息
 * 
 * @version 1.01
 * @author BeanSoft
 */
public class Logger implements Serializable {
    /** The logger name. */
    private final String name;
    
    /**
     * Cached instances of allocated logger objects.
     */
    private static Map loggerInstances = new TreeMap();
    
	private static final int NONE = 7;
	
    private static final int ALL = 1;

    private static final int FATAL = 6;

    private static final int ERROR = 5;

    private static final int WARN = 4;

    private static final int INFO = 3;

    private static final int DEBUG = 2;



    private static int logLevel = NONE;

    // Load log level from log.properties
    static {
        Properties props = new Properties();
        try {
            props.load(Logger.class.getResourceAsStream("log.properties"));
            String levelStr = props.getProperty("loglevel");

            if ("ALL".equalsIgnoreCase(levelStr)) {
                logLevel = ALL;
            } else if ("ERROR".equalsIgnoreCase(levelStr)) {
                logLevel = ERROR;
            } else if ("WARN".equalsIgnoreCase(levelStr)) {
                logLevel = WARN;
            } else if ("INFO".equalsIgnoreCase(levelStr)) {
                logLevel = INFO;
            } else if ("DEBUG".equalsIgnoreCase(levelStr)) {
                logLevel = DEBUG;
            } else if ("NONE".equalsIgnoreCase(levelStr)) {
                logLevel = NONE;
            } else if ("FATAL".equalsIgnoreCase(levelStr)) {
                logLevel = FATAL;
            }
            
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    /**
     * Creates new Logger the given logger name.
     * 
     * @param name
     *            the logger name.
     */
    protected Logger(final String name) {
        this.name = name;
        //this.loggerDelegate = getDelegatePlugin(name);
    }
    
    private String formatCurrentDate() {
        DateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
        return formatter.format(new Date());
    }

    /**
     * Added by BeanSoft.
     * 
     * @return the log level of this class
     */
    public int getLogLevel() {
        return logLevel;
    }

    /**
     * Return the name of this logger.
     * 
     * @return The name of this logger.
     */
    public String getName() {
        return name;
    }

    /**
     * Check to see if the DEBUG level is enabled for this logger.
     * 
     * @return true if a {@link #debug(Object)}method invocation would pass the
     *         msg to the configured appenders, false otherwise.
     */
    public boolean isDebugEnabled() {
        return getLogLevel() >= DEBUG;
    }

    /**
     * Issue a log msg with a level of DEBUG. Invokes log.log(Level.DEBUG,
     * message);
     */
    public void debug(Object message) {
        if (getLogLevel() <= DEBUG) {
            System.out.println(formatCurrentDate() + " " + getName() + ":debug:" + message);
        }
    }

    /**
     * Issue a log msg and throwable with a level of DEBUG. Invokes
     * log.log(Level.DEBUG, message, t);
     */
    public void debug(Object message, Throwable t) {
        if (getLogLevel() <= DEBUG) {
            System.out.println(formatCurrentDate() + " " + getName() + ":" + "debug:" + message);
            t.printStackTrace();
        }
    }

    /**
     * Check to see if the INFO level is enabled for this logger.
     * 
     * @return true if a {@link #info(Object)}method invocation would pass the
     *         msg to the configured appenders, false otherwise.
     */
    public boolean isInfoEnabled() {
        return getLogLevel() <= INFO;
    }

    /**
     * Issue a log msg with a level of INFO. Invokes log.log(Level.INFO,
     * message);
     */
    public void info(Object message) {
        if (getLogLevel() <= INFO) {
            System.out.println(formatCurrentDate() + " " + getName() + ":" + "info:" + message);
        }
    }

    /**
     * Issue a log msg and throwable with a level of INFO. Invokes
     * log.log(Level.INFO, message, t);
     */
    public void info(Object message, Throwable t) {
        if (getLogLevel() <= INFO) {
            System.out.println(formatCurrentDate() + " " + getName() + ":" + "info:" + message);
        	t.printStackTrace();
        }
    }

    /**
     * Issue a log msg with a level of WARN. Invokes log.log(Level.WARN,
     * message);
     */
    public void warn(Object message) {
        if (getLogLevel() <= WARN) {
            System.out.println(formatCurrentDate() + " " + getName() + ":" + "warn:" + message);
        }
    }

    /**
     * Issue a log msg and throwable with a level of WARN. Invokes
     * log.log(Level.WARN, message, t);
     */
    public void warn(Object message, Throwable t) {
        if (getLogLevel() <= WARN) {
	        System.out.println(formatCurrentDate() + " " + getName() + ":" + "warn:" + message);
	        t.printStackTrace();
        }
    }

    /**
     * Issue a log msg with a level of ERROR. Invokes log.log(Level.ERROR,
     * message);
     */
    public void error(Object message) {
        if (getLogLevel() <= ERROR) {
            System.err.println(formatCurrentDate() + " " + getName() + ":" + "error:" + message);
        }
    }

    /**
     * Issue a log msg and throwable with a level of ERROR. Invokes
     * log.log(Level.ERROR, message, t);
     */
    public void error(Object message, Throwable t) {
        if (getLogLevel() <= ERROR) {
            System.err.println(formatCurrentDate() + " " + getName() + ":" + "error:" + message);
            t.printStackTrace(System.err);
        }
    }

    /**
     * Issue a log msg with a level of FATAL. Invokes log.log(Level.FATAL,
     * message);
     */
    public void fatal(Object message) {
        if (getLogLevel() <= FATAL) {
            System.err.println(formatCurrentDate() + " " + getName() + ":" + "fatal error:" + message);
        }        
    }

    /**
     * Issue a log msg and throwable with a level of FATAL. Invokes
     * log.log(Level.FATAL, message, t);
     */
    public void fatal(Object message, Throwable t) {
        if (getLogLevel() <= FATAL) {
            System.err.println(formatCurrentDate() + " " + getName() + ":" + "fatal error:" + message);
            t.printStackTrace(System.err);
        }
    }

    /////////////////////////////////////////////////////////////////////////
    //                            Factory Methods
    /////////////////////////////////////////////////////////////////////////
    
    /**
     * Create a anonymous Logger instance.
     * Date: 2005-04-09
     */
    public static Logger getAnonymousLogger() {
        return getLogger("");
    }
    
    /**
     * Create a Logger instance given the logger name from cached instances.
     * 
     * @param name
     *            the logger name
     */
    public static Logger getLogger(String name) {
        Logger instance = (Logger) loggerInstances.get(name);
        
        if(instance == null) {
            instance = new Logger(name);
//            System.out.println(formatCurrentDate() + " " + instance + " not found, so create it!");
            loggerInstances.put(name, instance);
        }
        return instance;
    }

    /**
     * Create a Logger instance given the logger name with the given suffix.
     * 
     * <p>
     * This will include a logger seperator between classname and suffix
     * 
     * @param name
     *            The logger name
     * @param suffix
     *            A suffix to append to the classname.
     */
    public static Logger getLogger(String name, String suffix) {
        return getLogger(name + "." + suffix);
    }

    /**
     * Create a Logger instance given the logger class. This simply calls
     * create(clazz.getName()).
     * 
     * @param clazz
     *            the Class whose name will be used as the logger name
     */
    public static Logger getLogger(Class clazz) {
        return getLogger(clazz.getName());
    }

    /**
     * Create a Logger instance given the logger class with the given suffix.
     * 
     * <p>
     * This will include a logger seperator between classname and suffix
     * 
     * @param clazz
     *            The Class whose name will be used as the logger name.
     * @param suffix
     *            A suffix to append to the classname.
     */
    public static Logger getLogger(Class clazz, String suffix) {
        return getLogger(clazz.getName() + "." + suffix);
    }
    
    public String toString() {
        return getClass().getName() + "[" + getName() + "]";        
    }
    
    
    public static void main(String[] args) {
        Logger.getLogger(Logger.class).fatal("fatal");
		Logger.getLogger("test").error("error");
		Logger.getLogger("test").debug("debug");
    }

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美黄色影院| 懂色中文一区二区在线播放| 精品美女在线观看| 99久久综合狠狠综合久久| 亚洲成av人片在线观看| 日韩国产一区二| 国产性色一区二区| 欧美日韩一区二区在线观看视频| 老司机精品视频在线| 亚洲图片欧美激情| 精品国一区二区三区| 在线观看亚洲一区| 国产成人av电影在线播放| 日韩精品福利网| 综合色中文字幕| 久久综合成人精品亚洲另类欧美| 欧美性三三影院| 成人ar影院免费观看视频| 六月丁香婷婷久久| 午夜久久久久久| 亚洲欧美一区二区久久| 久久久久久久久岛国免费| 欧美精品黑人性xxxx| 91久久精品日日躁夜夜躁欧美| 国产精品自拍av| 久久精品免费观看| 天堂久久一区二区三区| 亚洲欧美中日韩| 国产亚洲欧洲997久久综合| 欧美一级视频精品观看| 欧美综合在线视频| 欧美性大战久久久久久久蜜臀| 不卡av在线免费观看| 国产成人精品三级| 国产成人日日夜夜| 国产美女娇喘av呻吟久久| 久久99精品国产.久久久久久 | 亚洲电影一级黄| 1024成人网| 综合av第一页| 亚洲女同女同女同女同女同69| 国产精品视频九色porn| 国产网红主播福利一区二区| 久久天天做天天爱综合色| 久久在线观看免费| 精品99一区二区三区| 日韩一级在线观看| 色婷婷精品久久二区二区蜜臀av | 狠狠色2019综合网| 午夜精品爽啪视频| 亚洲欧美另类综合偷拍| 国产精品成人免费在线| 国产拍揄自揄精品视频麻豆| 精品福利av导航| 日韩欧美亚洲一区二区| 欧美精品亚洲一区二区在线播放| 欧美优质美女网站| 欧美主播一区二区三区美女| 色吧成人激情小说| 91国产成人在线| 色哟哟一区二区| 国产成人激情av| 美日韩一区二区三区| 日日夜夜一区二区| 免费观看日韩电影| 韩国女主播成人在线| 美女性感视频久久| 激情综合亚洲精品| 狠狠色丁香婷综合久久| 高清视频一区二区| 97久久超碰国产精品电影| 91蝌蚪国产九色| 欧美亚洲国产一区二区三区| 欧美日韩另类一区| 欧美一区二区精品| 国产午夜精品一区二区三区视频 | 97久久精品人人澡人人爽| 91视频com| 欧美日本国产视频| 日韩欧美黄色影院| 国产精品免费丝袜| 亚洲麻豆国产自偷在线| 亚洲国产精品久久一线不卡| 亚洲精品国产视频| 日韩vs国产vs欧美| 国产精品99久久久久久宅男| 成人免费视频一区| 欧美三级在线看| 精品不卡在线视频| 中文字幕一区二| 亚洲6080在线| 国产精品91一区二区| 97久久精品人人做人人爽| 欧美精品一级二级| 欧美极品美女视频| 国产精品免费视频观看| 一区二区三区国产| 极品美女销魂一区二区三区| 91丨porny丨户外露出| 欧美日韩一区不卡| 国产亚洲欧美在线| 午夜视频一区二区| 国产91精品免费| 91精品婷婷国产综合久久竹菊| 久久久久久久电影| 午夜精品久久久| 久久精品999| 欧洲亚洲国产日韩| 国产偷国产偷亚洲高清人白洁| 一区二区三区中文字幕| 麻豆精品视频在线观看免费| 不卡一区中文字幕| 欧美一卡2卡三卡4卡5免费| 成人免费在线播放视频| 蜜桃视频一区二区| 欧美乱熟臀69xxxxxx| 专区另类欧美日韩| 成人国产精品免费观看动漫| 日韩美女视频一区二区在线观看| 中文字幕字幕中文在线中不卡视频| 亚洲尤物视频在线| 国产精品一区二区在线看| 欧美日韩国产中文| 亚洲天堂精品视频| 国产成人精品影视| 欧美刺激午夜性久久久久久久| 亚洲欧美另类综合偷拍| 大桥未久av一区二区三区中文| 欧美精品tushy高清| 亚洲精品日产精品乱码不卡| 国产成人在线观看| 日韩欧美中文字幕一区| 亚洲chinese男男1069| 色婷婷亚洲精品| 综合久久久久久| 国产成人免费9x9x人网站视频| 91精品国产综合久久精品麻豆 | 欧美影视一区二区三区| 国产精品久久久久精k8| 狠狠色丁香久久婷婷综| 日韩精品一区二区三区视频| 一区二区三区精品视频在线| 欧美色爱综合网| 夜夜爽夜夜爽精品视频| 91麻豆精东视频| 国产精品高潮久久久久无| 国产高清久久久久| 久久久午夜精品| 国产麻豆日韩欧美久久| 亚洲精品一区二区三区在线观看| 日韩中文字幕1| 欧美日韩一区二区三区视频| 一区二区国产视频| 在线观看欧美精品| 亚洲一区二区三区精品在线| 在线观看日韩精品| 亚洲午夜久久久久久久久久久| 色综合久久88色综合天天6| 亚洲男同性视频| 欧美午夜一区二区| 性欧美疯狂xxxxbbbb| 欧美精品国产精品| 久久99久久99小草精品免视看| 日本亚洲最大的色成网站www| 欧美无人高清视频在线观看| 亚洲成人自拍网| 91精品欧美久久久久久动漫| 日韩精品电影在线| 欧美一级专区免费大片| 国产在线精品一区二区三区不卡| 久久综合久久久久88| 精品中文字幕一区二区| 精品久久久久久亚洲综合网| 国产精选一区二区三区| 亚洲国产岛国毛片在线| 成人av网站免费| 亚洲高清久久久| 日韩欧美中文字幕制服| 国产精品99久久久久久久女警| 中文字幕在线不卡| 在线精品观看国产| 免费欧美在线视频| 26uuu色噜噜精品一区| 99re这里只有精品首页| 天天色图综合网| 久久久久久久久久久黄色| 99re热视频精品| 日韩在线一区二区| 久久久久综合网| 一本色道a无线码一区v| 亚洲午夜久久久久久久久电影院 | 激情欧美一区二区三区在线观看| 欧美极品少妇xxxxⅹ高跟鞋| 波多野结衣精品在线| 蜜臀国产一区二区三区在线播放| 国产精品污网站| 欧美日韩不卡一区| 国产成人久久精品77777最新版本| 一区二区三区波多野结衣在线观看| 欧美一区二区三区免费视频|