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");//写入日志