當前位置:首頁 » 編程語言 » php統計訪問量

php統計訪問量

發布時間: 2022-09-13 08:58:04

php統計今日訪問

$d = date('d');
if($nowd!=$oldd){
delete.......
insert into ....
}else{
insert into.....
}
保存統計時同時寫入一個當天的日期,並判斷與上一個日期是否相同,不相同刪,相同就寫入......我比較笨,覺得應該可行。。。。你這樣的統計用txt文件來保存的話應該更好。。。。

⑵ PHP+MYsql 如何准確實現頁面訪問統計次數

分兩種情況,一種是前置頁面統計,這個時候統計發送在點擊的時候,適用於這個鏈接是廣告鏈接,或者其他鏈接。第二種,是頁面打開加入統計,這種適用於SEO或者其他的需要,統計當前頁面到底有多少點擊率,不受前置頁面影響。

  • 在鏈接裡面加一個hook。比如

    <a href="頁面鏈接" onclick="countHit(this)">鏈接文字</a>

    然後定義一個js函數

    function countHit(obj){

    var url = $(obj).attr('href');

    //這里我使用jq,以鏈接為標准。當然對於廣告可以以

    //廣告id為統計 的標准

    $.ajax({

    url : '你作為統計的php頁面地址';

    type : 'post',//使用post是防止瀏覽器直接輸入這個地址而被刷

    data:{link:url}//把鏈接地址post傳過去

    });

    }

    在php頁面

    $link = addslashes($_GET['link']);//安全處理下,讓link能正常存入

    //接下來做有效性判斷,這里省略

    $query = mysql_query("SELECT 1 FROM `統計表` WHERE `link`='$link'");

    $has = mysql_fetch_array($query);

    if($has){

    //當前存在統計

    mysql_query("UPDATE `統計表` SET hits=hits+1 WHERE `link`='$link'");

    }else{

    mysql_query("INSERT INTO `統計表` (link,hits) VALUE('$link','1')");

    }

    這樣就完成了統計內容

  • 當前頁面統計

    一般這種統計為某種信息內容的統計,我這里假設是某一條新聞的統計,這個信息裡面有個hits欄位作為統計

    只要在php頁面裡面加上

    mysql_query("UPDATE `新聞表` SET hits=hits+1 WHERE `id`='新聞id'");

    這一句就可以完成統計了

⑶ PHP統計網頁訪問量,資料庫怎麼設置比較好

如果你不需要記錄每次訪問的詳細信息,可以不用記錄每一次訪問,那樣資料庫會非常龐大,而且統計也會很慢。

簡單的方法是就是只要一條記錄,用四個欄位分別累計本日、本周、本月、本年、總共的訪問數,每次訪問的時侯對這些欄位加1,另外一個欄位記錄最後一次更新的日期,如果最後更新日期不是本日,就在加1前把本日欄位設置為0,本周、本月、本年欄位類似處理即可。

⑷ php 怎麼統計文章的訪問量

先給儲存相應文章的數據表增加一個記錄訪問量的欄位。

可以每訪問一次,欄位數量加一,但是這樣會不準確,因為只要刷新一下,就會記錄一下。

為了防止上面的情況發生,可以記錄訪問者的IP地址,重復的IP地址訪問,只記錄一次。

但是,一個IP地址,只記錄一次,也有問題,比如,一個區域網,多個訪問者,共用一個IP地址,這樣也會記錄不準確。所以最好,一個IP地址一定時間內訪問記錄一次。這樣相對好一點。

不過,即使記錄IP地址,但是也有可能有惡意的用戶通過切換IP,或者通過刷票軟體來刷訪問量。

<?php
$ip = $_SERVER['REMOTE_ADDR'];

//循環對比數據表中儲存的IP,如果IP存在,不再記錄

$query = mysql_query("select * contetns where ip = '".$ip."'");

if(mysql_num_rows($query) > 0){
//IP存在
}else{
//記錄訪問量
}
?>

文/搬磚家(簡書作者)
原文鏈接:http://www.jianshu.com/p/3a1a9e618ede
著作權歸作者所有,轉載請聯系作者獲得授權,並標注「簡書作者」。

⑸ PHP怎麼做到統計單篇文章的瀏覽量

先給儲存相應文章的數據表增加一個記錄訪問量的欄位。

1, 可以每訪問一次,欄位數量加一,但是這樣會不準確,因為只要刷新一下,就會記錄一下。

2, 為了防止上面的情況發生,可以記錄訪問者的IP地址,重復的IP地址訪問,只記錄一次。

3, 但是,一個IP地址,只記錄一次,也有問題,比如,一個區域網,多個訪問者,共用一個IP地址,這樣也會記錄不準確。所以最好,一個IP地址一定時間內訪問記錄一次。這樣相對好一點。

4, 不過,即使記錄IP地址,但是也有可能有惡意的用戶通過切換IP,或者通過刷票軟體來刷訪問量。這些問題,還需要更深的研究一下,怎麼應對。

比如:

<?php
$ip = $_SERVER['REMOTE_ADDR'];

//循環對比數據表中儲存的IP,如果IP存在,不再記錄

$query = mysql_query("select * contetns where ip = '".$ip."'");

if(mysql_num_rows($query) > 0){
//IP存在
}else{
//記錄訪問量
}
?>

⑹ php 怎麼做瀏覽量的統計用的是thinkphp框架

可以提供簡單的方法:(基於你用的是tp,對於做cache緩存也不影響統計,畢竟是訪問了控制器方法)
第一:當訪問這個頁面的時候,對應的有控制器,在控制器中做一個操作,每被訪問這個頁面一次給資料庫那個欄位加1(這個不精準)
第二:獲取訪問頁面人的ip地址,在資料庫存記錄,每此訪問此頁面也就是控制器 就做同樣的操作,前提是判斷這個人的ip是否存在,存在證明已訪問過。(稍微精確點)
當然還有不少其他的方法,這里是比較簡單的。希望可以幫助到

⑺ php流量統計功能的實現代碼

流量統計功能
顯示效果:
總訪問量:399
今日流量:14
昨日流量:16
本代碼僅供學習交流,其中必有不妥之處。請見諒!
--
--
表的結構
`mycounter`
--
復制代碼
代碼如下:
CREATE
TABLE
`mycounter`
(
`id`
int(11)
NOT
NULL
auto_increment,
`Counter`
int(11)
NOT
NULL,
`CounterLastDay`
int(10)
default
NULL,
`CounterToday`
int(10)
default
NULL,
`RecordDate`
date
NOT
NULL,
PRIMARY
KEY
(`id`)
)
ENGINE=InnoDB
DEFAULT
CHARSET=gbk
AUTO_INCREMENT=2
;
函數過程如下:
復制代碼
代碼如下:
<?PHP
public
function
ShowMyCounter(){
//定義變數
$IsGone
=
FALSE;
//讀取數據
$querysql
=
"SELECT
*
FROM
`mycounter`
WHERE
id
=
Ƈ'
";
$queryset
=
mysql_query($querysql);
$row
=
mysql_fetch_array($queryset);
//獲得時間量
$DateNow
=
date('Y-m-d');
$RecordDate
=
$row['RecordDate'];
$DateNow_explode
=
explode("-",$DateNow);
$RecordDate_explode
=
explode("-",$RecordDate);
//判斷是否已過去一天
if(
$DateNow_explode[0]
>
$RecordDate_explode[0])
$IsGone
=
TRUE;
else
if(
$DateNow_explode[0]
==
$RecordDate_explode[0]
){
if(
$DateNow_explode[1]
>
$RecordDate_explode[1]
)
$IsGone
=
TRUE;
else
if(
$DateNow_explode[1]
==
$RecordDate_explode[1]
){
if(
$DateNow_explode[2]
>
$RecordDate_explode[2]
)
$IsGone
=
TRUE;
}else
BREAK;
}else
BREAK;
//根據IsGone進行相應操作
IF($IsGone)
{
$RecordDate
=
$DateNow;
$CounterToday
=
0;
$CounterLastDay
=
$row['CounterToday'];
$upd_sql
=
"update
mycounter
set
RecordDate
=
'$RecordDate',CounterToday
=
'$CounterToday',CounterLastDay
=
'$CounterLastDay'
WHERE
id
=
Ƈ'
";
mysql_query($upd_sql);
}
//再次獲取數據
$querysql
=
"SELECT
*
FROM
`mycounter`
WHERE
id
=
Ƈ'
";
$queryset
=
mysql_query($querysql);
$Counter
=
$row['Counter'];
$CounterToday
=
$row['CounterToday'];
$CounterLastDay
=
$row['CounterLastDay'];
if($row
=
mysql_fetch_array($queryset)
){
if(
$_COOKIE["user"]
!=
"oldGuest"
){
$Counter
=
++$row['Counter'];
$CounterToday
=
++$row['CounterToday'];
$upd_sql
=
"update
mycounter
set
counter
=
'$Counter',CounterToday
=
'$CounterToday'
WHERE
id
=
Ƈ'
";
$myquery
=
mysql_query($upd_sql);
}
echo
"總訪問量:".$Counter;
echo
"
";
echo
"今日流量:".$CounterToday;
echo
"
";
echo
"昨日流量:".$CounterLastDay;
}else{//如果資料庫為空時,相應的操作
}
}
?>
當然,需要在文件第一行開始寫出如下代碼:
復制代碼
代碼如下:
<?PHP
session_start();
if(
!isset($_COOKIE["user"])
){
setcookie("user","newGuest",time()+3600);
}else
{
setcookie("user","oldGuest");
}
?>

⑻ php如何實現訪問統計

兩種方式:

第一:使用一個文本文檔

每次讀取這個文本文檔的數,然後加1,再覆蓋寫入

關鍵代碼:

<?php
$txt_db='jsb.txt';
$nums=file_get_contents($txt_db);
$nums++;
file_put_contents($txt_db,$nums);
?>

第二:使用資料庫,設計數據表,每次更新資料庫。


個人建議:使用第一種方法。

原因:需求簡單,所以盡可能少佔資源,抗壓力強。

⑼ php怎麼統計訪問次數

那就給你個簡單的吧,就只記錄用戶瀏覽器 session_id 的。把代碼加入你的首頁 PHP文檔 即可

<?php
session_start();
$log = 'log.txt';
if(!$handle = fopen($log,"a+")){ echo '日誌文件打開失敗'; exit(); }
if(!fwrite($handle,session_id().chr(13))){ echo '數據寫入失敗'; exit(); }
fclose($handle);
$file = file_get_contents($log);
$content = explode(chr(13),$file);
echo "本頁被訪問次數: <b>".(count($content)-1)." </b>";
?>

⑽ php網站怎麼統計訪問量

你可以使用第三方統計,比如cnzz.com的統計服務,注冊一個賬號,創建網站統計並拿到相應的統計代碼,然後添加到需要統計的頁面里,具體的操作請查看統計服務平台的相關說明!

熱點內容
j2ee和java的區別 發布:2025-01-12 03:42:44 瀏覽:581
android6小米 發布:2025-01-12 03:38:35 瀏覽:85
redis與資料庫 發布:2025-01-12 03:20:21 瀏覽:211
怎麼升級安卓100 發布:2025-01-12 03:19:37 瀏覽:516
c語言倒數 發布:2025-01-12 03:14:37 瀏覽:929
如何免費激活行動電話卡安卓 發布:2025-01-12 03:10:27 瀏覽:89
2020凱越精英配置什麼樣 發布:2025-01-12 03:08:02 瀏覽:685
奧特曼空想特攝要怎麼樣的配置 發布:2025-01-12 03:08:01 瀏覽:998
空氣能的壓縮機 發布:2025-01-12 03:05:55 瀏覽:480
java字元串圖片 發布:2025-01-12 03:04:31 瀏覽:341