nasel jsem nekde na netu navod, jak si udelat statistiky přístupů na stránku - vypíše přístupy on-line, dnes a celkově.
problem je v tom, ze mi to nefunguje tak jak má... nevim v cem je chyba. nezobrazuje to správné výsledky. Když jsem se dnes zkoušel na stránku podívat ze školy a pak jsem se doma díval na ip, které se zapsaly do DB, tak tam byl jen jeden zaznam z moji domaci ip. Cili to nezapisuje vsechny navstevniky...
struktura DB (mysql):
CREATE TABLE `kruzek_pristupy` (
`ip` varchar(19) NOT NULL,
`datum` date NOT NULL default '0000-00-00',
`cas` int(10) NOT NULL default '0',
PRIMARY KEY (`datum`)
) ENGINE=MyISAM DEFAULT CHARSET=cp1250;
php kod na strance, ze ktere chci ziskat statistiky
<?php
@$spojeni = mysql_connect("server", "user", "password") or die('K databázi se nelze připojit, prosim zkuste požadavek opakovat později.');
mysql_select_db('databaze');
function kruzek_pristupy()
{
# funkce zjisti, jestli je dnes v tabulce navstevnik a podle toho ho bud vlozi, nebo mu zmeni cas navstevy na aktualni
$ip = getenv("REMOTE_ADDR"); //zjistime IP
#zjistime, jestli se IP dnes nachazi v tabulce
$dotaz = mysql_query("SELECT * FROM kruzek_pristupy
WHERE datum=NOW() AND ip='$ip'");
#jestli tam je, tak zmenime cas navstevy (kvuli online uzivatelum)
if (mysql_num_rows($dotaz))
$dotaz2 = mysql_query("UPDATE kruzek_pristupy SET cas='".time()."'
WHERE datum=NOW() AND ip='$ip'");
else #pokud neni, tak IP vlozime
$dotaz2 = mysql_query("INSERT INTO kruzek_pristupy (ip, datum, cas) VALUES('$ip',NOW(),'".time()."');");
}
function navstevy()
{
#funkce vraci pole s poctem navstev
$navstevnici = array();
#vybereme pocet vsech ulozenych IP adres
$dotaz = mysql_query("SELECT count(*) FROM kruzek_pristupy");
#vlozime hodnotu do pole
list($navstevnici['celkem'])=mysql_fetch_array($dotaz);
#vybereme pocet unikatnich dennich IP adres pro dnesni den
$dotaz = mysql_query("SELECT count(*) FROM kruzek_pristupy WHERE datum=NOW()");
#vlozime hodnotu do pole
list($navstevnici['dnes'])=mysql_fetch_array($dotaz);
#vybereme dnesni IP, ktere nejsou starsi nez 180 sekund = 3 minuty
$dotaz = mysql_query("SELECT count(*) FROM kruzek_pristupy WHERE datum=NOW() AND cas>='".(time()-180)."'");
#vlozime hodnotu do pole
list($navstevnici['online'])=mysql_fetch_array($dotaz);
#vratime pole
# $navstevnici['celkem'] = pocet navstev celkem
# $navstevnici['dnes'] = pocet navstev za dnesni den
# $navstevnici['online'] = pocet navstev, ktere nejsou starsi jak 3 minuty
return $navstevnici;
}
#zavolame kruzek_pristupy
kruzek_pristupy();
#vytvorime pole s pristupy
$navstevnici = navstevy();
#pole $navstevnici vypiseme
echo "ONLINE: $navstevnici[online]<br>
TODAY: $navstevnici[dnes]<br>
TOTAL: $navstevnici[celkem]<br>";
?>
nevite pls nekdo, v cem by mohla byt chyba?
Je preci jedno, jestli navstevnik se na tu stranku proklika nebo si ji otevre ze zalozek...
Diky