1

在使用 unCaughtExceptionHandler 发生未捕获的异常后,我尝试以隐式意图启动活动。Intent 应该在已崩溃的同一应用程序中将 Activity 作为 Dialog 启动。这对应于该线程中列出的示例:

需要处理未捕获的异常并发送日志文件

我在自己的处理程序结束时调用原始的 unCaughtExceptionHandler,如下所示:

public class ThisApplication extends Application
{
    Thread.UncaughtExceptionHandler originalUncaughtExceptionHandler;

    @Override
    public void onCreate ()
    {
        originalUncaughtExceptionHandler = Thread.getDefaultUncaughtExceptionHandler();

        Thread.setDefaultUncaughtExceptionHandler (new Thread.UncaughtExceptionHandler()
        {
            @Override
            public void uncaughtException (Thread thread, Throwable e)
            {
                handleUncaughtException (thread, e);
            }
        });
        super.onCreate();
    }

    public void handleUncaughtException (Thread thread, Throwable e)
    {
        e.printStackTrace();

        Intent intent = new Intent ();
        intent.setAction ("de.mydomain.myapp.action.PROCESS_LOG");

        intent.setFlags (Intent.FLAG_ACTIVITY_NEW_TASK);

        if (intent.resolveActivity(getPackageManager()) == null) {
            Log.d("ThisApplication","No receiver");
        } else {
            Log.d("ThisApplication", "Intent start");
            startActivity(intent);
        }

        originalUncaughtExceptionHandler.uncaughtException(thread, e);
    }
}

结果是,在出现异常后,会显示标准对话框,上面写着“不幸的是 App xxx 已关闭”。在那个对话框的后面,在后台,我可以看到我的对话框应该以这个意图“PROCESS_LOG”开始。所以显然是启动了,但问题是,在标准对话框关闭后,我的自定义对话框也关闭了。如果我添加

android:launchMode="singleInstance"

在对话框活动的清单中,对话框也被隐藏了,但是当从最近的应用程序菜单中选择应用程序时,可以再次激活它。这在我看来好像对话框没有完全独立于以前的应用程序进程/任务启动。

有人可以说我做错了什么吗?

这是对话活动的清单部分:

<activity
    android:name=".ProcessLogActivity"
    android:windowSoftInputMode="stateHidden"
    android:theme="@style/ProcessLogActivity"
    android:process=":report_process"
    >
    <intent-filter>
        <action android:name="de.mydomain.myapp.action.PROCESS_LOG" />
        <category android:name="android.intent.category.DEFAULT" />
    </intent-filter>
</activity>

对应样式:

<style name="ProcessLogActivity" parent="@style/Theme.AppCompat.Light.Dialog">
</style>

这是对话框活动类:

public class ProcessLogActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        requestWindowFeature (Window.FEATURE_NO_TITLE);
        setFinishOnTouchOutside (false);
        Log.d("ThisApplication", "Intent received");
        setContentView(R.layout.activity_process_log);
    }
}
4

2 回答 2

0

问题是 - 至少在 ACRA-Dialog 的情况下 - 它无法正常工作,因为应用程序是使用 android studio 的内置功能进行调试的。因此,您必须在没有 android studio IDE 支持的情况下在 android 测试系统(在调试设备上)上启动应用程序。当您这样做并引发异常时,ACRA-Dialog 会按原样出现。

于 2017-03-05T21:02:52.680 回答
0

要发布完整的消息(评论太短),这里是完整的类和配置:

我尝试将 ACRA 与内置对话功能一起使用,但无法正常工作。但是显示“吐司”的内置功能有效!所以这就是为什么我问自己问题在哪里显示对话框。我使用以下@ReportCrashed Annotation 进行测试:

@ReportsCrashes(
    formUri = "http://yourserver.com/yourscript",
    mode = ReportingInteractionMode.NOTIFICATION,
    resDialogText = R.string.app_name,
    resNotifTickerText = R.string.app_name,
    resNotifTitle = R.string.app_name,
    resNotifText = R.string.app_name
)

在我自己的应用程序类中,我使用以下初始化:

public class ThisApplication extends Application {
    @Override
    protected void attachBaseContext(Context base) {
        super.attachBaseContext(base);

        final ConfigurationBuilder configurationBuilder = new ConfigurationBuilder(this);
        configurationBuilder.setBuildConfigClass(BuildConfig.class);

        final ACRAConfiguration config;
        try {
            config = configurationBuilder.build();
            ACRA.init(this, config);
        } catch (ACRAConfigurationException e) {
            e.printStackTrace();
        }
    }
}

我的应用程序使用两种不同的构建风格和两种构建类型“调试”和“发布”。

当我抛出未处理的异常时,应用程序会关闭,并且有时只会在很短的时间内(不到半秒)显示一个对话框,然后整个应用程序会在没有任何对话框的情况下关闭。

有任何想法吗?...

编辑:上面的注释是尝试通知,也不起作用。通知也只显示很短的时间,然后立即消失。对话框注释是:

@ReportsCrashes(
    formUri = "http://yourserver.com/yourscript",
    mode = ReportingInteractionMode.DIALOG,
    resDialogText = R.string.app_name
)

这具有上述效果。

于 2017-03-04T17:38:19.787 回答