使用后退按钮时阻止用户访问应用程序

问题描述 投票:0回答:4

我正在制作一个简单的密码管理应用程序,它要求用户记住一个“主密码”以访问存储在应用程序中的所有其他密码。

但是我的问题是后退按钮(和多任务处理)。就好像用户(或更重要的是,其他人)使用这些,他/她可以访问该应用程序而无需通过初始验证页面。

有什么办法可以阻止这个问题吗?

或者有没有办法在按下开始按钮时简单地终止应用程序? (以达到与使用后退按钮退出应用程序时相同的效果)。

c# xaml security windows-phone-7 windows-phone-8
4个回答
2
投票

使用 App.xaml.cs 中的 Application_Activated 事件来检测这一点并相应地应用您的逻辑,例如再次要求身份验证。
Windows Phone 7 没有关闭应用程序的 API。对于 Windows Phone 8,您可以使用 Application.Current.Terminate();


0
投票

如果您的应用程序针对 Windows Phone 7(将在 Phone 8 上运行),您可以使用以下行退出应用程序:

new Microsoft.Xna.Framework.Game().Exit();

这是在 Microsoft.Xna.Framework.Game 程序集中找到的。


0
投票

我想我有最适合你的解决方案。 在 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。它简单且安全,并将提供可靠的用户体验。另外,因为它会在页面导航到时进行验证,我认为用户将更难尝试绕过某些方法。


-1
投票

在 Application_Deactivated 事件中抛出一个异常

private void Application_Deactivated(object sender, DeactivatedEventArgs e)
{
    throw new Exception("System Exit");
}
© www.soinside.com 2019 - 2024. All rights reserved.