一.续上文
不允许直接访问jsp处理方式一WEB-INF
介绍了WEB-INF来处理直接访问jsp,本文介绍过滤器来处理直接访问jsp。
二.直接上代码
<filter>
<filter-name>jspFilter</filter-name>
<filter-class>com.cb.cbms.coreserver.servlet.JspFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>jspFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
package com.cb.cbms.coreserver.servlet;
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.HttpServletResponse;
/**
* 不允许直接访问jsp
* 所有对jsp的直接访问,跳转到首页面
* @author eason
*
*/
public class JspFilter implements Filter {
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
HttpServletRequest httpServletRequest = (HttpServletRequest) request;
HttpServletResponse httpServletResponse = (HttpServletResponse) response;
String url = httpServletRequest.getRequestURI();
if(url != null && url.endsWith(".jsp")) {
httpServletResponse.sendRedirect(httpServletRequest.getContextPath());
return;
}
chain.doFilter(request, response);
}
@Override
public void destroy() {
}
@Override
public void init(FilterConfig arg0) throws ServletException {
}
}
三.
过滤器与
拦截器的区别
- 概念
- 过滤器:访问web服务器的时候,对一个请求,我们可以设置请求编码,设置请求参数,设置其是否能访问某个页面,设置相应编码等。
- 拦截器:访问web服务器的时候,在你调用的方法前做一个拦截,加上我想要的任意操作。比喻记录操作日志,加上某个特定业务(AOP)。
- 区别
- 过滤器是用函数回调实现的。拦截器是用反射实现的。这个是根本区别,造成了两者的不同用途。
- 过滤器是servlet里面的概念。拦截器是action里面的概念。
- 过滤器对配置的所有请求均有效,如上文里/*就是所有请求。拦截器只对action有效。
- 拦截器可以访问action上下文,值栈里的对象,而过滤器不能访问。
- 触发顺序
- 开始调用某方法。
- 过滤器。
- 拦截器。
- 真正执行方法。
- 拦截器后。
package com.skylark.service.interceptor;
/**
* LogInterceptor, spring Interceptor
* @author eason
*
*/
public class LogInterceptor extends LogConstant implements MethodInterceptor {
@Override
public Object invoke(MethodInvocation invocation) throws Throwable {
Object rval = null;
try {
List<String> contentList = getContentList(invocation);
rval = invocation.proceed();
logInformation(invocation, contentList);
} catch (InvocationTargetException e) {
log.error("invoke fail " + e);
e.printStackTrace();
}
return rval;
}
/**拦截器后
* 当invocation.proceed()即真正的方法顺利执行后,
* 调用此方法将操作日志写入数据库
* @param invocation
*/
private void logInformation(MethodInvocation invocation, List<String> contentList)
throws Exception {
...
}
}
- 过滤器后。上文的destory()方法。
分享到:
相关推荐
Servlet过滤器是Java Web开发中的一个重要概念,它允许开发者在请求到达Servlet之前或者Servlet响应返回客户端之前进行拦截处理。在本实例中,我们将深入探讨Servlet过滤器(Filter)的使用和实现,以及它在实际应用...
综上所述,使用servlet+jsp实现过滤器,可以有效地防止未登录用户访问受保护页面。开发者可以灵活地定义过滤器的行为,并且通过配置文件将过滤器与具体的URL模式关联起来,实现复杂的权限控制逻辑。
在这个项目中,“jsp+servlet登录验证过滤器”涉及了用户登录验证的过程,以及使用过滤器(Filter)来实现这一功能。下面将详细介绍这个主题中的相关知识点。 1. **JSP**:JSP是一种服务器端的技术,允许开发者在...
Servlet过滤器是Java Web开发中的一个重要概念,它允许开发者在HTTP请求到达Servlet之前或之后进行拦截处理。在标题"Servlet过滤器的简单使用源码+文档"中,我们可以理解为这个压缩包包含了一个关于Servlet过滤器的...
它不直接生成请求或响应,而是作为一个中间件存在,能够在请求到达目标Servlet或JSP页面前对`ServletRequest`对象进行检查和修改,同样,在响应返回给客户端之前,过滤器也有机会修改`ServletResponse`对象。...
6. **高级特性**:深入学习Servlet和JSP的高级特性,如过滤器(Filter)、监听器(Listener)等。 7. **项目实战**:参与真实的项目开发,提高解决实际问题的能力。 通过上述步骤的学习,可以帮助初学者系统地掌握...
在实际学习过程中,你可能还会涉及到Web容器的概念、部署描述符(web.xml)、请求和响应对象的使用、会话管理、Cookie、过滤器和监听器等进阶话题。通过不断实践和理解,你将能够熟练掌握这两种技术,为构建复杂的...
- **定义**:过滤器是一种基于Java Servlet API的组件,它在请求被Servlet处理之前和之后进行拦截。根据配置,过滤器可以对请求或响应进行修改、拦截、日志记录等操作。 - **工作原理**:过滤器遵循`Filter`接口,...
本书还涵盖了文本处理、图片验证、自动登录、验证过滤器、压缩处理、JSTL应用与操作等各种实用范例。 本书在讲解的过程中,以“微博”项目贯穿全书,随着每一章的讲述都在适当的时候将JSP & Servlet技术应用于...
在 `web.xml` 文件中,开发者可以配置 JSP 页面、Servlet、过滤器和监听器的行为,以及定义 URL 映射、错误处理等。它是整个 Web 应用的配置中心。 9. **常见错误** 在 JSP 和 Servlet 开发中,常见的错误包括...
- `Filter`和`FilterChain`: 用于实现请求过滤器,可以在请求到达Servlet之前进行预处理,或在响应发送回客户端之后进行后处理。 - `DispatcherType`: 定义了不同的请求调度类型,如REQUEST、FORWARD、INCLUDE等。...
2. **过滤器(Filter)**: 过滤器是Java Web应用中的另一种重要组件,它允许开发者在请求到达目标资源(如Servlet或JSP页面)之前和之后进行拦截处理。过滤器通过实现`javax.servlet.Filter`接口并配置在web.xml文件...
7. **过滤器(Filter)和监听器(Listener)**:这两种组件在Servlet容器中的作用,如何使用它们增强应用的功能,比如日志记录、会话管理等。 8. **Servlet配置**:web.xml文件的使用,以及在现代应用中采用注解...
8.Servlet的过滤器:Servlet的过滤器的使用和实现 9.JSP和Servlet的安全机制:JSP和Servlet的安全机制和实现 通过学习本资源,您将掌握JSP和Servlet的基本概念和高级主题,提高自己的Web开发能力。
而Filter(过滤器)是Servlet API的一部分,它提供了一种机制,可以在请求到达目标资源之前或之后对请求和响应进行拦截处理。Filter在处理Web请求时扮演着不可或缺的角色,比如日志记录、权限验证、内容压缩等。以下...
2. 接下来,在`web.xml`配置文件中定义这个过滤器: ```xml ... <filter-name>CharacterEncodingFilter <filter-class>com.example.CharacterEncodingFilter</filter-class> <filter-name>...
在Java Web开发中,`JSP` 和 `Servlet` 是两个关键组件,它们共同构建了动态Web应用...同时,过滤器提供了一种优雅的方式,让我们可以在请求到达目标资源之前进行预处理,确保只有已登录的用户才能访问受保护的页面。
在JavaServer Pages (JSP) 中,Servlet技术是不可或缺的一部分,它提供了服务器端处理动态内容的能力。而过滤器(Filter)和侦听器(Listener)是Servlet规范中的两个重要概念,它们增强了应用的功能和灵活性。 **...