|
Trouver une ressource
Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !
VISITEURS CONNECTÉS EN TEMPS RÉEL
Information sur la source
Description
Ce script vous permettra de savoir combien de visiteurs sont connectés sur votre site. Le script utilise la fonction session_start() : si vous êtes hébergé par Free, pensez à créer un dossier sessions à la racine du site. Créez une table sur votre BDD Mysql nommée `connectes` avec 2 champs : - sessid de type varchar (40) - timestamp de type INT (15)
Source
- <?php
- // Script réalisé par Vyk12
-
- session_start();
-
- if(isset($_GET['nbre_connectes']))
- {
- mysql_connect('serveur','login','pass');
- mysql_select_db('db');
- $sql = mysql_query('SELECT COUNT(*) AS nbre_sess FROM connectes WHERE sessid = \'' . $_REQUEST['PHPSESSID'] . '\'');
- $nbre_sess = mysql_fetch_array($sql);
- if($nbre_sess['nbre_sess'] == 0)
- mysql_query('INSERT INTO connectes VALUES (\'' . $_REQUEST['PHPSESSID'] . '\',\'' . time() . '\')');
- else
- mysql_query('UPDATE connectes SET timestamp = ' . time() . ' WHERE sessid = \'' . $_REQUEST['PHPSESSID'] . '\'');
- $timestamp_limite = time() - 2;
- mysql_query('DELETE FROM connectes WHERE timestamp < ' . $timestamp_limite);
- $retour = mysql_query('SELECT COUNT(*) AS nbre_sess FROM connectes');
- $donnee = mysql_fetch_array($retour);
- $phrase = ($donnee['nbre_sess'] == 1) ? 'Il y a actuellement 1 personne connectée.' : 'Il y a actuellement ' . $donnee['nbre_sess'] . ' personnes connectées.';
- echo $phrase;
- mysql_close();
- exit();
- }
- ?>
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr">
- <head>
- <title>Compteur connectés en temps réel</title>
- <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
- <meta http-equiv="Content-Language" content="fr" />
- <script type="text/javascript">
- <!--
- function nbre_connectes()
- {
- var xhr = null;
- if(window.XMLHttpRequest)
- xhr = new XMLHttpRequest();
-
- else if(window.ActiveXObject)
- xhr = new ActiveXObject('Microsoft.XMLHTTP');
-
- xhr.open('GET', 'connectes.php?nbre_connectes', true);
-
- xhr.onreadystatechange = function()
- {
- if(xhr.readyState == 4)
- {
- document.getElementById('connectes').innerHTML = xhr.responseText;
- }
- }
- xhr.send(null);
- }
- //-->
- </script>
- </head>
- <body onload="javascript:nbre_connectes();">
- <script type="text/javascript">
- <!--
- setInterval('nbre_connectes()', 1000);
- //-->
- </script>
- <p id="connectes">
- <noscript>
- Vous devez accepter JavaScript !
- </noscript>
- </p>
- </body>
- </html>
<?php
// Script réalisé par Vyk12
session_start();
if(isset($_GET['nbre_connectes']))
{
mysql_connect('serveur','login','pass');
mysql_select_db('db');
$sql = mysql_query('SELECT COUNT(*) AS nbre_sess FROM connectes WHERE sessid = \'' . $_REQUEST['PHPSESSID'] . '\'');
$nbre_sess = mysql_fetch_array($sql);
if($nbre_sess['nbre_sess'] == 0)
mysql_query('INSERT INTO connectes VALUES (\'' . $_REQUEST['PHPSESSID'] . '\',\'' . time() . '\')');
else
mysql_query('UPDATE connectes SET timestamp = ' . time() . ' WHERE sessid = \'' . $_REQUEST['PHPSESSID'] . '\'');
$timestamp_limite = time() - 2;
mysql_query('DELETE FROM connectes WHERE timestamp < ' . $timestamp_limite);
$retour = mysql_query('SELECT COUNT(*) AS nbre_sess FROM connectes');
$donnee = mysql_fetch_array($retour);
$phrase = ($donnee['nbre_sess'] == 1) ? 'Il y a actuellement 1 personne connectée.' : 'Il y a actuellement ' . $donnee['nbre_sess'] . ' personnes connectées.';
echo $phrase;
mysql_close();
exit();
}
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr">
<head>
<title>Compteur connectés en temps réel</title>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<meta http-equiv="Content-Language" content="fr" />
<script type="text/javascript">
<!--
function nbre_connectes()
{
var xhr = null;
if(window.XMLHttpRequest)
xhr = new XMLHttpRequest();
else if(window.ActiveXObject)
xhr = new ActiveXObject('Microsoft.XMLHTTP');
xhr.open('GET', 'connectes.php?nbre_connectes', true);
xhr.onreadystatechange = function()
{
if(xhr.readyState == 4)
{
document.getElementById('connectes').innerHTML = xhr.responseText;
}
}
xhr.send(null);
}
//-->
</script>
</head>
<body onload="javascript:nbre_connectes();">
<script type="text/javascript">
<!--
setInterval('nbre_connectes()', 1000);
//-->
</script>
<p id="connectes">
<noscript>
Vous devez accepter JavaScript !
</noscript>
</p>
</body>
</html>
Conclusion
Le script marche de la manière suivante : - Le visiteur ouvre cette page : on récupère son id de session - On se connecte à Mysql, on regarde si sa session est déjà dedans - Si son id est déjà dedans, on met à jour son timestamp - Sinon on insère son id + son timestamp - On supprime toutes les entrées dont leur timestamp n'a pas été actualisé depuis 2 secondes - On regarde combien il y a d'entrées et on affiche ce nombre
Historique
- 13 janvier 2008 16:34:10 :
- Spécification de la table à créer.
- 13 janvier 2008 16:34:51 :
- Spécification de la table à créer.
- 13 janvier 2008 18:34:37 :
- Réctification d'un bug
- 06 avril 2008 20:41:46 :
- Modification totale du code source
- 06 avril 2008 20:44:35 :
- modification du code source
- 07 avril 2008 18:29:30 :
- Modification code source
- 07 avril 2008 20:34:08 :
- Résolution de différents bugs
- 07 avril 2008 20:38:21 :
- Modif code source
- 09 avril 2008 15:33:30 :
- Oublie d'un =
- 17 avril 2008 15:10:44 :
- Résolution de tous les bugs : script marche à 100% (enfin je crois ...)
- 17 avril 2008 15:11:30 :
- Résolution de tous les bugs : script marche à 100% (enfin je crois ...)
- 18 avril 2008 17:38:02 :
- Ajout des <!-- et //--> dans le code JS
- 18 avril 2008 17:42:20 :
- Rajout des comentaires <!-- et //--> dans les balises script
Sources du même auteur
Sources de la même categorie
Sources en rapport avec celle ci
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
compteur de nombre de visiteurs connecté [ par developvbdebut ]
Bonjour tout le mondeQuel qu'un a ti'l déja utilisé la source de antidoteVoici le nom de la source ce dessou:COMPTEUR DE VISITEURS CONNECTÉS EN TEMPS
Membre connecté... [ par houseclubber ]
Je débute en PHP et je voulais faire un petit exercice pour m'entraîner.En fonction que l'on soit identifié ou non sur le site, certaine rubriques son
script "qui est connecté" [ par Pouky ]
Bonjour!!j'ai une tite question:est ce que qqun pour m'expliquer en gros le fonctionnement des scripts "qui est connecté" (comme celui qui est sur ce
Nombre de connectés en temps réel [ par Dino ]
Bonjour,Je ne trouve nulle part un code qui permet de connaitre le nombre de visiteurs sur le site en temps réel. On trouve des codes ou on considère
Authentification [ par erwan35 ]
Bonjour à tous!Je viens de commencer un site en php.Ce site est calqué sur le principe codes souces, c'est à dire qu'il sera une interface de libre éc
Compteur unique pour visiteurs [ par must ]
Salut,je voudrais faire un compteur de visites qui affiche le nombre de visiteurs,mais qu'une seule fois,quand personne viens 10 fois sur le site,le c
Ping sous php [ par juki_webmaster ]
Bonsoir , je voudrais avoir de l'aide pour crée un script php qui en utilisant une variable constente pingré une ip est afficherais sous forme :if ...
balise <noscript> en php ??? [ par pyranhaz ]
Bonjour,existe-il une façon efficace en php de rediriger tout visiteur automatiquement qui n'a pas le "active scripting" d'activé sur sa machine ???il
[Session] sous ie [ par petit_stagiaire ]
Bonjour,je gère des sessions pour un accès membre.Lorsqu'un utilisateur se connecte je remplis $SESSION['nom']...Mon problème vient de l'utilisation d
compteur de connecté [ par mdog ]
Bonjour,dans le but de réaliser un compteur de conectés pour mon site, quis era un site de jeux dans la ligné de "Rise Of Lords" etc..., j'ai besoin d
|
Téléchargements
Logiciels à télécharger sur le même thème :
Comparez les prix Nouvelle version
|