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

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

?? log4j_usage_detail.txt

?? log4j使用文檔中的中上品。 包括:1
?? TXT
?? 第 1 頁 / 共 3 頁
字號:
package log4j;

import java.util.* ;
import java.io.* ;
import java.net.* ;

// add for log4j: import some package
import org.apache.log4j.PropertyConfigurator ;
import org.apache.log4j.Logger ;
import org.apache.log4j.Level ;

/**
 *
 * <p> Server With Log4j </p>
 * <p> Description: a sample with log4j</p>
 * @version 1.0
 */
public class ServerWithLog4j {

    final static int SERVER_PORT = 8001 ; // this server's port

    /*
    add for log4j: class Logger is the central class in the log4j package.
    we can do most logging operations by Logger except configuration.
    getLogger(...): retrieve a logger by name, if not then create for it.
    */
    static Logger logger = Logger.getLogger 
	( ServerWithLog4j.class.getName () ) ;

    /**
     *
     * @param args
     */
    public static void main ( String args[]) {
        String clientRequest = null ;
        BufferedReader reader = null ;
        PrintWriter writer = null ;
        ServerSocket server = null ;
        Socket socket = null ;

        InputStream in = null ;
        OutputStream out = null ;

        /*
        add for log4j: class BasicConfigurator can quickly configure the package.
        print the information to console.
        */
        PropertyConfigurator.configure ( "ServerWithLog4j.properties" ) ;

        // add for log4j: set the level
//        logger.setLevel ( ( Level ) Level.DEBUG ) ;

        try{
            server = new ServerSocket ( SERVER_PORT ) ;

            // add for log4j: log a message with the info level
            logger.info ( "ServerSocket before accept: " + server ) ;

            // add for log4j: log a message with the info level
            logger.info ( "Java server with log4j, on-line!" ) ;

            // wait for client's connection
            socket = server.accept() ;

            // add for log4j: log a message with the info level
            logger.info ( "ServerSocket after accept: " + server ) ;

            in = socket.getInputStream() ;
            out = socket.getOutputStream() ;

        } catch ( IOException e ) {

            // add for log4j: log a message with the error level
            logger.error ( "Server constructor IOException: " + e ) ;
            System.exit ( 0 ) ;
        }
        reader = new BufferedReader ( new InputStreamReader ( in ) ) ;
        writer = new PrintWriter ( new OutputStreamWriter ( out ), true ) ;

        // send welcome string to client
        writer.println ( "Java server with log4j, " + new Date () ) ;

        while ( true ) {
            try {
                // read from client
                clientRequest = reader.readLine () ;

                // add for log4j: log a message with the debug level
                logger.debug ( "Client says: " + clientRequest ) ;

                if ( clientRequest.startsWith ( "HELP" ) ) {

                    // add for log4j: log a message with the debug level
                    logger.debug ( "OK!" ) ;

                    writer.println ( "Vocabulary: HELP QUIT" ) ;
                }
                else {
                    if ( clientRequest.startsWith ( "QUIT" ) ) {

                        // add for log4j: log a message with the debug level
                        logger.debug ( "OK!" ) ;

                        System.exit ( 0 ) ;
                    }
                    else {

                        // add for log4j: log a message with the warn level
                        logger.warn ( "Command '" 
						+ clientRequest + "' not understood." ) ;

                        writer.println ( "Command '"
						+ clientRequest + "' not understood." ) ;
                    }
                }
            } catch ( IOException e ) {

                // add for log4j: log a message with the error level
                logger.error( "IOException in Server " + e ) ;

                System.exit ( 0 ) ;
            }
        }
    }
}

 

2.2.3. 配置文件 

2.2.3.1. 客戶程序配置文件


log4j.rootLogger=INFO, A1

log4j.appender.A1=org.apache.log4j.ConsoleAppender

log4j.appender.A1.layout=org.apache.log4j.PatternLayout

log4j.appender.A1.layout.ConversionPattern=%-4r %-5p [%t] %37c %3x - %m%n

 

2.2.3.2. 服務器程序配置文件


log4j.rootLogger=INFO, A1

log4j.appender.A1=org.apache.log4j.ConsoleAppender

log4j.appender.A1.layout=org.apache.log4j.PatternLayout

log4j.appender.A1.layout.ConversionPattern=%-4r %-5p [%t] %37c %3x - %m%n

 

2.3. 比較


比較這兩個應用可以看出,采用Log4j進行日志操作的整個過程相當簡單明了,與直接使用System.out.println語句進行日志信息輸出的方式相比,基本上沒有增加代碼量,同時能夠清楚地理解每一條日志信息的重要程度。通過控制配置文件,我們還可以靈活地修改日志信息的格式,輸出目的地等等方面,而單純依靠System.out.println語句,顯然需要做更多的工作。

下面我們將以前面使用Log4j的應用作為例子,詳細講解使用Log4j的主要步驟。

Log4j基本使用方法


Log4j由三個重要的組件構成:日志信息的優先級,日志信息的輸出目的地,日志信息的輸出格式。日志信息的優先級從高到低有ERROR、WARN、INFO、DEBUG,分別用來指定這條日志信息的重要程度;日志信息的輸出目的地指定了日志將打印到控制臺還是文件中;而輸出格式則控制了日志信息的顯示內容。

3.1.定義配置文件


其實您也可以完全不使用配置文件,而是在代碼中配置Log4j環境。但是,使用配置文件將使您的應用程序更加靈活。

Log4j支持兩種配置文件格式,一種是XML格式的文件,一種是Java特性文件(鍵=值)。下面我們介紹使用Java特性文件做為配置文件的方法:

配置根Logger,其語法為: 
log4j.rootLogger = [ level ] , appenderName, appenderName, …

其中,level 是日志記錄的優先級,分為OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定義的級別。Log4j建議只使用四個級別,優先級從高到低分別是ERROR、WARN、INFO、DEBUG。通過在這里定義的級別,您可以控制到應用程序中相應級別的日志信息的開關。比如在這里定義了INFO級別,則應用程序中所有DEBUG級別的日志信息將不被打印出來。 
appenderName就是指定日志信息輸出到哪個地方。您可以同時指定多個輸出目的地。 
配置日志信息輸出目的地Appender,其語法為 
log4j.appender.appenderName = fully.qualified.name.of.appender.class
log4j.appender.appenderName.option1 = value1
log4j.appender.appenderName.option = valueN
其中,Log4j提供的appender有以下幾種: 
org.apache.log4j.ConsoleAppender(控制臺), 
org.apache.log4j.FileAppender(文件), 
org.apache.log4j.DailyRollingFileAppender(每天產生一個日志文件),org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產生一個新的文件), 
org.apache.log4j.WriterAppender(將日志信息以流格式發送到任意指定的地方) 
配置日志信息的格式(布局),其語法為: 
log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
log4j.appender.appenderName.layout.option1 = value1
log4j.appender.appenderName.layout.option = valueN
其中,Log4j提供的layout有以下幾種: 
org.apache.log4j.HTMLLayout(以HTML表格形式布局), 
org.apache.log4j.PatternLayout(可以靈活地指定布局模式), 
org.apache.log4j.SimpleLayout(包含日志信息的級別和信息字符串), 
org.apache.log4j.TTCCLayout(包含日志產生的時間、線程、類別等等信息) 
3.2.在代碼中使用Log4j


下面將講述在程序代碼中怎樣使用Log4j。

3.2.1.得到記錄器 

使用Log4j,第一步就是獲取日志記錄器,這個記錄器將負責控制日志信息。其語法為:

public static Logger getLogger( String name),

通過指定的名字獲得記錄器,如果必要的話,則為這個名字創建一個新的記錄器。Name一般取本類的名字,比如:

static Logger logger = Logger.getLogger ( ServerWithLog4j.class.getName () ) ;

3.2.2.讀取配置文件 

當獲得了日志記錄器之后,第二步將配置Log4j環境,其語法為: 
BasicConfigurator.configure (): 自動快速地使用缺省Log4j環境。 
PropertyConfigurator.configure ( String configFilename) :讀取使用Java的特性文件編寫的配置文件。 
DOMConfigurator.configure ( String filename ) :讀取XML形式的配置文件。 

3.2.3.插入記錄信息(格式化日志信息) 

當上兩個必要步驟執行完畢,您就可以輕松地使用不同優先級別的日志記錄語句插入到您想記錄日志的任何地方,其語法如下:

Logger.debug ( Object message ) ; 
Logger.info ( Object message ) ; 
Logger.warn ( Object message ) ; 
Logger.error ( Object message ) ; 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产高清久久久久| 欧美在线观看视频一区二区| 欧美日韩在线播放三区四区| 中文字幕一区二区三区在线观看| 国产99精品国产| 国产精品麻豆视频| 91首页免费视频| 亚洲午夜在线电影| 欧美精选一区二区| 天堂成人国产精品一区| 欧美一区永久视频免费观看| 老司机午夜精品| 精品国产免费一区二区三区香蕉| 国产一区欧美一区| 国产精品久久久久久妇女6080 | 中文字幕av一区二区三区免费看 | 欧美日韩高清在线| 日本不卡高清视频| 久久综合九色综合欧美亚洲| 国产一区激情在线| 亚洲精选免费视频| 日韩午夜激情av| 成人av集中营| 亚洲成人一区二区在线观看| 日韩精品一区二区三区在线观看 | 国产日韩欧美精品在线| 成人午夜伦理影院| 久久久国产精品麻豆| 国产成人av影院| 一区二区国产盗摄色噜噜| 欧美一级视频精品观看| 国产精品99久久久久久似苏梦涵| 亚洲品质自拍视频| 欧美大片在线观看| 一区二区三区四区视频精品免费| 国产日韩欧美精品一区| 久久综合给合久久狠狠狠97色69| 777久久久精品| 欧美日本在线播放| 欧美日韩国产首页在线观看| 色先锋aa成人| 色婷婷久久综合| 91玉足脚交白嫩脚丫在线播放| 国产91综合一区在线观看| 激情六月婷婷久久| 国产一区二区0| 国产成人日日夜夜| 成人激情文学综合网| 国产91精品露脸国语对白| 国产成人精品午夜视频免费| 国产二区国产一区在线观看| 国产精品1区2区3区| 国产精品99久久久久久久vr| 国产a级毛片一区| 9色porny自拍视频一区二区| av一二三不卡影片| 色哟哟国产精品| 欧美性大战久久久久久久蜜臀| 欧美日韩在线一区二区| 欧美日韩免费观看一区三区| 欧美日韩国产片| 欧美日韩精品专区| 日韩精品一区二区三区蜜臀 | 国产丝袜美腿一区二区三区| 久久久午夜精品| 国产精品国产三级国产aⅴ中文| 国产精品污污网站在线观看| 国产精品高潮呻吟| 亚洲午夜免费视频| 九色porny丨国产精品| 国产成人在线视频网址| 99久久er热在这里只有精品66| 欧洲精品视频在线观看| 7777精品伊人久久久大香线蕉经典版下载| 7777女厕盗摄久久久| 欧美成人午夜电影| 国产精品三级在线观看| 亚洲高清免费在线| 久久福利资源站| 91美女福利视频| 日韩午夜av电影| 国产精品久久久久久久久免费相片| 伊人开心综合网| 九九热在线视频观看这里只有精品| av亚洲产国偷v产偷v自拍| 欧美午夜精品一区| 久久久高清一区二区三区| 亚洲欧美色综合| 久久99精品一区二区三区| av色综合久久天堂av综合| 欧美一区二区三区人| 国产精品水嫩水嫩| 欧美aaaaa成人免费观看视频| 国产夫妻精品视频| 欧美日韩成人在线| 欧美激情一区二区三区在线| 午夜久久电影网| 高清不卡一二三区| 制服丝袜亚洲网站| 亚洲图片欧美激情| 麻豆成人av在线| 成人一区二区三区中文字幕| 欧美日本精品一区二区三区| 欧美国产1区2区| 精品在线亚洲视频| 欧美专区亚洲专区| 国产精品色一区二区三区| 久久99国产精品久久99| 欧美日韩中文另类| 亚洲欧洲成人自拍| 国产精品一区二区果冻传媒| 欧美日韩国产首页在线观看| 国产精品高潮久久久久无| 国产乱对白刺激视频不卡| 欧美高清精品3d| 亚洲日本va在线观看| 国产在线精品一区二区| 制服丝袜av成人在线看| 亚洲综合色自拍一区| 北岛玲一区二区三区四区| 久久嫩草精品久久久精品一| 日日夜夜精品视频天天综合网| 91福利视频久久久久| 国产精品黄色在线观看| 国产宾馆实践打屁股91| 国产清纯白嫩初高生在线观看91 | 日韩免费观看高清完整版| 亚洲成av人片在www色猫咪| 成人黄色小视频在线观看| 欧美精品一区在线观看| 久久99久久精品| 精品国产乱码久久久久久闺蜜| 日本伊人色综合网| 欧美另类一区二区三区| 亚洲综合图片区| 色成年激情久久综合| 一区二区成人在线观看| 91毛片在线观看| 夜夜嗨av一区二区三区网页 | 自拍偷拍欧美激情| 99久久伊人精品| 一区在线观看免费| 99久精品国产| 亚洲美女在线一区| 色综合夜色一区| 亚洲少妇屁股交4| 99久久婷婷国产综合精品电影| 国产精品久久久久一区二区三区| 国产成人在线电影| 中文成人av在线| 成人精品视频网站| 亚洲人成影院在线观看| 在线观看欧美黄色| 日韩电影在线看| 欧美不卡一区二区三区四区| 韩国三级中文字幕hd久久精品| 精品三级av在线| 国产麻豆精品久久一二三| 国产日韩综合av| 91看片淫黄大片一级在线观看| 夜夜揉揉日日人人青青一国产精品| 欧美男生操女生| 奇米四色…亚洲| 欧美激情自拍偷拍| 色综合天天天天做夜夜夜夜做| 亚洲综合色噜噜狠狠| 91精品国产入口在线| 国产精品一区在线观看你懂的| 国产精品久久久久四虎| 在线中文字幕一区二区| 视频一区视频二区中文| 亚洲精品在线免费观看视频| 成人福利视频网站| 亚洲国产日韩av| 7777女厕盗摄久久久| 国产91丝袜在线播放0| 亚洲麻豆国产自偷在线| 欧美精品日韩一本| 国产福利91精品一区| 亚洲成人综合网站| 久久久久久9999| 欧美日韩综合一区| 国产乱妇无码大片在线观看| 亚洲黄色av一区| 精品久久久久香蕉网| 91在线视频播放地址| 久久精品国产精品青草| 亚洲欧洲99久久| 日韩三级精品电影久久久| 成人免费视频视频在线观看免费| 亚洲国产一二三| 国产精品色哟哟网站| 67194成人在线观看| 99精品视频在线播放观看| 免费成人性网站| 亚洲综合色在线| 国产欧美视频一区二区三区| 欧美日韩高清一区二区| 91在线无精精品入口| 国产一区二区在线电影|