Android自定義Log,帶保存文件和定時(shí)刪除

簡單的日志保存工具類

public class LogUtil {
    private final static Boolean ENABLE = true;
    private final static Boolean NEED_SAVE = true;
    private final static String PATH = Environment.getExternalStorageDirectory().getPath() + "/MyLog//";

    public static void d(String tag, String info) {
        if (ENABLE) {
            Log.d(tag, info);
            save(tag, info);
        }
    }

    public static void e(String tag, String info) {
        if (ENABLE) {
            Log.e(tag, info);
            save(tag, info);
        }
    }

    public static void save(String tag, String info) {
        if (!NEED_SAVE) {
            return;
        }
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        makeRootDirectory(PATH);
        String filename = Datetimeutil.date() + ".txt";
        String filePath = PATH + filename;
        String strContent = simpleDateFormat.format(System.currentTimeMillis()) + ":" + tag + ":" + info + "\r\n";
        try {
            File file = new File(filePath);
            if (!file.exists()) {
                file.getParentFile().mkdirs();
                file.createNewFile();
            }
            RandomAccessFile raf = new RandomAccessFile(file, "rwd");
            raf.seek(file.length());
            raf.write(strContent.getBytes());
            raf.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    private static void makeRootDirectory(String filePath) {
        File file = null;
        try {
            file = new File(filePath);
            if (!file.exists()) {
                file.mkdir();
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

定時(shí)刪除工具類,刪除30天以前的

 public static void removeFileByTime(String dirPath) {
        //獲取目錄下所有文件
        List<File> allFile = getDirAllFile(new File(dirPath));
        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm");
        //獲取當(dāng)前時(shí)間
        Date end = new Date(System.currentTimeMillis());
        try {
            end = dateFormat.parse(dateFormat.format(new Date(System.currentTimeMillis())));
        } catch (Exception e){
            e.printStackTrace();
        }
        for (File file : allFile) {//ComDef
            try {
                //文件時(shí)間減去當(dāng)前時(shí)間
                Date start = dateFormat.parse(dateFormat.format(new Date(file.lastModified())));
                long diff = end.getTime() - start.getTime();//這樣得到的差值是微秒級別
                long days = diff / (1000 * 60 * 60 * 24);
                if(30 <= days){
                    deleteFile2(file);
                }

            } catch (Exception e){
                e.printStackTrace();
            }
        }
    }

    //刪除文件夾及文件夾下所有文件
    public static void deleteFile2(File file) {
        if (file.isDirectory()) {
            File[] files = file.listFiles();
            for (int i = 0; i < files.length; i++) {
                File f = files[i];
                deleteFile2(f);
            }
            file.delete();
        } else if (file.exists()) {
            file.delete();
        }
    }

    //獲取指定目錄下一級文件
    public static List<File> getDirAllFile(File file) {
        List<File> fileList = new ArrayList<>();
        File[] fileArray = file.listFiles();
        if(fileArray == null)
            return fileList;
        for (File f : fileArray) {
            fileList.add(f);
        }
        fileSortByTime(fileList);
        return fileList;
    }

    //對文件進(jìn)行時(shí)間排序
    public static void fileSortByTime(List<File> fileList) {
        Collections.sort(fileList, new Comparator<File>() {
            public int compare(File p1, File p2) {
                if (p1.lastModified() < p2.lastModified()) {
                    return -1;
                }
                return 1;
            }
        });
    }

自定義Constants接口保存一些常用的常量

  String INTENT_ALARM_LOG = "delete_log";

如果想要定時(shí)刪除需要用到鬧鐘廣播,每天上午十點(diǎn)刪除如下,可以在MainActivity的onCreate()下調(diào)用下面的代碼

  AlarmManager am = (AlarmManager) getSystemService(ALARM_SERVICE);
        Calendar calendar = Calendar.getInstance();
        calendar.set(Calendar.HOUR_OF_DAY, 10);
        calendar.set(Calendar.MINUTE, 0);
        calendar.set(Calendar.SECOND, 0);
        Intent intent = new Intent(Constants.INTENT_ALARM_LOG);
        PendingIntent pi = PendingIntent.getBroadcast(this, 0, intent, 0);
        am.setRepeating(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), 1000 * 60 * 60 * 24, pi);

然后寫一個廣播接收類AlarmReceiver ,再靜態(tài)注冊

public class AlarmReceiver extends BroadcastReceiver {
    @Override
    public void onReceive(Context context, Intent intent) {
        String action = intent.getAction();
        if (action.equals(Constants.INTENT_ALARM_LOG)) {
            new Thread(new Runnable() {
                @Override
                public void run() {
                    FileUtils.removeFileByTime(LogUtils.PATH);
                }
            }).start();

        }
    }
}

靜態(tài)注冊

  <receiver android:name=".view.receiver.AlarmReceiver">
            <intent-filter>
                <action android:name="delete_log"/>
            </intent-filter>
        </receiver>
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容