ACRA with android:如何在报告崩溃之前执行代码



我正在使用我的安卓应用程序的ACRA。我的问题是,当崩溃发生时,我如何确保在报告崩溃之前执行一些代码。我的意思是我想在崩溃发生时添加一些自定义变量,以便我知道应用程序处于什么状态?

请帮忙

谢谢

实现你自己的发送器,如此处所述。它可以只是一些现有发送方的包装器,将发送功能转发到那里。

在发件人代码中,您可以在实际发送报告之前执行任何特殊操作。

这就是使用带有 HttpSender 后端的 ACRA 4.5.0 对我有用的方法。 我在Cloudant上使用Acralyzer。

原始代码:

@ReportsCrashes(
    mode = ReportingInteractionMode.DIALOG,
    resDialogText = R.string.crash_dialog_text,
    resDialogCommentPrompt = R.string.crash_dialog_comment_prompt,
    formUri = "https://kpc.cloudant.com/acra-openconnect/_design/acra-storage/_update/report",
    formUriBasicAuthLogin="[restricted reporter login]",
    formUriBasicAuthPassword="[restricted reporter password]",
    reportType = org.acra.sender.HttpSender.Type.JSON,
    httpMethod = org.acra.sender.HttpSender.Method.PUT,
    formKey = ""
)
public class Application extends android.app.Application {
    public void onCreate() {
        super.onCreate();
        ACRA.init(this);

我的应用程序保留一个包含日志消息的内存循环缓冲区。 这不会写入磁盘,我也不是特别想在每次添加条目时将其呈现为字符串并调用 putCustomData()。 因此,我调用我的静态"转储"方法VPNLog.dumpLast()在HttpSender.send()运行之前修改报告。 新代码如下所示:

@ReportsCrashes(
    mode = ReportingInteractionMode.DIALOG,
    resDialogText = R.string.crash_dialog_text,
    resDialogCommentPrompt = R.string.crash_dialog_comment_prompt,
    formUri = "https://kpc.cloudant.com/acra-openconnect/_design/acra-storage/_update/report",
    formUriBasicAuthLogin="[restricted reporter login]",
    formUriBasicAuthPassword="[restricted reporter password]",
    // reportType and httpMethod are now defined below
    formKey = ""
)
public class Application extends android.app.Application {
    public void onCreate() {
        super.onCreate();
        ACRA.init(this);
        ACRA.getErrorReporter().setReportSender(
            new HttpSender(org.acra.sender.HttpSender.Method.PUT,
                           org.acra.sender.HttpSender.Type.JSON,
                           null) {
                @Override
                public void send(CrashReportData report) throws ReportSenderException {
                    report.put(ReportField.APPLICATION_LOG, VPNLog.dumpLast());
                    super.send(report);
                }
            });

我添加的值是一个长(100+ 行)字符串;Acralyzer 正确地将其分解为单独的编号行。

另一种选择是用多个键/值对填充ReportField.CUSTOM_DATA:

report.put(ReportField.CUSTOM_DATA, "key0=value0nkey1=value1n");

Acralyzer 将在 HTML 表中显示这些内容。

Acra 通过使用 Thread.setDefaultUncaughtExceptionHandler(...) 工作;

您可以设置自己的未捕获异常处理程序,然后调用 ACRA 生成报告:

public class My_Exception_Interceptor implements Thread.UncaughtExceptionHandler {
    /**
     * Sets up to catch an exception. 
     * Call this after initializing ACRA.
     */
    public void setUpFatalExceptionHandling() {
        Thread.setDefaultUncaughtExceptionHandler(this);
    }
    /**
     * Called by the JVM on an uncaught exception. 
     * @param t - the thread
     * @param e - the throwable
     */
    @Override
    public void uncaughtException(@Nullable Thread t, @NonNull Throwable e) {
        ...your code...
        ACRA.getErrorReporter().handleException(e, true);
    }
}

相关内容

  • 没有找到相关文章

最新更新