wpf 实现长时间未操作自动退出登录

思路

        在WPF应用程序中实现长时间未操作自动退出,主要思路是先收集用户操作行为,用一个全局变量记录用户最后操作时间,再用一个异步线程去监控用户的最后操作时间和当前时间进行比较如果超过了设定时间认为长时间未操作自动退出登录并显示相关日志消息。

        有一个问题自动退出后当前停留的界面功能是否还有权限使用呀?这个问题要怎么解决?大家可以自己去想想,我是解决了。如果想和我交流可以在评论区讨论。

收集用户操作行为

        我想到了两种方式:

        一、在所有按钮或功能中调用一个公共方法记录用户的操作行为。优点:实现简单,不足:如果系统功能多且在系统要完工时加这个功能,那工作量不少哦,代码改动面也大可能改出其他BUG。

        二、可以通过监听用户的鼠标和键盘事件来实现。优点:改动小,工作量小。不足:有点难,没事有我呢。我来分享。我用的就是这种方法

监听用户的鼠标和键盘事件来实现

  1. 在主窗口(如MainWindow)中,设置一个计时器(如DispatcherTimer)。

  2. 当用户进行鼠标或键盘操作时,判断是否超时,没有超时更新用户最后操作时间,否则调用自动退出方法。

  3. 如果计时器到达设定的时间且没有其他操作事件触发,则调用自动退出方法。

示例代码:

/// <summary>
/// MainWindow.xaml 的交互逻辑
/// </summary>
public partial class MainWindow : System.Windows.Window
{
    /// <summary>
/// 刷新时间
/// </summary>
private readonly DispatcherTimer _timerwatchpermit = new DispatcherTimer();

    public MainWindow()
    {
        InitializeComponent();
        this.MouseMove += MainWindow_MouseMove;
        this.KeyDown += MainWindow_KeyDown;
        this.Loaded += MainWindow_Loaded;
    }

    /// <summary>
    /// 键盘按下事件
    /// </summary>
    /// <param name="sender"></param>
    /// <param name="e"></param>
    /// <exception cref="NotImplementedException"></exception>
    private void MainWindow_KeyDown(object sender, KeyEventArgs e)
    {
        userOperationLastTimeMonitoringAndUpdate();
    }

    /// <summary>
    /// 鼠标移动事件
    /// </summary>
    /// <param name="sender"></param>
    /// <param name="e"></param>
    /// <exception cref="NotImplementedException"></exception>
    private void MainWindow_MouseMove(object sender, MouseEventArgs e)
    {
        userOperationLastTimeMonitoringAndUpdate();
    }

    /// <summary>
    /// 用户操作时间监控和更新
    /// </summary>
    private void userOperationLastTimeMonitoringAndUpdate()
    {
        if (Global.UserOperationLastTime != SystemConst.DateTimeDefault && !Global.user_permit.Equals("操作员"))
        {
            //检查是否超过指定分钟数验证,SystemConfigConst.UserOperationMaxMinute是配置的超时时间
            if (DateTime.Now > Global.UserOperationLastTime.AddMinutes(SystemConfigConst.UserOperationMaxMinute))
            {
                //超过了,自动退出登录
                Global.UserLogOut(true);
            }
            else
            {
                Global.UserOperationLastTime = DateTime.Now;
            }
        }
    }

    private void MainWindow_Loaded(object sender, RoutedEventArgs e)
    {
        //Log_Msg.Foreground = Brushes.Wheat;//#AAFFFFFF
        Log_Msg.Foreground = new SolidColorBrush((Color)ColorConverter.ConvertFromString("#AAFFFFFF"));
        Log_Alm.Foreground = Log_Msg.Foreground;
        Log_SocketMsg.Foreground = Log_Msg.Foreground;
        Log_SendNeedleLog.Foreground = Log_Msg.Foreground;
        Log_MonitoringMsg.Foreground = Log_Msg.Foreground;
        cboIsCurrentXY.Foreground = Log_Msg.Foreground;

        _timerwatchpermit.Interval = new TimeSpan(0, 0, 0, 1, 0);
        _timerwatchpermit.Tick += Tmr_sacn_Tick;
        _timerwatchpermit.Start();
    }

    private void Tmr_sacn_Tick(object sender, EventArgs e)
{
    try
    {
        //CurrentTime = DateTime.Now;
        //MessageHelper.ShowMsg("当前时间:"+ CurrentTime.ToString("yyyy-MM-dd HH:mm:ss"), "Tmr_sacn_Tick");
        if (Global.UserOperationLastTime != SystemConst.DateTimeDefault &&         !Global.user_permit.Equals("操作员"))
{
    //检查是否超过指定分钟数验证
    if (DateTime.Now > Global.UserOperationLastTime.AddMinutes(SystemConfigConst.UserOperationMaxMinute))
    {
        //超过了,自动退出登录
        Global.UserLogOut(true);
    }
}

    }
    catch (Exception ex)
    {
        MessageHelper.ShowMsgError(_className + ".Tmr_sacn_Tick 方法异常-> " + ex, _className + ".Tmr_sacn_Tick");
    }
}
}

当用户的鼠标移动或按下键盘键时,会触发MouseMoveKeyDown事件,并调用 userOperationLastTimeMonitoringAndUpdate();。如果在设置内没有任何事件被触发,计时器会完成并调用Global.UserLogOut(true)方法来退出登录。

  • 11
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

StevenChen85

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值