Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> 關於Android編程 >> Android 使用Log4j把日志寫入SD卡,動態修改輸出文件名稱

Android 使用Log4j把日志寫入SD卡,動態修改輸出文件名稱

編輯:關於Android編程



一、Log4j簡單使用 1. 下載log4j.jar http://logging.apache.org/log4j/2.x/
2. 創建Java代碼
public class Loggers {

    public static Logger logger =
            Logger. getLogger(Loggers. class);

    public static void init() {
        try {
            PatternLayout patternLayout = new PatternLayout();
            patternLayout.setConversionPattern("%d{yyyy-MM-dd HH:mm:ss} %m %n");
            FileAppender fileAppender = new FileAppender(patternLayout, "D://log4j_info.log" );
            logger.addAppender(fileAppender);
           
        } catch (IOException e) {
            e.printStackTrace();
        }  
    }
   
   
    public static void main(String argv[]) {
        init();
       
        logger.debug( "Hello, my name is Homer Simpson." );

        logger.info( "We are the Simpsons!" );

        logger.warn( "Mmm...forbidden donut." );

        logger.error( "Dear Baby, Welcome to Dumpsville. Population: you.");

        logger.fatal( "Eep.");
       
    }
}


init中的代碼是為了根據不同手機設置路徑與輸出文件名,所以使用代碼配置輸出路徑。
二、Android 使用Log4j把日志寫入SD卡,動態修改輸出文件名稱
1. 使用以下代碼可以設置輸出路徑,在以上init方法中調用
     private static String getOutputPath(Context context, String name) {
        String rootPath = getSdcardPath(context);

        StringBuilder fileName = new StringBuilder();
        // 手機型號
        fileName.append(android.os.Build. MODEL);
        fileName.append( "-");
       
        // 系統版本
        fileName.append( "Android_");
        fileName.append(android.os.Build.VERSION.RELEASE );
        // SDK版本
        fileName.append( "_");
        fileName.append(android.os.Build.VERSION. SDK);
        fileName.append( "-");

        String path = rootPath + "/" + fileName.toString() + name;
       
        return path;
    }

    private static String getSdcardPath(Context context) {
        // SD卡是否存在
        if (android.os.Environment.getExternalStorageState().equals(android.os.Environment. MEDIA_MOUNTED)) {
            // SD卡存在,返回SD卡根目錄
            return Environment.getExternalStorageDirectory().getPath();
        } else {
            return context.getFilesDir().getPath();
        }
    }



2. 設置SD卡讀寫權限
      
      
      
          



  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved