diff options
Diffstat (limited to 'visites.php')
| -rw-r--r-- | visites.php | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/visites.php b/visites.php new file mode 100644 index 0000000..c9b77fb --- /dev/null +++ b/visites.php | |||
| @@ -0,0 +1,84 @@ | |||
| 1 | <?php | ||
| 2 | session_start(); | ||
| 3 | |||
| 4 | try | ||
| 5 | { | ||
| 6 | // create database | ||
| 7 | $Db = new PDO('mysql:host=localhost;charset=utf8', 'root', 'qsdfgh'); | ||
| 8 | $db_name = 'ordipolo'; | ||
| 9 | $Db->exec('CREATE DATABASE IF NOT EXISTS ' . $db_name . ';'); | ||
| 10 | unset($Db); | ||
| 11 | |||
| 12 | // connexion | ||
| 13 | $Db = new PDO('mysql:host=localhost;dbname=ordipolo;charset=utf8', 'root', 'qsdfgh'); | ||
| 14 | |||
| 15 | // create tables | ||
| 16 | $Db->query('CREATE TABLE IF NOT EXISTS visites (id INT PRIMARY KEY AUTO_INCREMENT, ip VARCHAR(30), hote VARCHAR(255), user_agent TEXT, date DATE, nb_pages INT);'); | ||
| 17 | //$Db->query('CREATE TABLE IF NOT EXISTS compteur (visiteurs INT, bots INT);'); | ||
| 18 | $Db->query('CREATE TABLE IF NOT EXISTS compteur (visiteurs INT);'); | ||
| 19 | |||
| 20 | // initialiser table compteur avec des 0 si la table est vide | ||
| 21 | if(!$Db->query('SELECT * FROM compteur')->fetch()) | ||
| 22 | { | ||
| 23 | $Db->query('INSERT INTO `compteur` VALUES (0);'); | ||
| 24 | } | ||
| 25 | } | ||
| 26 | catch (Exception $e) | ||
| 27 | { | ||
| 28 | die('Erreur : ' . $e->getMessage()); | ||
| 29 | } | ||
| 30 | |||
| 31 | |||
| 32 | // variables | ||
| 33 | $ip = $_SERVER['REMOTE_ADDR']; // IP | ||
| 34 | $hote = gethostbyaddr($ip); // nom d'hôte si possible | ||
| 35 | date_default_timezone_set ('Europe/Paris'); // configure le décalage horaire sur Europe/Paris | ||
| 36 | $user = $_SERVER['HTTP_USER_AGENT']; // infos sur le client (navigateur, OS), attention aux menteurs | ||
| 37 | $user = mb_strtolower($user); // minuscules pour strpos() | ||
| 38 | $date = date('Y-m-d'); // date formatée | ||
| 39 | |||
| 40 | // script recherchant le pays | ||
| 41 | // la commande whois nécessite le paquet whois (debian) ou bind-tools (archlinux) | ||
| 42 | // on récupère la ligne (ou les lignes) indiquant le pays avec grep (-i sert à ignorer la casse) | ||
| 43 | $country = strtolower(shell_exec("whois " . $ip . " | grep -i country | cut -d: -f2 | sed -e ' s/\ //g'")); | ||
| 44 | |||
| 45 | |||
| 46 | function incrementerTableCompteur($Db, $field) | ||
| 47 | { | ||
| 48 | $nombre = $Db->query('SELECT ' . $field . ' FROM compteur')->fetch(); | ||
| 49 | if(!$nombre){$nombre = [0];} // tableau d'une seule case | ||
| 50 | $nombre[0] += 1; | ||
| 51 | |||
| 52 | $requete = $Db->prepare('UPDATE compteur SET ' . $field . ' = :nombre'); | ||
| 53 | $requete->execute(array('nombre' => $nombre[0])); | ||
| 54 | } | ||
| 55 | |||
| 56 | // MAJ de la base | ||
| 57 | if(isset($_SESSION['id_visiteur'])) // pages suivantes | ||
| 58 | { | ||
| 59 | $requete = $Db->prepare("UPDATE visites SET nb_pages = nb_pages + 1 WHERE id = :id"); | ||
| 60 | |||
| 61 | $requete->execute(array( | ||
| 62 | ':id' => $_SESSION['id_visiteur'])); | ||
| 63 | } | ||
| 64 | else // première page visitée dans la session | ||
| 65 | { | ||
| 66 | $requete = $Db->prepare(" | ||
| 67 | INSERT INTO visites (ip, hote, user_agent, date, nb_pages) | ||
| 68 | VALUES (:ip, :hote, :user_agent, :date, 1)"); | ||
| 69 | // si la visite est déjà enregistrée, ajoute +1 au nombre de pages | ||
| 70 | |||
| 71 | $requete->execute(array( | ||
| 72 | ':ip' => $ip, | ||
| 73 | ':hote' => $hote, | ||
| 74 | ':user_agent' => $user, | ||
| 75 | ':date' => $date)); | ||
| 76 | |||
| 77 | $_SESSION['id_visiteur'] = $Db->lastInsertId(); | ||
| 78 | |||
| 79 | // compte visiteurs + 1 | ||
| 80 | incrementerTableCompteur($Db, 'visiteurs'); | ||
| 81 | } | ||
| 82 | |||
| 83 | echo "visite enregistrée!"; | ||
| 84 | ?> | ||
