Android应用记录器 - 适用于测试人员

时间:2015-07-15 04:10:40

标签: android android-debug android-developer-api android-log

我是一名Android开发人员,我为客户开发应用程序。 但是,在客户端设备中,通常会发生一些应用程序崩溃问题但它并没有发生在我的设备中。 但我无法联系到我的客户,所以,这里有一个问题:~~~~ 是否有任何插件或工具可以实现到我的Android应用程序中,所以当我的客户端设备中的应用程序崩溃时,崩溃日志将被发送到我的电子邮件或我可以检查它的某个地方,所以我可以调试它。 请告诉我,谢谢

3 个答案:

答案 0 :(得分:1)

转到https://play.google.com/apps/publish/并发布您的应用。当用户安装您的应用并崩溃时,它会通知Google,当您登录此控制面板时,您将能够在“报告”标签下找到此类报告,然后在“CRASHES& ANRS”下找到。

答案 1 :(得分:0)

试着看看Crashlytics:http://try.crashlytics.com/sdk-android/

答案 2 :(得分:0)

我认为你应该扩展Application类,并用稳定的代码重新定义Exception Handle(不包括android版本)。

代码示例:

<强> YourApplication.java

public class YourApplication extends Application {       
@Override
public void onCreate() {
    Thread.setDefaultUncaughtExceptionHandler(ExceptionHandler.inContext(getApplicationContext()));

    super.onCreate();
}}

<强> ExceptionHandler.java

final public class ExceptionHandler implements Thread.UncaughtExceptionHandler{
private final DateFormat formatter = new SimpleDateFormat("dd.MM.yy HH:mm");
private final DateFormat fileFormatter = new SimpleDateFormat("dd-MM-yy");
private String versionName = "0";
private int versionCode = 0;
private final String stacktraceDir;
private final Thread.UncaughtExceptionHandler previousHandler;

private ExceptionHandler(Context context, boolean chained) {

    PackageManager mPackManager = context.getPackageManager();
    PackageInfo mPackInfo;
    try {
        mPackInfo = mPackManager.getPackageInfo(context.getPackageName(), 0);
        versionName = mPackInfo.versionName;
        versionCode = mPackInfo.versionCode;
    } catch (PackageManager.NameNotFoundException e) {
        // ignore
    }
    if(chained)
        previousHandler = Thread.getDefaultUncaughtExceptionHandler();
    else
        previousHandler = null;
    stacktraceDir = String.format("/Android/data/%s/files/", context.getPackageName());
}

static ExceptionHandler inContext(Context context) {
    return new ExceptionHandler(context, true);
}

static ExceptionHandler reportOnlyHandler(Context context) {
    return new ExceptionHandler(context, false);
}

@Override
public void uncaughtException(Thread thread, Throwable exception) {
    final String state = Environment.getExternalStorageState();
    final Date dumpDate = new Date(System.currentTimeMillis());
    if (Environment.MEDIA_MOUNTED.equals(state)) {

        StringBuilder reportBuilder = new StringBuilder();
        reportBuilder
                .append("\n\n\n")
                .append(formatter.format(dumpDate)).append("\n")
                .append(String.format("Version: %s (%d)\n", versionName, versionCode))
                .append(thread.toString()).append("\n");
        processThrowable(exception, reportBuilder);

        File sd = Environment.getExternalStorageDirectory();
        File stacktrace = new File(
                sd.getPath() + stacktraceDir,
                String.format(
                        "stacktrace-%s.txt",
                        fileFormatter.format(dumpDate)));
        File dumpdir = stacktrace.getParentFile();
        boolean dirReady = dumpdir.isDirectory() || dumpdir.mkdirs();
        if (dirReady) {
            FileWriter writer = null;
            try {
                writer = new FileWriter(stacktrace, true);
                writer.write(reportBuilder.toString());
            } catch (IOException e) {
                // ignore
            } finally {
                try {
                    if (writer != null)
                        writer.close();
                } catch (IOException e) {
                    // ignore
                }
            }
        }
    }
    if(previousHandler != null)
        previousHandler.uncaughtException(thread, exception);
}

private void processThrowable(Throwable exception, StringBuilder builder) {
    if(exception == null)
        return;
    StackTraceElement[] stackTraceElements = exception.getStackTrace();
    builder
            .append("Exception: ").append(exception.getClass().getName()).append("\n")
            .append("Message: ").append(exception.getMessage()).append("\nStacktrace:\n");
    for(StackTraceElement element : stackTraceElements) {
        builder.append("\t").append(element.toString()).append("\n");
    }
    processThrowable(exception.getCause(), builder);
}}

如果您的应用程序已经成功,您可以在/sdcard/android/data/you.package.name/files/所有日志文件中找到包含StackTrace的日志。 此外,您可以在每个应用程序启动时检查此文件夹中的新日志文件。如果您找到新文件,可以将其发送到您的电子邮箱。