├── .gitignore ├── README.md ├── XLog.iml ├── app ├── .gitignore ├── app.iml ├── build.gradle ├── proguard-rules.pro └── src │ ├── androidTest │ └── java │ │ └── com │ │ └── sum │ │ └── xlog │ │ └── ApplicationTest.java │ └── main │ ├── AndroidManifest.xml │ ├── java │ └── com │ │ └── sum │ │ └── xlog │ │ └── sample │ │ ├── MainActivity.java │ │ ├── MyApplication.java │ │ └── Test.java │ └── res │ ├── layout │ └── activity_main.xml │ ├── mipmap-hdpi │ └── ic_launcher.png │ ├── mipmap-mdpi │ └── ic_launcher.png │ ├── mipmap-xhdpi │ └── ic_launcher.png │ ├── mipmap-xxhdpi │ └── ic_launcher.png │ ├── mipmap-xxxhdpi │ └── ic_launcher.png │ ├── values-w820dp │ └── dimens.xml │ └── values │ ├── colors.xml │ ├── dimens.xml │ ├── strings.xml │ └── styles.xml ├── build.gradle ├── gradle.properties ├── gradle └── wrapper │ ├── gradle-wrapper.jar │ └── gradle-wrapper.properties ├── gradlew ├── gradlew.bat ├── settings.gradle └── xlog ├── .gitignore ├── build.gradle ├── proguard-rules.pro ├── src ├── androidTest │ └── java │ │ └── com │ │ └── sum │ │ └── xlog │ │ └── ApplicationTest.java └── main │ ├── AndroidManifest.xml │ └── java │ └── com │ └── sum │ └── xlog │ ├── core │ ├── FileLogHelper.java │ ├── XLog.java │ └── XLogConfiguration.java │ ├── crash │ ├── CrashExceptionLogger.java │ ├── CrashHandler.java │ └── OnCrashInfoListener.java │ ├── print │ ├── LogLevel.java │ ├── XLogPrinter.java │ └── XLogPrinterImpl.java │ └── util │ ├── DateUtil.java │ ├── FileUtil.java │ └── OtherUtil.java └── xlog.iml /.gitignore: -------------------------------------------------------------------------------- 1 | .gradle 2 | /local.properties 3 | /.idea 4 | .DS_Store 5 | /build 6 | /captures 7 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ##XLOG简介 2 | * 自动保存LOG 3 | * 过期删除LOG,控制LOG存储大小 4 | * 自定义Crash操作 5 | 6 | [ ![Download](https://api.bintray.com/packages/qiu800820/maven/xlogUtils/images/download.svg) ](https://bintray.com/qiu800820/maven/xlogUtils/_latestVersion) 7 | 8 | Gradle构建: 9 | ```javascript 10 | compile 'com.sum.xlog:xlog:1.1.4' 11 | ``` 12 | 13 | 14 | 15 | 初始化:
16 | ```java 17 | XLogConfiguration.Builder builder = new XLogConfiguration.Builder(MyApplication.this) 18 | .setConsoleLogLevel(LogLevel.D) //Logger输出最低级别 19 | .setFileLogLevel(LogLevel.D) //保存至文件最低级别 20 | .setCrashHandlerOpen(true) //开启异常捕获 21 | .setOriginalHandler(Thread.getDefaultUncaughtExceptionHandler()) //第三方统计 22 | .setOnCrashInfoListener(new OnCrashInfoListener() { 23 | @Override 24 | public void onUpdateCrashInfo(File file) { 25 | // 可以根据自己的需求启动另一个进程实现上传文件至服务器, 26 | // Note: 不能直接做耗时操作,影响后续UncaughtExceptionHandler 27 | Log.d("onUpdateCrashInfo","onUpdateCrashInfo"); 28 | } 29 | }) //Crash回调 30 | .setFileLogRetentionPeriod(7); //过期删除 31 | ``` 32 | 33 | XLog使用方法:
34 | ```java 35 | 36 | XLog.startMethod(); 37 | XLog.d("=== XXX ==="); 38 | XLog.d("=== %s,%s ===", "XXX", "XXX"); 39 | XLog.endMethod(); 40 | 41 | FileUtil.getTodayLogFile() //获取当天LOG日志文件 42 | FileUtil.getXLogDirFile() //获取LOG日志文件夹 43 | 44 | 45 | ``` 46 | 47 | 混淆 48 | ```java 49 | -keepattributes SourceFile,LineNumberTable 50 | -keep class com.sum.xlog.print.XLogPrinterImpl {*;} 51 | ``` 52 | 53 | Email:
54 | -------------------------------------------------------------------------------- /XLog.iml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | -------------------------------------------------------------------------------- /app/.gitignore: -------------------------------------------------------------------------------- 1 | /build 2 | -------------------------------------------------------------------------------- /app/app.iml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 8 | 9 | 10 | 11 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | 64 | 65 | 66 | 67 | 68 | 69 | 70 | 71 | 72 | 73 | 74 | 75 | 76 | 77 | 78 | 79 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | 88 | 89 | 90 | 91 | 92 | 93 | 94 | 95 | 96 | 97 | 98 | 99 | 100 | 101 | 102 | 103 | 104 | 105 | 106 | 107 | 108 | 109 | 110 | 111 | 112 | 113 | 114 | 115 | 116 | 117 | 118 | 119 | 120 | 121 | 122 | 123 | -------------------------------------------------------------------------------- /app/build.gradle: -------------------------------------------------------------------------------- 1 | apply plugin: 'com.android.application' 2 | 3 | android { 4 | compileSdkVersion 26 5 | defaultConfig { 6 | applicationId "com.sum.xlog.sample" 7 | minSdkVersion 14 8 | targetSdkVersion 26 9 | versionCode 1 10 | versionName "1.0" 11 | } 12 | buildTypes { 13 | release { 14 | minifyEnabled true 15 | proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' 16 | } 17 | debug { 18 | minifyEnabled true 19 | proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' 20 | } 21 | } 22 | productFlavors { 23 | } 24 | } 25 | 26 | dependencies { 27 | compile fileTree(include: ['*.jar'], dir: 'libs') 28 | compile 'com.android.support:support-v4:26.+' 29 | compile project(':xlog') 30 | } 31 | -------------------------------------------------------------------------------- /app/proguard-rules.pro: -------------------------------------------------------------------------------- 1 | # Add project specific ProGuard rules here. 2 | # By default, the flags in this file are appended to flags specified 3 | # in D:\AndroidSDK/tools/proguard/proguard-android.txt 4 | # You can edit the include path and order by changing the proguardFiles 5 | # directive in build.gradle. 6 | # 7 | # For more details, see 8 | # http://developer.android.com/guide/developing/tools/proguard.html 9 | 10 | # Add any project specific keep options here: 11 | 12 | # If your project uses WebView with JS, uncomment the following 13 | # and specify the fully qualified class name to the JavaScript interface 14 | # class: 15 | #-keepclassmembers class fqcn.of.javascript.interface.for.webview { 16 | # public *; 17 | #} 18 | -keepattributes SourceFile,LineNumberTable 19 | -keep class com.sum.xlog.print.XLogPrinterImpl {*;} 20 | -------------------------------------------------------------------------------- /app/src/androidTest/java/com/sum/xlog/ApplicationTest.java: -------------------------------------------------------------------------------- 1 | package com.sum.xlog; 2 | 3 | import android.app.Application; 4 | import android.test.ApplicationTestCase; 5 | 6 | /** 7 | * Testing Fundamentals 8 | */ 9 | public class ApplicationTest extends ApplicationTestCase { 10 | public ApplicationTest() { 11 | super(Application.class); 12 | } 13 | } -------------------------------------------------------------------------------- /app/src/main/AndroidManifest.xml: -------------------------------------------------------------------------------- 1 | 2 | 4 | 5 | 6 | 7 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | -------------------------------------------------------------------------------- /app/src/main/java/com/sum/xlog/sample/MainActivity.java: -------------------------------------------------------------------------------- 1 | package com.sum.xlog.sample; 2 | 3 | import android.app.Activity; 4 | import android.content.Intent; 5 | import android.net.Uri; 6 | import android.os.Bundle; 7 | import android.view.View; 8 | import android.widget.Button; 9 | 10 | import com.sum.xlog.core.XLog; 11 | import com.sum.xlog.util.FileUtil; 12 | 13 | public class MainActivity extends Activity { 14 | 15 | private static final String TAG = "MainActivity"; 16 | 17 | @Override 18 | protected void onCreate(Bundle savedInstanceState) { 19 | super.onCreate(savedInstanceState); 20 | XLog.startMethod(); 21 | setContentView(R.layout.activity_main); 22 | 23 | 24 | //因为XLog有缓冲区, 满20条才会写入文件 降低CPU负担 25 | for(int i = 0; i < 10; i++){ 26 | XLog.d("=== XXX ==="); 27 | XLog.d("=== test url encode text %2f ==="); 28 | XLog.d("=== %s,%s ===", "XXX", "XXX"); 29 | } 30 | 31 | String a = null; 32 | try{ 33 | a.length(); 34 | }catch (NullPointerException e){ 35 | XLog.e(e); 36 | XLog.e(e.getMessage()); 37 | XLog.e("=== %s Exception ===", "Null"); 38 | XLog.e("=== %s Exception ===", e, "Null"); 39 | XLog.w("=== Null Exception ===", e); 40 | } 41 | 42 | Button sendLog = (Button)findViewById(R.id.send_log); 43 | sendLog.setOnClickListener(new View.OnClickListener() { 44 | @Override 45 | public void onClick(View v) { 46 | Intent data = new Intent(Intent.ACTION_SEND); 47 | data.putExtra(Intent.EXTRA_EMAIL, new String[]{"test@test.com"}); 48 | data.putExtra(Intent.EXTRA_SUBJECT, getString(R.string.app_name)); 49 | data.putExtra(Intent.EXTRA_TEXT, "这是我的LOG日志"); 50 | data.putExtra(Intent.EXTRA_STREAM, Uri.parse("file://" + FileUtil.getTodayLogFile().getAbsolutePath())); 51 | data.setType("message/rfc882"); 52 | startActivity(Intent.createChooser(data, getString(R.string.app_name))); 53 | } 54 | }); 55 | 56 | Button testCrash = findViewById(R.id.testCrash); 57 | testCrash.setOnClickListener(new View.OnClickListener() { 58 | @Override 59 | public void onClick(View v) { 60 | String a = null; 61 | a.length(); 62 | } 63 | }); 64 | new Test().show(); 65 | 66 | XLog.endMethod(); 67 | } 68 | 69 | @Override 70 | protected void onDestroy() { 71 | super.onDestroy(); 72 | } 73 | } 74 | -------------------------------------------------------------------------------- /app/src/main/java/com/sum/xlog/sample/MyApplication.java: -------------------------------------------------------------------------------- 1 | package com.sum.xlog.sample; 2 | 3 | import android.app.Application; 4 | import android.util.Log; 5 | 6 | import com.sum.xlog.core.XLog; 7 | import com.sum.xlog.core.XLogConfiguration; 8 | import com.sum.xlog.crash.OnCrashInfoListener; 9 | import com.sum.xlog.print.LogLevel; 10 | 11 | import java.io.File; 12 | 13 | 14 | public class MyApplication extends Application { 15 | 16 | 17 | 18 | @Override 19 | public void onCreate() { 20 | super.onCreate(); 21 | 22 | XLogConfiguration.Builder builder = new XLogConfiguration.Builder(MyApplication.this) 23 | .setConsoleLogLevel(LogLevel.D) //Logger输出最低级别 24 | .setFileLogLevel(LogLevel.D) //保存至文件最低级别 25 | .setCrashHandlerOpen(true) //开启异常捕获 26 | .setOriginalHandler(Thread.getDefaultUncaughtExceptionHandler()) //第三方统计 27 | .setOnCrashInfoListener(new OnCrashInfoListener() { 28 | @Override 29 | public void onUpdateCrashInfo(File file) { 30 | // TODO 可以根据自己的需求启动另一个进程实现上传文件至服务器, 31 | // Note: 不能直接做耗时操作,影响后续UncaughtExceptionHandler 32 | Log.d("onUpdateCrashInfo","onUpdateCrashInfo"); 33 | 34 | 35 | } 36 | }) //Crash回调 37 | .setFileLogRetentionPeriod(7); //过期删除 38 | 39 | XLog.init(MyApplication.this, builder.build()); 40 | // Default 41 | // XLog.init(this); 42 | 43 | 44 | } 45 | 46 | } 47 | -------------------------------------------------------------------------------- /app/src/main/java/com/sum/xlog/sample/Test.java: -------------------------------------------------------------------------------- 1 | package com.sum.xlog.sample; 2 | 3 | import com.sum.xlog.core.XLog; 4 | 5 | /** 6 | * Created by Sen on 2018/5/29. 7 | */ 8 | 9 | public class Test { 10 | 11 | public void show(){ 12 | XLog.d("测试混淆TAG className:%s", getClass().getSimpleName()); 13 | XLog.d("测试混淆TAG className:%s", getClass().getSimpleName()); 14 | XLog.d("测试混淆TAG className:%s", getClass().getSimpleName()); 15 | } 16 | 17 | } 18 | -------------------------------------------------------------------------------- /app/src/main/res/layout/activity_main.xml: -------------------------------------------------------------------------------- 1 | 2 | 9 | 10 |