1.概述

Servlet过滤器可以对用户提交的数据或服务器返回的数据进行更改。任何到达服务器的请求都会首先经过过滤器的处理。本实例应用过滤器的这个特点,编写了一个在过滤器中统计网站流量的实例。

本实例的设计思路:主体是在过滤器中通过文本文件来存储和读取网站访问量的数据,并且应用自定义变量和session变量防止因页面刷新而导致统计数据不准确。

首先创建Flux_Data类,通过ReadFile()和WriteFile()方法读取和写入数据;然后创建Filter_flux类,应用Filter统计网站的流量,判断自定义变量和session变量的值是否相同,根据判断结果执行不同的操作。

2.技术要点

本实例主要应用Servlet过滤器(Filter),有关Filter接口中提供的方法的详细讲解请参考实例108。

在doFilter()方法中,应用了synchronized关键字。通过synchronized修饰的方法在执行过程中不会中断(即线程一旦进入synchronized修饰的方法,其他线程就会被阻塞,直到当前线程执行完这个方法为止)。从而避免了在Web系统中多用户访问系统时,出现多用户同时修改变量的值而引发的冲突,导致统计数据的不准确。

为了确保统计数据的准确性,还应用到一个自定义变量flux和session变量flux,通过判断二者的值,根据判断结果执行不同的操作。

判断当自定义变量的值等于0时,将自定义变量值加1,并将该值赋给session变量,通过WriteFile()方法将数据0写入到文本文件中。

判断当自定义变量的值与session变量的值相同时,直接调用ReadFile()方法,读取文本文件中的数据;否则将调用WriteFile()方法将统计的数据加1后重新写入到文本文件中。

3.具体实现

(1)首先创建index.jsp文件,输出从Request请求中获取的网站流量的数据。

(2)编写Flux_Data类,创建ReadFile()方法读取文本文件中存储的数据;创建WriteFile()方法向文本文件中写入数据。其关键代码如下:

public class Flux_Data {
private String record = null; //保存文本的变量
private BufferedReader file; //BufferedReader对象,用于读取文件数据
private String path; //文件完整路径
//ReadFile方法用来读取文件filePath中的数据,并返回这个数据
public String ReadFile(String filePath) throws FileNotFoundException {
path = filePath;
file = new BufferedReader(new FileReader(path)); //创建新的BufferedReader对象
String result = null;
try {
record = file.readLine(); //读取一行数据并保存到currentRecord变量中
} catch (IOException e) { //抛出错误
System.out.println("数据读取失败!");
}
if (record == null) { //如果文件为空
result = "没有任何记录";
} else { //文件不为空
result = record;
}
return result; //返回读取文件的结果
}
//创建WriteFile方法,将数据counter+1后,并将结果重新写入到文本文件filePath中
public void WriteFile(String filePath, String counter) throws
FileNotFoundException {
path = filePath;
int count = Integer.parseInt(counter) + 1; //将counter转换为int类型并加一
try {
//创建PrintWriter对象,用于写入数据到文件中
PrintWriter pw = new PrintWriter(new FileOutputStream(filePath));
pw.println(count); //用文本格式打印整数count
pw.close(); //清除PrintWriter对象
} catch (IOException e) {
System.out.println("文件写入失败" + e.getMessage());
}
}
}

(3)创建Filter_flux类,应用Filter统计网站的流量,并且将统计的数据通过WriteFile()方法写入到指定的文本文件中,然后通过ReadFile()方法读取出文本文件中的数据,在index.jsp文件中输出流量数据。其关键代码如下:

public class Filter_flux extends HttpServlet implements Filter {
private static int flux = 0; //定义变量
private String file_path="D:/JavaFlsc/过滤器分析流量/build/web/count.txt"; //定义文本文件的位置
public void init(FilterConfig filterConfig) throws ServletException {
}
public synchronized void doFilter(ServletRequest request, ServletResponse response,
FilterChain Chain) throws
ServletException, IOException {
HttpSession session = ((HttpServletRequest) request).getSession();
Flux_Data data=new Flux_Data(); //实例化数据的读取和写入的类
if(flux==0){
this.flux++;
session.setAttribute("flux", flux); //将flux的值写入到session中
data.WriteFile(file_path, "0"); //调用WriteFile方法,将数据加1
String count = data.ReadFile(file_path); //重新读取数据
request.setAttribute("count", String.valueOf(count));
}
if (flux == session.getAttribute("flux")) { //判断当flux的值等于session的值时,直接读取记录
String count = data.ReadFile(file_path); //调用ReadFile方法,读取数据
request.setAttribute("count", String.valueOf(count));
}else {
this.flux++; //flux值增加
session.setAttribute("flux", flux); //将flux的值写入到session中
String counts = data.ReadFile(file_path); //读取文本文件中的数据
data.WriteFile(file_path, counts); //调用WriteFile方法,将数据加1
String count = data.ReadFile(file_path); //重新读取数据
request.setAttribute("count", String.valueOf(count));
}
Chain.doFilter(request, response);
}
public void destroy() {
}
}

(4)最后在web.xml文件中配置Filter_flux类。完成过滤器的初始化操作。首先通过<filter></filter>标签配置Servlet过滤器名称和所在包的类名,然后再通过<filter-mapping> </filter-mapping>标签配置Servlet过滤器的映射路径,其关键代码如下:

<filter>
<!—servlet过滤器的名称 -->
<filter-name>Filter_flux</filter-name>
<!—servlet过滤器的包所在类名称-->
<filter-class>com.pkh.Filter_flux</filter-class>
</filter>
<filter-mapping>
<!--要映射的servlet过滤器名称-->
<filter-name>Filter_flux</filter-name>
<!--要映射的servlet过滤器映射的范围-->
<url-pattern>/ *</url-pattern>
<dispatcher>REQUEST</dispatcher>
<dispatcher>FORWARD</dispatcher>
</filter-mapping>

Servlet过滤器——过滤器分析流量的更多相关文章

  1. 面试之servlet、过滤器、监听器

    servlet.过滤器.监听器servlet是Java中WEB请求和响应的容器servlet的运行需要在类似tomcat容器中,一个 Web 应用对应一个 Context 容器,也就是 Servlet ...

  2. Servlet的过滤器Filter

    Servlet 编写过滤器 Servlet 过滤器可以动态地拦截请求和响应,以变换或使用包含在请求或响应中的信息. 可以将一个或多个 Servlet 过滤器附加到一个 Servlet 或一组 Serv ...

  3. javaWeb中servlet开发——过滤器

    servlet开发--过滤器(filter) servlet有三种,分为简单servlet.过滤器servlet.监听servlet 简单servlet是作为一种程序所必须的开发结构保存的,继承htt ...

  4. Servlet之过滤器(Filter)和监听器(Listener)

    过滤器 过滤器是一个java组件,可以拦截发送至某个servelet,jsp页面或静态页面的请求,可以在响应发送到客户之前进行拦截 工作原理: 过滤器类必须实现 Filter 接口,包含的方法如下: ...

  5. STM32之CAN通讯接收过滤器过滤分析

    一.前言 学习了CAN通讯,底层的东东CAN控制器已经帮你处理完成,也就是CAN通讯协议已经做好,你按协议格式往对应的位扔数据发送就好,所以使用CAN通讯,我们只需要去关心制定发送的数据间的协议,也就 ...

  6. java过滤器(过滤器排序)

    java过滤器(过滤器排序) 定义过滤器顺序是很简单的:匹配请求的过滤器将按照它们出现在部署描述符或者编程式配置中的顺序添加到过滤器链中(记住,如果同时再部署描述符或者编程式配置中设置了一些过滤器,那 ...

  7. MapReduce分析流量汇总

    一.MapReduce编程规范 一.MapReduce编程规范 用户编写mr程序主要分为三个部分:Mapper,Reducer,Driver 1.Mapper阶段 (1)用户自定义Mapper类 要继 ...

  8. 动手学servlet(六) 过滤器和监听器

     过滤器(Filter) 过滤器是在客户端和请求资源之间,起一个过滤的作用,举个例子,比如我们要请求admin文件夹下的index.jsp这个页面,那么我们可以用一个过滤器,判断登录用户是不是管理员 ...

  9. java servlet之过滤器1(解决jsp之间POST方式数据传递乱码)

    首先,看看没有解决乱码的效果,新建两个jsp页面(a.jsp跳转到b.jsp). <form action="b.jsp" method="post"&g ...

随机推荐

  1. 海量数据处理算法—Bloom Filter

    海量数据处理算法—Bloom Filter 1. Bloom-Filter算法简介 Bloom-Filter,即布隆过滤器,1970年由Bloom中提出.它可以用于检索一个元素是否在一个集合中. Bl ...

  2. WebLech是一个功能强大的Web站点下载与镜像工具

    WebLech是一个功能强大的Web站点下载与镜像工具.它支持按功能需求来下载web站点并能够尽可能模仿标准Web浏览器的行为.WebLech有一个功能控制台并采用多线程操作. http://sour ...

  3. [转]tripwire-文件指纹

    原文链接:http://www.ipython.me/centos/tripwire-file-md5.html Tripwire是目前最为著名的unix下文件系统完整性检查的软件工具,这一软件采用的 ...

  4. Nginx的500,502,504错误解决方法

    Nginx的500,502,504错误解决方法 一.解决500错误: 1.500错误指的是服务器内部错误,也就是服务器遇到意外情况,而无法履行请求. 2.500错误一般有几种情况: (1)web脚本错 ...

  5. Git 将本次修改追加在上一次修改上面

    Git 将本次修改追加在上一次修改上面 git add . git commit --amend 之后就是进入日志提交页面 确保change-Id那条记录出现在最后一行,如: zh-->en 修 ...

  6. 分享非常有用的Java程序 (关键代码) (三)---创建ZIP和JAR文件

    原文:分享非常有用的Java程序 (关键代码) (三)---创建ZIP和JAR文件 import java.util.zip.*; import java.io.*; public class Zip ...

  7. mysql 行锁排查

    <pre name="code" class="html">mysql 锁表: 隔离级别使用RR: mysql> SELECT @@GLOBA ...

  8. Python 文本解析器

    Python 文本解析器 一.课程介绍 本课程讲解一个使用 Python 来解析纯文本生成一个 HTML 页面的小程序. 二.相关技术 Python:一种面向对象.解释型计算机程序设计语言,用它可以做 ...

  9. [Boost]boost的时间和日期处理-(1)日期的操作

    <开篇> Boost.DateTime库提供了时间日期相关的计算.格式化.转换.输入输出等等功能,为C++的编程提供了便利.不过它有如下特点: 1. Boost.DateTime 只支持1 ...

  10. Eclipse一个打开文件夹目录插件——Open In Explorer

    MyEclipse开发的都常用到其中一个"Open In Explorer"的小插件,可以直接在Windows资源管理器中打开选中文件所在的目录,工具虽小,但我们经常需要用到它 由 ...