Java后端长时间无操作自动退出的实现方式

目录
  • Java后端长时间无操作自动退出
    • 使用session(最优)
    • 使用拦截器
  • 对于登陆长时间未操作超时退出问题
    • 首先设置一个拦截器
    • 然后进行配置文件
    • 页面以及调用
    • 页面

Java后端长时间无操作自动退出

使用session(最优)

设置session的过期时间,长时间(例如30分钟)无请求就会自动清除,达到长时间无操作自动退出的目的

server:
port: 9201
session:
timeout: 1800

使用拦截器

实现思路:每次请求后台时,在拦截器中刷新session,设置session时间为30分钟,这样请求每次进来都会重新设置session的过期时间

对于登陆长时间未操作超时退出问题

首先设置一个拦截器

import java.io.IOException; 
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
 
/**
 * 全局session拦截器
 * 
 * @author shenyanwei
 * @date:2016年11月18日 下午1:33:40
 * @version
 */
public class SessionFilter implements Filter {
 
    /*
     * (non-Javadoc)
     * 
     * @see javax.servlet.Filter#destroy()
     */
    @Override
    public void destroy() {
    }
 
    /*
     * (non-Javadoc)
     * 
     * @see javax.servlet.Filter#doFilter(javax.servlet.ServletRequest,
     * javax.servlet.ServletResponse, javax.servlet.FilterChain)
     */
    @Override
    public void doFilter(ServletRequest request, ServletResponse response,
            FilterChain filterChain) throws IOException, ServletException {
        HttpServletRequest httpRequest = (HttpServletRequest) request;
        // 如果不为'鉴定是否锁定的请求',将用户的请求时间放置session
        if (!httpRequest.getServletPath().equals(
                "/session/checkLastPostTime.action")) {
            HttpSession session = httpRequest.getSession(true);
            session.setAttribute("lastPostTime", System.currentTimeMillis());
        }
        // 执行之后的过滤
        filterChain.doFilter(request, response); 
    } 
    /*
     * (non-Javadoc)
     * 
     * @see javax.servlet.Filter#init(javax.servlet.FilterConfig)
     */
    @Override
    public void init(FilterConfig arg0) throws ServletException { 
    } 
}

然后进行配置文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.1.7//EN"
    "http://struts.apache.org/dtds/struts-2.1.7.dtd">
<struts>
    <!-- 全局session处理action -->
    <package name="session" namespace="/session" extends="json-default">
        <action name="*" class="sessionAction" method="{1}">
            <result name="json" type="json">
                <param name="contentType">text/html</param>
                <param name="ignoreHierarchy">false</param>
            </result>
        </action>
    </package>
</struts>

Action:

import javax.servlet.http.HttpSession; 
import org.apache.struts2.ServletActionContext;
import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Controller; 
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;
 
/**
 * 全局session处理action
 * 
 * @author shenyanwei
 * @date:2016年11月18日 下午1:59:56
 * @version
 */
@Controller
@Scope("prototype")
@SuppressWarnings("all")
public class SessionAction extends ActionSupport {
    /**
     * 鉴权用户停止操作的时间是否超过20分钟
     * 
     * @return
     */
    public String checkLastPostTime() {
        HttpSession session = ServletActionContext.getRequest().getSession();
        Object attribute = session.getAttribute("lastPostTime");
        ActionContext.getContext().getValueStack().push(false);
        if (null != attribute) {
            Long lastPostTime = (Long) attribute;
            long currentTimeMillis = System.currentTimeMillis();
            if (1200000 <= (currentTimeMillis - lastPostTime)) {
                ActionContext.getContext().getValueStack().push(true);
            }
        }
        return ReturnType.JSON;
    }
}

页面以及调用

$(function() {
      
        checkLastPostTime();
    });
var checkLastPostTimeInterval; 
    function checkLastPostTime(){
        checkLastPostTimeInterval = window.setInterval(function() {
            $.post("${pageContext.request.contextPath}/session/checkLastPostTime.action",{},
                function(result){
                    if (result) {
                        window.clearInterval(checkLastPostTimeInterval);
                        $("#checkLastPostTimeDialogError").html(" ");
                        $("#checkLastPostTimeDialog").dialog('open');
                    }
                }
            ,"json");
        }, 300000);
    }
    
    function checkLastPostTimeDialogFormSumbit(){
        if($('#checkLastPostTimeDialogForm').form('validate')){
            $.post("${pageContext.request.contextPath}/jsonLogin.action",{
                    username:$("#checkLastPostTimeDialogFormUserName").val(),
                    password:$("#checkLastPostTimeDialogFormPassword").textbox('getValue')
                },
                function(result){
                    if (result.errorMsg) {
                        $("#checkLastPostTimeDialogError").html(result.errorMsg);
                    } else {
                        $("#checkLastPostTimeDialog").dialog('close');
                        checkLastPostTime();
                    }
                }
            ,"json");
        }
    }

页面

<div id="checkLastPostTimeDialog" class="easyui-dialog" style="width:400px;height:200px;padding:20px;" data-options="title:'已锁定',border:false,closable:false,draggable:false,resizable:false,closed:true,modal:true,tools:'#checkLastPostTimeDialogTool'">
        <form id="checkLastPostTimeDialogForm" method="post">
            <div id="checkLastPostTimeDialogError" style="color:red;position:absolute;right:20px;" align="right" ></div>
            <table width="100%" >
                <tr>
                    <td >账    号:</td>
                    <td height="40px"  align="left"><shiro:principal /><input id="checkLastPostTimeDialogFormUserName" type="hidden"    style="width:220px;height:30px;line-height:30px;border-color:#5b97db;border-width: 1px;border-style: solid;" name="username" value="<shiro:principal />" /></td>
                </tr>
                <tr>
                    <td >密    码:</td>
                    <td height="40px"  align="left"><input id="checkLastPostTimeDialogFormPassword" required="true" class="easyui-textbox" type="password" style="width:220px;height:30px;line-height:30px;border-color:#5b97db;border-width: 1px;border-style: solid;" name="password" value="" /></td>
                </tr>
                <tr>
                    <td colspan="2" align="center">
                        <input class="login"  type="button" οnclick="checkLastPostTimeDialogFormSumbit();" style="width:110px;height:33px;border:0" value="" />
                    </td>
                </tr>
            </table>
        </form>
    </div>
    <div id="checkLastPostTimeDialogTool">
        <a href="#" style="width:30px;text-decoration:underline;line-height:16px;font-size:12px;" οnclick="logout();" >注销</a>
    </div>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • 详解前后端分离之Java后端

    前后端分离的思想由来已久,不妨尝试一下,从上手开始,先把代码写出来再究细节. 代码下载:https://github.com/jimolonely/AuthServer 前言 以前服务端为什么能识别用户呢?对,是session,每个session都存在服务端,浏览器每次请求都带着sessionId(就是一个字符串),于是服务器根据这个sessionId就知道是哪个用户了. 那么问题来了,用户很多时,服务器压力很大,如果采用分布式存储session,又可能会出现不同步问题,那么前后端分离就很好的解

  • 关于java后端的详解

    新手程序员通常会走入一个误区,就是认为学习了一门语言,就可以称为是某某语言工程师了.但事实上真的是这样吗?其实并非如此. 今天我们就来聊一聊,Java 开发工程师到底开发的是什么东西.准确点来说,Java后端到底在做什么? 大家都知道 Java 是一门后端语言,后端指的就是服务端,服务端代码一般运行在服务器上,通常我们运行Java 程序的服务器都是 Linux 服务器. 这些服务器在互联网公司中一般放在一个叫做机房的地方里,于是像我们这类 Java 程序员的代码一般也运行在这些机房里的服务器中.

  • java后端解决跨域的几种问题解决

    1.java过滤器过滤 允许整个项目跨域访问,可通过filter来进行过虑: public class SimpleCORSFilter implements Filter{ @Override public void destroy() { } @Override public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletExceptio

  • Java后端长时间无操作自动退出的实现方式

    目录 Java后端长时间无操作自动退出 使用session(最优) 使用拦截器 对于登陆长时间未操作超时退出问题 首先设置一个拦截器 然后进行配置文件 页面以及调用 页面 Java后端长时间无操作自动退出 使用session(最优) 设置session的过期时间,长时间(例如30分钟)无请求就会自动清除,达到长时间无操作自动退出的目的 server: port: 9201 session: timeout: 1800 使用拦截器 实现思路:每次请求后台时,在拦截器中刷新session,设置ses

  • vue实现用户长时间不操作自动退出登录功能的实现代码

    一.需求说明 昨天后端开发人员让我实现一个网页锁屏,当时我一头雾水,问他为啥搞的跟安卓系统一样.他的回复是"看起来帅点". 首先我们梳理下逻辑,先来个简化版的,用户长时间未操作时,返回登录页 二.思路 使用 mouseover 事件来监测是否有用户操作页面,写一个定时器间隔特定时间检测是否长时间未操作页面,如果是,退出登陆,清除token,返回登录页 三.实现 [1]在util文件夹下创建一个storage.js封装localStorage方法 export default { set

  • vue中js判断长时间不操作界面自动退出登录(推荐)

    需求说明,后台有做半个小时不请求接口的话返回标识退出登录,但是要请求接口才行,现在要实现前端用js判断半个小时不操作界面的话自动跳转到登录页面. 创建一个.js文件,在main.js引入此js(vue框架) 在登录成功的时候保存当前时间localStorage.setItem("lastTime",new Date().getTime()); 然后在点击的时候更新这个时间 var lastTime = new Date().getTime(); var currentTime = ne

  • Vue设置长时间未操作登录自动到期返回登录页

    Vue设置长时间未操作登录以后自动到期返回登录页 首先我们写在main.js文件中 import routerUtil from "@/utils/routerutil";//先将js文件在main.js中引入 routerUtil(router); 我们会在登陆成功后调用sessionUtil文件中的setSession,sessionUtil下面写的有 import sessionUtil from '@/utils/sessionutil' sessionUtil.setSess

  • PHP利用Cookie设置用户30分钟未操作自动退出功能

    登陆控制器需要做的登陆成功把用户ID等信息存入cookie: $this->systemSetKey(array('name'=>$admin_info['admin_name'], 'id'=>$admin_info['admin_id'],'gid'=>$admin_info['admin_gid'],'sp'=>$admin_info['admin_is_super']));//登陆成功之后做得事情 父类中的 systemSetKey 方法: /** * 系统后台 会员

  • 解决JDBC连接Mysql长时间无动作连接失效的问题

    错误场景介绍 做的有一个项目使用JDBC手动创建Connection实现了一个简单的自定义数据库连接池,用来支持Canal解析数据库Binlog指定业务库的插入修改SQL来进行数据库分表备份(按照月份)操作. 但是发现当一个一段时间(较长)没有进行数据库操作时,连接都失效了,导致SQL执行失败失效提示为No operations allowed after connection closed 查明原因 经过搜索发现这个问题是由于Mysql默认一个已创建的长连接28800秒(八小时)内没有任何动作

  • vue+Java后端进行调试时解决跨域问题的方式

    今天在开发过程中遇到一个问题,拿到了一套vue代码,计划对这套代码的部分样式进行调整,Java后端代码已经写好并且部署到了线上.这时命令行运行vue项目时访问会受限,取不下数据来,遇到了跨域访问失败的问题,这时可以怎么做呢? 首先,要了解什么叫跨域访问? 跨域,指的是浏览器不能执行其他网站的脚本.它是由浏览器的同源策略造成的,是浏览器对javascript施加的安全限制. 所谓同源是指,域名,协议,端口均相同,举个例子: http://www.123.com/index.html 调用 http

  • JavaScript实现页面无操作倒计时退出

    项目前端页面需要实现,页面没人操作进入倒计时,以下为前端代码实现. //设置(倒计时功能)开关 var _mouseActiveListener_flag = true; beforecount:触发倒计时间隔(单位:毫秒) count:倒计时总数(单位:秒) var mouseActiveListener = function (beforecount, count, callback) { //config var __countdown_html = '<div id="__tt&q

  • vue用户长时间不操作退出到登录页的两种实现方式

    目录 问题描述 前端控制(方式一) 思路 代码 后端控制(方式二) 思路 代码 总结 问题描述 产品说,出于安全考虑,用户长时间不操作,就回到登录页面,让用户重新登录,就像银行的app一样.本文就记录一下实现这种效果的两种方式,分别是前端控制和后端控制,各有细节及适用使用场景 前端控制(方式一) 思路 首先,用户长时间不操作具体表现形式是啥?其实就是事件是否长时间没有被触发执行. 比如用户长时间不操作,就没有鼠标点击(click)事件.鼠标滚轮(mousewheel)事件.鼠标移动(mousem

  • 利用JAVA反射,读取数据库表名,自动生成对应实体类的操作

    本代码是利用java反射,读取数据库表自动根据表名生成实体类,数据库采用老牌SQLSERVER 2000,驱动为JTDS,其他数据库可根据情况自定修改. 代码中包含了大部分数据库类型与JAVA类型的转换,少数未包含进去的会在生成代码时打印出来,方面后期查找修改. import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.io.PrintWriter; import java.sq

随机推荐