我正在制作一个简单的密码管理应用程序,它要求用户记住一个“主密码”以访问存储在应用程序中的所有其他密码。
但是我的问题是后退按钮(和多任务处理)。就好像用户(或更重要的是,其他人)使用这些,他/她可以访问该应用程序而无需通过初始验证页面。
有什么办法可以阻止这个问题吗?
或者有没有办法在按下开始按钮时简单地终止应用程序? (以达到与使用后退按钮退出应用程序时相同的效果)。
使用 App.xaml.cs 中的 Application_Activated 事件来检测这一点并相应地应用您的逻辑,例如再次要求身份验证。
Windows Phone 7 没有关闭应用程序的 API。对于 Windows Phone 8,您可以使用 Application.Current.Terminate();
如果您的应用程序针对 Windows Phone 7(将在 Phone 8 上运行),您可以使用以下行退出应用程序:
new Microsoft.Xna.Framework.Game().Exit();
这是在 Microsoft.Xna.Framework.Game 程序集中找到的。
我想我有最适合你的解决方案。 在 app.xaml.cs 中,您将创建一个全局变量 didResume。在 Appication_Activated 事件中,您要将 didResume 设置为 true。现在,每当您加载需要用户身份验证的页面时,请检查变量以查看用户是否恢复,如果他们恢复了,您可以根据需要进行处理。这是 app.xaml.cs 的代码:
public static bool didResume = false;
private void Application_Activated(object sender, ActivatedEventArgs e)
{
didResume = true;
}
现在您只需将此方法添加到您要保护的任何页面:
protected override void OnNavigatedTo(NavigationEventArgs e)
{
base.OnNavigatedTo(e);
if(App.didResume)
{
NavigationService.Navigate(new Uri("/MainPage.xaml", UriKind.Relative));
}
}
我认为这应该可行,因为它确实不会调用任何可能无法在 Windows Phone 7 上运行的 API。它简单且安全,并将提供可靠的用户体验。另外,因为它会在页面导航到时进行验证,我认为用户将更难尝试绕过某些方法。
在 Application_Deactivated 事件中抛出一个异常
private void Application_Deactivated(object sender, DeactivatedEventArgs e)
{
throw new Exception("System Exit");
}