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

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

?? 使用log4j進行日志操作.txt

?? 對 網絡編程 時錯誤 有很大幫助的
?? TXT
?? 第 1 頁 / 共 2 頁
字號:
            logger.debug ( "HELP" ) ;

            writer.println ( "HELP" ) ;
            response = reader.readLine () ;

            // add for log4j: log a message with the debug level
            logger.debug ( "Server responds: '" + response + "'") ;

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

            writer.println ( "QUIT" ) ;
        } catch ( IOException e ) {

            // add for log4j: log a message with the warn level
            logger.warn ( "IOException in client.in.readln()" ) ;

            System.out.println ( e ) ;
        }
        try {
            Thread.sleep ( 2000 ) ;
        } catch ( Exception ignored ) {}
    }
}
 


2.2.2. 服務器程序 


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 ) ; 



 


 回頁首 
 



參考資料 

如果您想更深入地了解Log4j,請經常訪問下面提及的相關鏈接。

Log4j項目主頁------------------------------------------------------ www.log4j.org 

Log4j FAQ ------------------------------------------------------- www.log4j.org/log4j/faq.html 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区国产| 亚洲成人av在线电影| 麻豆传媒一区二区三区| 日韩一区二区三区免费观看| 青青草国产精品97视觉盛宴| 精品国精品自拍自在线| 国产精品一区二区在线观看不卡 | 欧美日韩一二三区| 一色桃子久久精品亚洲| 成人动漫在线一区| 欧美经典一区二区三区| 色综合天天综合给合国产| 伊人色综合久久天天人手人婷| 在线观看国产一区二区| 视频一区欧美精品| 国产三级精品视频| 欧美日韩在线播放三区| 黄网站免费久久| 亚洲黄一区二区三区| 日韩一区二区免费高清| 国产成人自拍网| 亚洲福利国产精品| 国产亚洲综合av| 欧美三级在线视频| 国产乱码精品一区二区三| 亚洲黄色免费电影| 久久―日本道色综合久久| 色哦色哦哦色天天综合| 久久精品国产99久久6| 国产福利一区二区| 亚洲精品少妇30p| 欧美日韩高清一区二区三区| 国产一区二区伦理片| 一区二区三区久久久| 精品久久五月天| 欧美综合视频在线观看| 国产又粗又猛又爽又黄91精品| 亚洲精品日韩综合观看成人91| 欧美一级专区免费大片| 一本久久综合亚洲鲁鲁五月天| 美国毛片一区二区三区| 亚洲免费观看高清完整| 久久综合色之久久综合| 欧美区一区二区三区| av中文字幕不卡| 免费人成精品欧美精品| 亚洲欧洲精品一区二区精品久久久 | 欧美一级国产精品| 国产成人在线看| 成人三级伦理片| 午夜精品久久久久久久久久久| 久久久亚洲综合| 欧美日本不卡视频| 91美女在线看| 国产激情精品久久久第一区二区| 视频在线在亚洲| 亚洲自拍都市欧美小说| 亚洲欧洲精品天堂一级| 国产女人aaa级久久久级| 精品福利av导航| 777午夜精品免费视频| 一本大道久久a久久综合| av在线播放不卡| 成人免费视频一区| 高清beeg欧美| 国产精品99久久久久久久女警 | 国产欧美日韩视频一区二区| 日韩免费观看高清完整版| 欧美日韩国产高清一区二区| 国产一区二区三区免费| 91在线云播放| 成人蜜臀av电影| 黑人精品欧美一区二区蜜桃| 激情都市一区二区| 久久精品免费看| 国产一区二区福利| 国产成人综合网站| 99综合电影在线视频| 成人app在线| 99久久免费视频.com| 91在线高清观看| 91首页免费视频| 欧美在线观看你懂的| 欧美午夜精品久久久久久孕妇| 91片在线免费观看| 欧美在线高清视频| 欧美美女一区二区| 日韩三级免费观看| 久久久久久久一区| 国产精品欧美一区二区三区| 亚洲欧洲国产日韩| 亚洲国产视频在线| 美女在线视频一区| 粉嫩av一区二区三区在线播放| 91福利在线免费观看| 精品国产一区二区三区四区四| 91精品免费观看| 欧美一区二区三区在线电影| 日韩精品在线一区二区| 中文幕一区二区三区久久蜜桃| 国产精品美女久久福利网站| 亚洲黄色录像片| 美脚の诱脚舐め脚责91| 国产99精品国产| 色综合久久久久网| 5858s免费视频成人| 久久久久久一级片| 亚洲亚洲人成综合网络| 美女久久久精品| 99久久久久久99| 91精品国产91久久综合桃花| 国产亚洲美州欧州综合国| 亚洲激情在线激情| 久久99精品国产麻豆婷婷| 成人午夜视频福利| 91精品国产综合久久久久久| 国产日产亚洲精品系列| 亚洲一区二区精品视频| 国产伦精品一区二区三区免费 | 欧美一区二区观看视频| 2021中文字幕一区亚洲| 中文字幕一区在线| 香蕉成人啪国产精品视频综合网| 久久精品国产999大香线蕉| 99精品视频中文字幕| 欧美一区在线视频| 国产精品久久久久久户外露出| 日韩影院免费视频| 色综合中文综合网| 日本精品视频一区二区三区| 精品国产亚洲一区二区三区在线观看| 欧美激情一区在线观看| 午夜av一区二区三区| 成人看片黄a免费看在线| 91精品国产手机| 亚洲精品乱码久久久久久 | av色综合久久天堂av综合| 欧美一区二区三区免费视频| 亚洲美女区一区| 成人深夜在线观看| 26uuu精品一区二区三区四区在线| 精品久久久久一区二区国产| 亚洲毛片av在线| 麻豆91免费观看| 日本丶国产丶欧美色综合| 国产婷婷色一区二区三区四区 | 天天色综合成人网| 成人av网址在线观看| 欧美精品一区二区三区在线| 亚洲成av人片| 欧美亚男人的天堂| 亚洲精品国产视频| 91日韩精品一区| 亚洲欧洲日本在线| 99久久精品免费看国产免费软件| 精品国产乱码久久久久久久| 麻豆一区二区在线| 91精品国产欧美一区二区18| 午夜视频在线观看一区| 欧美色图天堂网| 亚洲福利视频导航| 欧美精品电影在线播放| 亚洲成人在线免费| 欧美日韩精品一区二区天天拍小说| 一区二区三区在线不卡| 欧美性受极品xxxx喷水| 亚洲一区二区三区四区在线免费观看| 91理论电影在线观看| 亚洲国产另类av| 日本丰满少妇一区二区三区| 成人欧美一区二区三区| 99国产精品久久久| 亚洲视频网在线直播| 91黄色激情网站| 亚洲成人第一页| 日韩午夜在线影院| 精品在线播放午夜| 久久精品视频一区| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 成人免费在线播放视频| 99久久久久免费精品国产| 一区二区三区高清在线| 欧美色涩在线第一页| 日本中文一区二区三区| 日韩欧美黄色影院| 国产精品中文字幕一区二区三区| 国产夜色精品一区二区av| 成人avav在线| 亚洲成人av资源| 久久综合久久综合久久综合| 懂色av中文字幕一区二区三区 | 久久久久亚洲综合| 色噜噜狠狠色综合中国| 亚洲成在线观看| 欧美成人伊人久久综合网| 岛国精品一区二区| 一区二区日韩av| 日韩午夜小视频| 99vv1com这只有精品| 日日摸夜夜添夜夜添精品视频|