后端过滤器的实现,

简介: javaEE过滤器的实现分为两步走1.(1).在相应的类中也就是你的过滤器类中拱写相应的代码,注意:,这个类要继承Filter这个接口,主要的代码是在dofilter这个方法中实现的,,大致思路是这样的,从sess...

javaEE过滤器的实现分为两步走

1.(1).在相应的类中也就是你的过滤器类中拱写相应的代码,

注意:,这个类要继承Filter这个接口,

主要的代码是在dofilter这个方法中实现的,,大致思路是这样的,从session中取出用户的登录对象

然后进行判断如果这个对象不为空,就让他继续进行访问这个项目,如果为空就强制让他转到登录界面,提示他登录失效等等, 



@Override
public void init(FilterConfig filterConfig) throws ServletException {
config=filterConfig;
}


@Override  
public void doFilter(ServletRequest request, ServletResponse response,
            FilterChain chain) throws IOException, ServletException {
  // 获得在下面代码中要用的request,response,session对象
        HttpServletRequest servletRequest = (HttpServletRequest) request;
        HttpSession session = servletRequest.getSession();
TbUser admin=(TbUser)session.getAttribute("admin");
        if(admin != null) {
            chain.doFilter(request, response);
        }else {
        // 当用户为登录或登录超时时提醒并跳转到登录界面
        String returnUrl = servletRequest.getContextPath() + "/login";
response.getWriter().println("<script language=\"javascript\">" + "alert(\"登录失效!请重新登录\");"
+ "if(window.opener==null){window.top.location.href=\"" + returnUrl
+ "\";}else{window.opener.top.location.href=\"" + returnUrl + "\";window.close();}</script>");
return;
        }

}


@Override
public void destroy() {
this.config = null;
}

2.在你的web.xml中配置你的过滤路径,注意这时的过滤的就是你要访问的网址的路径,

<!-- 配置管理员登陆过滤器 -->
<filter>
        <filter-name>AdminFilter</filter-name>
        <filter-class>com.torrow.school.filter.AdminFilter</filter-class>
    </filter>


    <filter-mapping>
        <filter-name>AdminFilter</filter-name>
        <url-pattern>/link/*</url-pattern>
</filter-mapping>

<filter-mapping>
        <filter-name>AdminFilter</filter-name>
        <url-pattern>/category/*</url-pattern>
</filter-mapping>

<filter-mapping>
        <filter-name>AdminFilter</filter-name>
        <url-pattern>/general/*</url-pattern>
</filter-mapping>

<filter-mapping>
        <filter-name>AdminFilter</filter-name>
        <url-pattern>/message/*</url-pattern>
</filter-mapping>

<filter-mapping>
        <filter-name>AdminFilter</filter-name>
        <url-pattern>/others/*</url-pattern>
</filter-mapping>

<filter-mapping>
        <filter-name>AdminFilter</filter-name>
        <url-pattern>/news/*</url-pattern>
</filter-mapping>

<filter-mapping>
        <filter-name>AdminFilter</filter-name>
        <url-pattern>/user/*</url-pattern>
</filter-mapping>

相关文章
|
19天前
|
API 持续交付 开发者
后端开发中的微服务架构实践与挑战
在数字化时代,后端服务的构建和管理变得日益复杂。本文将深入探讨微服务架构在后端开发中的应用,分析其在提高系统可扩展性、灵活性和可维护性方面的优势,同时讨论实施微服务时面临的挑战,如服务拆分、数据一致性和部署复杂性等。通过实际案例分析,本文旨在为开发者提供微服务架构的实用见解和解决策略。
|
2天前
|
Web App开发 JavaScript 前端开发
Node.js 是一种基于 Chrome V8 引擎的后端开发技术,以其高效、灵活著称。本文将介绍 Node.js 的基础概念
Node.js 是一种基于 Chrome V8 引擎的后端开发技术,以其高效、灵活著称。本文将介绍 Node.js 的基础概念,包括事件驱动、单线程模型和模块系统;探讨其安装配置、核心模块使用、实战应用如搭建 Web 服务器、文件操作及实时通信;分析项目结构与开发流程,讨论其优势与挑战,并通过案例展示 Node.js 在实际项目中的应用,旨在帮助开发者更好地掌握这一强大工具。
12 1
|
12天前
|
存储 SQL API
探索后端开发:构建高效API与数据库交互
【10月更文挑战第36天】在数字化时代,后端开发是连接用户界面和数据存储的桥梁。本文深入探讨如何设计高效的API以及如何实现API与数据库之间的无缝交互,确保数据的一致性和高性能。我们将从基础概念出发,逐步深入到实战技巧,为读者提供一个清晰的后端开发路线图。
|
6天前
|
JSON API 开发者
构建高效API:后端开发中的RESTful最佳实践####
在数字化时代,API作为不同系统间通信的桥梁,其重要性日益凸显。本文将深入探讨RESTful API的设计原则与最佳实践,通过实际案例分析,揭示如何构建高效、可维护且易于使用的API接口,助力后端开发者提升项目质量与用户体验。 ####
|
7天前
|
JSON 缓存 API
探索后端开发中的RESTful API设计原则
【10月更文挑战第41天】在后端开发的广阔天地中,API的设计如同绘制一幅精细的地图,指引着数据的流向和前端的交互。本文将带你走进RESTful API的世界,一起探索如何用简洁高效的设计原则来构建一个清晰、可维护且易于理解的API结构。我们将从RESTful API的基础概念出发,通过实际案例分析,揭示如何在实践中应用这些设计原则,并讨论如何在复杂的业务逻辑中保持API的简洁性和一致性。
|
11天前
|
JSON 前端开发 API
后端开发中的API设计与文档编写指南####
本文探讨了后端开发中API设计的重要性,并详细阐述了如何编写高效、可维护的API接口。通过实际案例分析,文章强调了清晰的API设计对于前后端分离项目的关键作用,以及良好的文档习惯如何促进团队协作和提升开发效率。 ####
|
13天前
|
存储 SQL 数据库
深入浅出后端开发之数据库优化实战
【10月更文挑战第35天】在软件开发的世界里,数据库性能直接关系到应用的响应速度和用户体验。本文将带你了解如何通过合理的索引设计、查询优化以及恰当的数据存储策略来提升数据库性能。我们将一起探索这些技巧背后的原理,并通过实际案例感受优化带来的显著效果。
30 4
|
12天前
|
Web App开发 JavaScript 前端开发
深入浅出Node.js后端开发
【10月更文挑战第36天】本文将引导您探索Node.js的世界,通过实际案例揭示其背后的原理和实践方法。从基础的安装到高级的异步处理,我们将一起构建一个简单的后端服务,并讨论如何优化性能。无论您是新手还是有经验的开发者,这篇文章都将为您提供新的视角和深入的理解。
|
17天前
|
Web App开发 存储 JavaScript
深入浅出Node.js后端开发
【10月更文挑战第31天】本文将引导你进入Node.js的奇妙世界,探索其如何革新后端开发。通过浅显易懂的语言和实际代码示例,我们将一起学习Node.js的核心概念、搭建开发环境,以及实现一个简单但完整的Web应用。无论你是编程新手还是希望拓展技术的开发者,这篇文章都将为你打开一扇通往高效后端开发的大门。

热门文章

最新文章