當前位置:首頁 » 密碼管理 » java網站訪問量統計

java網站訪問量統計

發布時間: 2023-01-19 22:52:03

java如何統計網站訪問

步驟一、建一個表,表名任意,這里取名為:visitorcounter,表的結構如下所示:
+-------+------------------+------+-----+------------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+------------------+------+-----+------------+----------------+
| id | int(11) unsigned | NO | PRI | NULL | auto_increment |
| vdate | date | NO | | 2000-01-01 | |
| vnum | int(11) | NO | | 0 | |
+-------+------------------+------+-----+------------+----------------+
步驟二、建立一個java類,名字也為:visitorcounter,類的內容如下:
package com.hdzx.pub;
import java.sql.ResultSet;
import java.text.SimpleDateFormat;
import java.util.Date;
public class VisitorCounter {
private final static String TABLE_NAME = "visitorcounter";
private static String today = null;
private static long today_num = 0;
private static long total_num = 0;
//載入訪問量
public static void loadNum(){
if(total_num<1)
loadTotalNum();
if(today_num<1)
loadToadyNum();
}
//載入今日訪問量
private static void loadToadyNum() {
// TODO Auto-generated method stub
DBConnect db = null;
ResultSet rs = null;
if(today==null)
today = getTodayDate();
String sql = "select vnum from "+TABLE_NAME+" where vdate='"+today+"'";
try {
db = new DBConnect();
rs = db.executeQuery(sql);
if(rs.next()){
today_num = rs.getLong("vnum");
}
else
{
sql = "insert into "+TABLE_NAME+"(vdate,vnum) values('"+today+"',0)";
db.executeUpdate(sql);
today_num = 0;
}
} catch (Exception e) {
// TODO: handle exception
today_num = 0;
System.out.println("com.hdzx.pub~VisitorCounter.incTotalCounter:獲得訪問人數");
}
}
//載入總訪問量
private static void loadTotalNum() {
// TODO Auto-generated method stub
// TODO Auto-generated method stub
DBConnect db = null;
ResultSet rs = null;
if(today==null)
today = getTodayDate();
String sql = "select vnum from "+TABLE_NAME+" where id=1";
try {
db = new DBConnect();
rs = db.executeQuery(sql);
if(rs.next()){
total_num = rs.getLong("vnum");
}
else
{
total_num = 0;
}
} catch (Exception e) {
// TODO: handle exception
total_num = 0;
System.out.println("com.hdzx.pub~VisitorCounter.incTotalCounter:獲得訪問人數");
}
}
//增加總的訪問量
private static int incTotalCounter(){
int k = 0;
DBConnect db = null;
loadNum();
total_num = total_num+1;
String sql = "update "+TABLE_NAME+" set vnum="+total_num+" where id=1";
try {
db = new DBConnect();
k = db.executeUpdate(sql);
} catch (Exception e) {
// TODO: handle exception
System.out.println("com.hdzx.pub~VisitorCounter.incTotalCounter:增加訪問人數");
}
return k;
}
//增加今日的訪問量
public static int incTodayCounter(){
int k = 0;
DBConnect db = null;
String sql = null;
loadNum();
today_num += 1;
sql = "update "+TABLE_NAME+" set vnum="+today_num+" where vdate='"+today+"'";
try {
db = new DBConnect();
k = db.executeUpdate(sql);
if(k > 0)
incTotalCounter();
} catch (Exception e) {
// TODO: handle exception
System.out.println("com.hdzx.pub~VisitorCounter.incTotalCounter:增加訪問人數");
}
return k;
}
//獲得今天的日期
private static String getTodayDate(){
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
return sdf.format(new Date());
}
///獲得今日訪問量
public static long getTodayNum(){
loadNum();
return today_num;
}
//獲得總的訪問量
public static long getTotalNum(){
loadNum();
return total_num;
}
}
步驟三、經過以上的步驟後,在頁面中加入以下的代碼,就可以實現網站訪問量的統計工作:
if(session.isNew())
{
VisitorCounter.incTodayCounter();
}
%>
今日訪問量:<%=VisitorCounter.getTodayNum() %><br/>
總的訪問量: <%=VisitorCounter.getTotalNum() %>

Ⅱ 網站訪問量統計java代碼

public class Counter {

private int count;

// 每訪問一次,計數器自加一
public int getCount() {
return ++count;
}

public void setCount(int count) {
this.count = count;
}

}
<%-- 定義一個 session 范圍內的計數器 記錄個人訪問信息 --%>
<jsp:useBean id="personCount" class="com.helloweenvsfei.jspweb.bean.Counter" scope="session" />

<%-- 定義一個 application 范圍內的計數器 記錄所有人的訪問信息 --%>
<jsp:useBean id="totalCount" class="com.helloweenvsfei.jspweb.bean.Counter" scope="application" />

<div align="center">
<form action="method.jsp" method="get">
<fieldset style='width: 300'>
<legend>計數器</legend>
<table align="center" width="400">
<tr>
<td width=150 align="right" style="font-weight:bold; ">您的訪問次數:</td>
<td>
<%-- 獲取個人的 訪問次數 --%>
<jsp:getProperty name="personCount" property="count" /> 次
</td>
</tr>
<tr>
<td width=150 align="right" style="font-weight:bold; ">總共的訪問次數:</td>
<td>
<%-- 獲取所有人的 訪問次數 --%>
<jsp:getProperty name="totalCount" property="count" /> 次
</td>
</tr>
</table>
</fieldset>
</form>
</div>
希望你能幫到你

Ⅲ java怎麼統計網站訪問量

<DIV class="h">
<%-- 記錄網站訪問次數 --%>
<%
Integer counter = (Integer)application.getAttribute("counter"); //先從application裡面獲取計數器的key的值
if(counter==null){
//如果該值為null,說明第一次訪問
application.setAttribute("counter",1);
counter=(Integer)application.getAttribute("counter");
}else {
//如果該值不為空,取出來進行累加
int i = counter.intValue();
i++;
application.setAttribute("counter",i);//累加後再放進去
}
%>
<% User user =(User)session.getAttribute("users"); %>
<%="歡迎"+user.getName() %> |您是第<%=counter.intValue()%>位訪客
</DIV>

Ⅳ 網站統計不同區域的訪問量java 和mysql語句實現 。 謝謝!

大約要三張表
A表(地區名):
地區代碼 地區名 總訪問次數
1 廣東省 0
2 江蘇省 0
...

B表(日訪問表)
地區代碼 訪問時間 日訪問次數
1 20131224 0
8 20131224 0

C表(ip來源表)
序號 來訪IP 地區代碼 時間

處理流程基本上就是
1、先取用戶ip,從ip庫中查詢出用戶地區(這種代碼隨處可以找到,比如http://zhaoshijie.iteye.com/blog/1171132)一般就是純真ip庫,有了地區後,從A表中查出地區代碼
2、向C表中添加記錄
3、然後查一下B表有沒有當日該地區記錄,如果沒有就在B表中新增一條,如果有就將B表對應的次數加1,然後A表中對應地區代碼次數統計也加1
然後比如你要查2013年12月24日的各地區統計就可以是
select * from a,b where a.地區代碼=b.地區代碼 and b.訪問時間=20131224

Ⅳ java web 網站訪問量統計 設計求解答

如果後續需要用到這部分數據,肯定是要做持久化的。 統計處理可以精細化到具體頁面(這個要看錶結構如何設計了) 頁面處理建議在action中直接入庫及訪問數據展示~ 或js頁面初始化時ajax入庫

Ⅵ 一道java編程題求大神指點

importjava.util.concurrent.CopyOnWriteArrayList;
importjava.util.concurrent.TimeUnit;
importjava.util.concurrent.atomic.AtomicLong;

{

AtomicLongcount=newAtomicLong(0);
CopyOnWriteArrayList<Long>list=newCopyOnWriteArrayList<>();
//hr介面多線程訪問
@Override
publicvoidhr(){
count.getAndAdd(1);
System.out.println(Thread.currentThread().getName()+"訪問次數:"+count);
list.add(System.currentTimeMillis());
}

@Override
publicDateStatestate(){
DateStatedateState=newDateState();

intnum=0;
longnow=System.currentTimeMillis();

longs1=TimeUnit.SECONDS.toMillis(10);
longs2=TimeUnit.SECONDS.toMillis(60);
longm1=TimeUnit.MINUTES.toMillis(10);
longm2=TimeUnit.MINUTES.toMillis(60);

if(list.size()>0){
for(inti=list.size()-1;i>-1;i--){
longtime=now-list.get(i);
num++;
if(time<s1){
dateState.setLast10Second(num);
}
if(time<s2){
dateState.setLast60Second(num);
}
if(time<m1){
dateState.setLast10Minute(num);
}
if(time<m2){
dateState.setLast60Minute(num);
}else{
break;
}
}
}
System.out.println(dateState);
returndateState;
}

}
importjava.util.concurrent.ExecutorService;
importjava.util.concurrent.Executors;
importjava.util.concurrent.TimeUnit;

publicclassTestCount{
publicstaticvoidmain(String[]args){

AccessTaskaccessTask=newAccessTask();
ExecutorServicepool=Executors.newFixedThreadPool(20);

for(inti=0;i<100;i++){
try{
TimeUnit.SECONDS.sleep(2);
}catch(InterruptedExceptione){
e.printStackTrace();
}
pool.execute(newRunnable(){
@Override
publicvoidrun(){
accessTask.hr();
accessTask.state();

}
});
}
pool.shutdown();
}
}

Ⅶ Java 帖子的瀏覽量,總訪問人數怎麼統計

一般來說,如果是網頁,完全沒有必要自己去統計網站人數(自己統計可以放在application域中,定時同步到資料庫),一般我們的解決方案是使用插件,各種各樣的插件,比如cnzz的站長統計插件(總訪問人數,ip,pv,up等),至於帖子的瀏覽量,就算同一個session只加一次比較好

Ⅷ 現在做一個java web的項目,要實現一個功能,就是實現訪問量統計,每一次瀏覽網頁訪問量+1,最重要的是

給你個思路:比如要統計某一篇文章的訪問次數。
你應該能獲取這篇文章所在的資料庫的記錄;然後把記錄的ID保存在當前的session中。判斷當前session中是否有這個ID了,如果沒有的話,把這條記錄的訪問記錄加1(前提是這條記錄有欄位去記錄對應的訪問次數),如果有的話,啥都不操作。

保存在session中的話,如果在session有效期內,用戶無論怎麼刷新頁面訪問次數不會重復疊加,這樣做有一個不好的地方就是如果session失效了,那麼即使是同一台電腦再次訪問這篇文章的話,記錄還是會加1的。

因此有人提出保存在cookie中,只要用戶不清理cookie,並且cookie設置永久不失效那麼即使是同一台電腦在不同時間訪問這個文章,那麼之前已經統計過的話,這個是不會重復統計的。

兩個方法都有優缺點,一般來說訪問次數都是一個大概取值,所以上述兩者其實都有人用的。

Ⅸ java怎麼實統計在線人數,和訪問量

簡單的說個我的思路供你借鑒:
在線人數,我理解為當前應用的session數目,不過sevlert好像不提供獲取全部session的方法,可以通過加一個sessionlistener來記錄(創建就+1,銷毀就-1)
訪問量相對簡單,你定義一個全局的計數器就好了,來一個(這個有很多種方法,比如:有一個新的session被創建)人你就+1

熱點內容
雲伺服器開游戲 發布:2025-08-27 10:41:37 瀏覽:439
ftp後台登陸 發布:2025-08-27 10:39:00 瀏覽:773
java武漢培訓 發布:2025-08-27 10:33:06 瀏覽:642
什麼是圓點密碼 發布:2025-08-27 10:31:48 瀏覽:543
php培訓機構那個比較好 發布:2025-08-27 10:24:13 瀏覽:913
ssl加密訪問 發布:2025-08-27 10:19:16 瀏覽:211
安裝包解壓密碼 發布:2025-08-27 10:15:28 瀏覽:359
poor腳本怎麼用 發布:2025-08-27 10:14:43 瀏覽:366
伺服器監聽ip是什麼 發布:2025-08-27 09:49:21 瀏覽:916
北京php好找工作嗎 發布:2025-08-27 09:30:58 瀏覽:711