READMD-zh.md 3.1 KB

Prerequisites

如果你想编译源代码,请确保NDK版本不高于16.1.4479499

Installation

在项目的build.gradle文件中添加:

compile 'com.dianping.android.sdk:logan:1.2.4'

Usage

在使用之前,必须初始化Logan,例如:

LoganConfig config = new LoganConfig.Builder()
        .setCachePath(getApplicationContext().getFilesDir().getAbsolutePath())
        .setPath(getApplicationContext().getExternalFilesDir(null).getAbsolutePath()
                + File.separator + "logan_v1")
        .setEncryptKey16("0123456789012345".getBytes())
        .setEncryptIV16("0123456789012345".getBytes())
        .build();
Logan.init(config);

初始化之后,就可以愉快的写日志了,例如这样写一条日志:

Logan.w("test logan", 1);

Logan.w方法有两个参数,详解如下:

  • String log:写入的日志内容;
  • int type:写入的日志类型,这非常重要,在下文的最佳实践内容会详细讲述如何优雅利用日志类型参数。 注意:type值1已被logan内部占用,建议业务方的日志类型使用新的type值。

如果你想立即写入日志文件,需要调用flush方法:

Logan.f();

如果你想查看所有日志文件的信息,需要调用getAllFilesInfo方法:

Map<String, Long> map = Logan.getAllFilesInfo();

其中key为日期,value为日志文件大小(Bytes)。

Upload

推荐使用这个接口上传数据,我们开源了Logan后台日志解析和展示的部分,只要部署好服务器就可以用这个接口直接上报日志到后端。

final String url = "https://openlogan.inf.test.sankuai.com/logan/upload.json";
Logan.s(url, loganTodaysDate(), "testAppId", "testUnionid", "testdDviceId", "testBuildVersion", "testAppVersion", new SendLogCallback() {
    @Override
    public void onLogSendCompleted(int statusCode, byte[] data) {
        final String resultData = data != null ? new String(data) : "";
        Log.d(TAG, "日志上传结果, http状态码: " + statusCode + ", 详细: " + resultData);
    }
});

Logan内部提供了日志上传机制,对需要上传的日志做了预处理操作。如果你需要上传日志功能,首先需要实现一个自己的SendLogRunnable:

public class RealSendLogRunnable extends SendLogRunnable {

    @Override
    public void sendLog(File logFile) {
      // logFile为预处理过后即将要上传的日志文件
      // 在此方法最后必须调用finish方法
      finish();
      if (logFile.getName().contains(".copy")) {
				logFile.delete();
			}
    }
}

注意:在sendLog方法的最后必须调用finish方法。如上面代码所示。

最后需要调用Logan的send方法:

Logan.s(date, mSendLogRunnable);

其中第一个参数为日期数组(yyyy-MM-dd)。

Permission

如果你需要上传日志到服务器,需要申请 INTERNET 权限。

如果你需要写日志到外部存储,或者从外部存储读取日志信息,则需要 WRITE_EXTERNAL_STORAGE 权限或者 READ_EXTERNAL_STORAGE 权限。