场景

  一般javaweb网站都有用户登录,而有一些操作必须用户登录才能进行,常见流程:用户请求--》后台判断是否登录--》没登录跳转到登录界面,登录用户正常操作

解决思路

  在用过滤器过滤请求,判断是否登录,如果未登录,返回参数跳转的登录界面,登录了的请求放行

具体实现

  •   新建一个web工,参考:【Maven】Eclipse 使用Maven创建Java Web项目
  •   新建一个LoginFilter过滤器类,继承Filter类
     package com.test.login;
    
     import java.io.IOException;
    import java.io.PrintWriter;
    import java.util.ArrayList;
    import java.util.List; 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.HttpServletResponse;
    import javax.servlet.http.HttpSession; public class LoginFilter implements Filter { public static List<String> pattenURL = new ArrayList<String>(); @Override
    public void destroy() {
    // TODO Auto-generated method stub } @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
    throws IOException, ServletException { HttpServletRequest httpRequest = (HttpServletRequest) request;
    HttpServletResponse httpResponse = (HttpServletResponse) response;
    HttpSession session = httpRequest.getSession();
    // 登陆url
    String loginUrl = httpRequest.getContextPath() + "/login.jsp";
    String url = httpRequest.getRequestURI().toString(); // 注:在pattenURL中的全部不拦截 url.indexOf(urlStr) > -1 表示urlStr在url中出现过,出现就不拦截
    for (String urlStr : pattenURL) {
    if (url.indexOf(urlStr) > -1) {
    chain.doFilter(request, response);
    return;
    }
    } //超时处理,ajax请求超时设置超时状态,页面请求超时则返回提示并重定向,session.getAttribute("")是获取到登录人的session信息
    if (session.getAttribute("") == null) {
    // 判断是否为ajax请求
    if (httpRequest.getHeader("x-requested-with") != null
    && httpRequest.getHeader("x-requested-with").equalsIgnoreCase("XMLHttpRequest")) {
    httpResponse.addHeader("sessionstatus", "timeOut"); // 返回超时标识
    httpResponse.addHeader("loginPath", loginUrl);// 返回url
    chain.doFilter(request, response);// 不可少,否则请求会出错
    } else {
    // alert('会话过期,请重新登录');
    String str = "<script language='javascript'>" + "window.top.location.href='" + loginUrl + "';</script>";
    response.setContentType("text/html;charset=UTF-8");// 解决中文乱码
    try {
    PrintWriter writer = response.getWriter();
    writer.write(str);
    writer.flush();
    writer.close();
    } catch (Exception e) {
    e.printStackTrace();
    }
    }
    } else {
    chain.doFilter(request, response);
    }
    } /**
    * 过滤器初始化调用方法 在pattenURL中的全部不拦截,所以上面会使用:path.indexOf(urlStr) > -1
    */
    @Override
    public void init(FilterConfig config) throws ServletException {
    pattenURL.add("login.jsp");// 登录jsp
    pattenURL.add("login.do");// 登录方法
    pattenURL.add("css");// css
    pattenURL.add("image");// image
    pattenURL.add("js");// js
    pattenURL.add("fonts");// fonts } }
  •   在web.xml中注册过滤器
     <?xml version="1.0" encoding="UTF-8"?>
    <web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"> <display-name>test-login</display-name> <!-- 登录过滤器  -->
    <filter>
    <description>登录过滤器</description>
    <filter-name>loginFilter</filter-name>
    <filter-class>com.test.login.LoginFilter</filter-class>
    </filter>
    <filter-mapping>
    <filter-name>loginFilter</filter-name>
    <url-pattern>/*</url-pattern>
    </filter-mapping>
      
    <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
    </welcome-file-list> </web-app>
  •   引入一个全局的js。用户控制ajax请求,如果是ajax请求的话,跳转到登录界面。js代码主要是真对所有ajax请求进行跳转的,所以如果有的ajax不想被过滤拦截,则只需要写上:global:false即可不被拦截到
     /* 
     * 说明:此处是调用ajax方法时,判断session是否过期 
     *  
     * 注:如果不想让ajax方法受这个影响,可以在ajax方法中写: global:false 
     * 如下: 
     * $.ajax({ 
     *    url:"test.html", 
     *    global:false    //不触发全局ajax事件 
     * }) 
     *  
     * **/  
      
    $(document).ajaxComplete(function(event, xhr, settings) {   
        if(xhr.getResponseHeader("sessionstatus")=="timeOut"){   
            if(xhr.getResponseHeader("loginPath")){  
                alert("登录过期,请重新登录...");  
                window.location.replace(xhr.getResponseHeader("loginPath"));
            }else{   
                //alert("请求超时请重新登陆 !");   
            }   
        }   
    }); 

【Java】JavaWeb 登录检查及界面跳转的更多相关文章

  1. springMVC 拦截器如何做登录检查及页面跳转

    一个非常简单的登录权限拦截器 问题一:登录页面的提交请求肯定是要过滤掉的,目前采用在xml里配置<mvc:mapping path="/supplier/*"/>来过滤 ...

  2. Java Web登录界面

    非常激动的开通了我的第一个博客,在这里希望大家能多多指点,相互学习. 一个简单的登录界面 首先我们先把这个登录分为三块: 一.数据库 数据库我用的是MYSQL: 二.前端 三.后台 1.  后台代码的 ...

  3. java web登录界面 源代码

    大概流程: 在java web项目中 导入sqljdbc4的包 在java Resources中完成java代码 在webContent 下建立一个存放自己写jsp的文件夹 将sqljdbc4和jst ...

  4. java 自动登录代码

    javaBean的代码    package bean;    import java.io.Serializable;    public class Admin implements Serial ...

  5. angular利用ui-router登录检查

    angular利用ui-router登录检查 SAP都会有这个问题,session过期或者页面被刷新的情况下应该进入登录页. 监听ui-router的satte事件可以实现当state切换的时候检查登 ...

  6. java单点登录原理与简单实现

    一.单系统登录机制 1.http无状态协议 web应用采用browser/server架构,http作为通信协议.http是无状态协议,浏览器的每一次请求,服务器会独立处理,不与之前或之后的请求产生关 ...

  7. angular中的 登录检查 和 过期Session清理

    angular利用ui-router进行登录检查 SAP都会有这个问题,session过期或者页面被刷新的情况下应该进入登录页. 监听ui-router的satte事件可以实现当state切换的时候检 ...

  8. 【struts2】自定义登录检查拦截器

    在实际开发中,一个常见的功能要求是:有很多操作都需要登录后才能操作,如果操作的时候还没有登录,那么通常情况下会要求跳转回到登录页面. 1)如何实现这样的功能呢? 在具体实现之前,先来考虑几个问题: ( ...

  9. 界面跳转+信息传递+AS中如何将ADV转移到其他盘中

    今日所学:界面跳转 信息传递 遇到的问题: 昨天遇到不能新建java类,在网上百度了很多,大多原因是没有新建java类的模板,但是我有,换了一个新的新建的方式后,发现虽然能建立了,但在测试时还是不能页 ...

随机推荐

  1. 【pyspider】启动爬虫后在results页面没有看到结果

    今天根据书上的介绍写了一个简单爬虫,爬取豌豆荚里面APP的基本信息,但是在调试结果正常后,发现跳转到result页面后没有看到结果. 后来上网查了一下,发现要在def detail_page(self ...

  2. oracle中case...when的用法

    全表的内容 case...when可以解决在显示的时候想显示别的名称的例子, 用的最多的地方就是性别, 比如上面的表中的性别是由'1'和'0'表示的, 但是实际显示出来在页面上给客户看是不可取的, 这 ...

  3. Java 中的 static 使用

    Java语言基础--static 0.目录 8.static 8.1 Java 中的 static 使用之静态变量 8.2 Java 中的 static 使用之静态方法 8.3 Java 中的 sta ...

  4. 纯css3棋盘图案背景以及45度斜纹背景

    css代码  .stripes {     height: 250px;     width: 375px;     float: left;          margin: 10px;      ...

  5. Jenkins+sonar7.3集成

    Jenkins安装请参考:https://blog.csdn.net/CheNorton/article/details/50327825?utm_source=copy Jenkins更新请参考:h ...

  6. vue element upload上传、清除等

    如果项目中可以使用file-list,那我们可以点击file-list删除文件列表: 有时候项目中是不要这个文件列表的,所以在上传成功以后,文件列表一直存在,要重新上传就必须刷新页面,所以我们需要手动 ...

  7. poj2635(千进制取模+同余模定理)

    题目链接:https://www.cnblogs.com/kuangbin/archive/2012/04/01/2429463.html 题意:给出大数s (s<=10100) ,L (< ...

  8. ceph luminous 新功能之内置dashboard 之 mgr功能模块配置

    前言 ceph luminous版本新增加了很多有意思的功能,这个也是一个长期支持版本,所以这些新功能的特性还是很值得期待的,从底层的存储改造,消息方式的改变,以及一些之前未实现的功能的完成,都让ce ...

  9. 在IDEA中使用gradle配置打可执行jar包[可执行jar与其所依赖的jar分离]

    下面是我的项目的build.gradle文件的所有内容,注意高亮部分是关键: group 'com.xbs' version '1.0-SNAPSHOT' apply plugin: 'java' a ...

  10. linux查看本服务端口开放情况

    在Linux使用过程中,需要了解当前系统开放了哪些端口,并且要查看开放这些端口的具体进程和用户,可以通过netstat命令进行简单查询. 1.netstat命令各个参数说明如下: -t : 指明显示T ...