JSP实现网页访问统计

1. 利用application对象进行统计,得到的效果是每进入一次该网页就统计一次。但效果不怎么好,因为一般统计网页访问量,刷新是不算进统计里的,这里就是这种缺点。

具体实现是:

<%@ page language="java" import="java.util.*" pageEncoding="GB2312"%>
< html >
  < head >
  < title >java 计数器程序</ title >
  </ head >
  < body >
  <%
  if (application.getAttribute("count") == null) {
   application.setAttribute("count", new Integer(0));
  }
  Integer count = (Integer) application.getAttribute("count");
  application
    .setAttribute("count", new Integer(count.intValue() + 1));
  count = (Integer) application.getAttribute("count");
  %>
   < center >这是第<%=count.intValue()%>个访问者</ center >
  </ body >
  </ html

 2.为了解决上面的问题,有了另一种方法,就是同时利用application对象和session对象来统计,这种方法的原理是从打开浏览器到关闭浏览器算是访问一次,刷新、返回等操作不算做一次访问。但还是有缺陷,当jsp服务器从新启动时,数据也被清零了。
下面还是具体实现:

2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<%@ page language="java" import="java.util.*" pageEncoding="GB2312"%>
< html >
  < head >
  < title >java 计数器程序</ title >
  </ head >
  < body >
  <%
  int n = 0; String counter = (String)application.getAttribute("counter");
  if(counter != null){
   n = Integer.parseInt(counter);
  }
  if(session.isNew())
   ++n;
  %>
   < center >这是第<%out.print(n);%>个访问者</ center >
   <%
   counter = String.valueOf(n);
   application.setAttribute("counter", counter);
    %>
  </ body >
  </ html >


3. 第三种方法是将统计数据存储在本地的文件当中,比如存储在一个txt文件当中。
这是为了解决重启服务器之后数据不用担心会丢失。
创建一个类:JSPCount

import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;
  
  
public class JSPCount {
  //写入文件的方法
  public static void write2File(String filename, long count){
   try {
    PrintWriter out = new PrintWriter( new FileWriter(filename));
    out.println(count);
    out.close();
   } catch (IOException e) {
    // TODO: handle exception
    e.printStackTrace();
   }
  }
   
  //读文件的方法
  public static long readFromFile(String filename){
   File file = new File(filename);
   long count = 0 ;
   if (!file.exists()){
    try {
     file.createNewFile();
    } catch (IOException e) {
     // TODO Auto-generated catch block
     e.printStackTrace();
    }
    write2File(filename, 0 );
   }
   try {
    BufferedReader in = new BufferedReader( new FileReader(file));
    try {
     count = Long.parseLong(in.readLine());
    }
    catch (NumberFormatException e) {
     // TODO: handle exception
     e.printStackTrace();
    } catch (IOException e) {
     // TODO Auto-generated catch block
     e.printStackTrace();
    }
   } catch (FileNotFoundException e) {
    // TODO: handle exception
    e.printStackTrace();
   }
   return count;
  }

 在WebRoot目录下建jsp文件:count.jsp

<%@ page language="java" import="java.util.*" pageEncoding="GB2312"%>
<%@ page import="org.wwj.count.JSPCount" %>
< html >
  < head >
  < title >java 计数器程序</ title >
  </ head >
  < body >
  <%
  JSPCount CountFileHandler = new JSPCount();
  //读取文件
  long count = CountFileHandler.readFromFile(request.getRealPath("/") + "count.txt");
  count = count + 1; //修改记录 +1
  out.print(count); //显示数据
  //更新文件内容。
  CountFileHandler.write2File(request.getRealPath("/") + "count.txt", count);
   
  %>
  </ body >
  </ html >

程序运行之后会在tomcat下的webapps目录下的对应的web项目生成一个count.txt文本文件

4.第四种方法,只是保存了访问的统计数据罢了,但没有保证刷新页面的时候不会自增,这样还是不好。当然总会有解决的办法的,一般的解决方案就是结合各种方案的优点。下面是由session对象+application对象+txt文本来实现网站的访问统计。

import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;
  
import javax.servlet.http.HttpServlet;
  
public class Counter extends HttpServlet{
  //写入文件的方法
  public static void write2File(String filename, long count){
   try {
    PrintWriter out = new PrintWriter( new FileWriter(filename));
    out.println(count);
    out.close();
   } catch (IOException e) {
    // TODO: handle exception
    e.printStackTrace();
   }
  }
   
  //读文件的方法
  public static long readFromFile(String filename){
   File file = new File(filename);
   long count = 0 ;
   if (!file.exists()){
    try {
     file.createNewFile();
    } catch (IOException e) {
     // TODO Auto-generated catch block
     e.printStackTrace();
    }
    write2File(filename, 0 );
   }
   try {
    BufferedReader in = new BufferedReader( new FileReader(file));
    try {
     count = Long.parseLong(in.readLine());
    }
    catch (NumberFormatException e) {
     // TODO: handle exception
     e.printStackTrace();
    } catch (IOException e) {
     // TODO Auto-generated catch block
     e.printStackTrace();
    }
   } catch (FileNotFoundException e) {
    // TODO: handle exception
    e.printStackTrace();
   }
   return count;
  }

jsp文件代码:

<%@page import="org.servlet.count.Counter"%>
<%@ page language="java" import="java.util.*" pageEncoding="GB2312"%>
< html >
  < head >
   < title >java 计数器程序</ title >
  </ head >
  < body >
  <%
  Counter CountFileHandler = new Counter();
  long count = 0;
  if(application.getAttribute("count") == null){
   count = CountFileHandler.readFromFile(request.getRealPath("/") + "count.txt");
   application.setAttribute("count", new Long(count));
 
  count = (Long)application.getAttribute("count");
  if(session.isNew()){
   count++;
   application.setAttribute("count", count);
   //更新文件目录
   CountFileHandler.write2File(request.getRealPath("/") + "count.txt",count);
   }
  %>
  访问人数:<%=count %>
   </ body >
</ html >

以上四种方法,是每一次改进才得到的方法,如果要实现网站访问统计,当然最后一种是最好的,知识不是一步登天,需要在问题上不断改进,获得最终的解决方案,当然最后一种不一定是最好的,实现策略上,如果可以利用数据库也是可以的,但我认为每次访问网站都要读和写数据库,这样效率就降低了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值