实验8 Servlet过滤器与监听器

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

/view/4636a813a2161479

1711280c.html

实验8 Servlet过滤器与监听器

第一部分 Servlet过滤器

一、实验目的

1. 了解过滤器的作用;

2. 掌握过滤器的开发与部署的步骤;

3. 了解过滤器链。

二、实验原理

过滤器是web服务器上的组件,它们对客户和资源之间的请求和响应进行过滤。

过滤器的工作原理是:当servlet容器接收到对某个资源的请求,它要检查是否有过滤器与之关联。如果有过滤器与该资源关联,servlet容器将把该请求发送给过滤器。在过滤器处理完请求后,它将做下面3件事:

∙产生响应并将其返回给客户;

∙如果有过滤器链,它将把(修改过或没有修改过)请求传递给下一个过滤器;

∙将请求传递给不同的资源。

当请求返回到客户时,它是以相反的方向经过同一组过滤器返回。过滤器链中的每个过滤器够可能修改响应。

过滤器API主要包括:Filter、FilterConfig和FilterChain接口。

三、实验内容与步骤

(一)编写一个过滤器审计用户对资源的访问。

【步骤1】该过滤器实现的功能是,当用户访问应用程序任何资源时,将用户的IP地址和主机名写入日志文件中,过滤器代码如下:

package filter;

import java.io.IOException;

import javax.servlet.*;

import javax.servlet.http.*;

public class AuditFilter implements Filter {

protected FilterConfig config;

public void init(FilterConfig filterConfig)

throws ServletException {

this.config = filterConfig;

}

public void doFilter(ServletRequest request,

ServletResponse response,FilterChain chain)

throws IOException, ServletException {

HttpServletRequest req = (HttpServletRequest)request;

HttpServletResponse res = (HttpServletResponse)response;

String addr = req.getRemoteAddr();

String user = req.getRemoteHost();

config.getServletContext().log("RemoteAddress:"+addr+

",RemoteHost:"+user);

chain.doFilter(req, res);

}

public void destroy() {

}

}

【步骤2】配置过滤器。在部署描述文件web.xml中配置过滤器:

AuditFilter

filter. AuditFilter

AuditFilter

/*

上述代码中过滤器映射使用的URL模式为/*,这表示将该过滤器映射到Web应用程序的任何资源。如果只对某些资源(如JSP页面审计,则可以指定具体的资源)。

【步骤3】访问该应用程序中的任何一个资源,如使用下面的URL访问onlineCount.jsp:http://localhost:8080/ helloapp/onlineCount.jsp

然后打开\logs目录中的localhost.2006-02-05.log文件中有下面一行(访问多个资源就会有多行):

信息: RemoteAddress:127.0.0.1,RemoteHost:127.0.0.1

(二)编写一个过滤器改变请求编码。

【步骤1】编写一个loginform.html文件,代码如下:

使用过滤器改变请求编码

请输入用户名和口令:

用户名:
口令: