JSP实现网页访问统计

    xiaoxiao2021-03-25  117

    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 >

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

    转载请注明原文地址: https://ju.6miu.com/read-21707.html

    最新回复(0)