Android工具之Log信息写入储存卡

package com.toolsclass.chenjun.general.generalcj.Utility;

import android.content.Context;
import android.os.Environment;
import android.text.format.Formatter;
import android.util.Log;

import java.io.BufferedWriter;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileWriter;
import java.text.SimpleDateFormat;
import java.util.Date;

/**
 * 作者:陈骏
 * 时间: 2017/10/19 0019 10:05
 * QQ:200622550
 * 作用:Log信息写入储存卡
 */

public class LogToFileUtils {
    private static Context mContext;
    private static LogToFileUtils instance;
    private static File logFile;
    private static SimpleDateFormat logSDF = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
    private static final int LOG_MAX_SIZE = 10485760;
    private static String tag;

    public LogToFileUtils() {
    }

    public static void init(Context context) {
        Log.i("LogToFileUtils", "初始化中。。。");
        if(null != mContext && null != instance && null != logFile && logFile.exists()) {
            Log.i("LogToFileUtils", "已经初始化 ...");
        } else {
            mContext = context;
            instance = new LogToFileUtils();
            logFile = getLogFile();
            Log.i("LogToFileUtils", "文件路径: " + logFile.getPath());
            long logFileSize = getFileSize(logFile);
            Log.d("LogToFileUtils", "Log最大: " + Formatter.formatFileSize(context, 10485760L));
            Log.i("LogToFileUtils", "Log现在的大小是: " + Formatter.formatFileSize(context, logFileSize));
            if(10485760L < logFileSize) {
                resetLogFile(); // 重置日志文件
            }
        }

    }

    public static void write(Object str) {
        if(null != mContext && null != instance && null != logFile && logFile.exists()) {
            String logStr = getFunctionInfo() + " - " + str.toString();
            Log.i(tag, logStr);

            try {
                BufferedWriter e = new BufferedWriter(new FileWriter(logFile, true));
                e.write(logStr);
                e.write("\r\n");
                e.flush();
            } catch (Exception var3) {
                Log.e(tag, "写入失败!!! " + var3.toString());
            }

        } else {
            Log.e("LogToFileUtils", "初始化失败!!!");
        }
    }

    /**
     * 重置日志文件
     */
    private static void resetLogFile() {
        Log.i("LogToFileUtils", "重置日志文件 ... ");
        File lastLogFile = new File(logFile.getParent() + "/lastLog.txt");
        if(lastLogFile.exists()) {
            lastLogFile.delete();
        }

        logFile.renameTo(lastLogFile);

        try {
            logFile.createNewFile();
        } catch (Exception var2) {
            Log.e("LogToFileUtils", "创建日志文件失败!!! " + var2.toString());
        }

    }

    private static long getFileSize(File file) {
        long size = 0L;
        if(file.exists()) {
            try {
                FileInputStream e = new FileInputStream(file);
                size = (long)e.available();
            } catch (Exception var4) {
                Log.e("LogToFileUtils", var4.toString());
            }
        }

        return size;
    }

    private static File getLogFile() {
        File file;
        if(Environment.getExternalStorageState().equals("mounted")) {
            file = new File(mContext.getExternalFilesDir("Log").getPath() + "/");
        } else {
            file = new File(mContext.getFilesDir().getPath() + "/Log/");
        }

        if(!file.exists()) {
            file.mkdir();
        }

        File logFile = new File(file.getPath() + "/logs.txt");
        if(!logFile.exists()) {
            try {
                logFile.createNewFile();
            } catch (Exception var3) {
                Log.e("LogToFileUtils", "创建日志文件失败!!! " + var3.toString());
            }
        }

        return logFile;
    }

    private static String getFunctionInfo() {
        StackTraceElement[] sts = Thread.currentThread().getStackTrace();
        if(sts == null) {
            return null;
        } else {
            StackTraceElement[] var1 = sts;
            int var2 = sts.length;

            for(int var3 = 0; var3 < var2; ++var3) {
                StackTraceElement st = var1[var3];
                if(!st.isNativeMethod() && !st.getClassName().equals(Thread.class.getName()) && !st.getClassName().equals(instance.getClass().getName())) {
                    tag = st.getFileName();
                    return "[" + logSDF.format(new Date()) + " " + st.getClassName() + " " + st.getMethodName() + " Line:" + st.getLineNumber() + "]";
                }
            }

            return null;
        }
    }
}
用法:
1、Application初始化-->LogToFileUtils.init(this);
2、LogToFileUtils.write("sample text");//写入日志

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值