Problème pour transformer un code en pdo
Résolu/Fermé
A voir également:
- Problème pour transformer un code en pdo
- Le code ascii en informatique - Guide
- Code puk bloqué - Guide
- Code telephone oublié - Guide
- Code activation windows 10 - Guide
- Transformer majuscule en minuscule word - Guide
2 réponses
jordane45
Messages postés
38304
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
23 novembre 2024
4 705
Modifié par jordane45 le 30/12/2016 à 16:45
Modifié par jordane45 le 30/12/2016 à 16:45
Bonjour,
Déjà.. prend l'habitude de placer le code de connexion à la BDD dans un fichier à part.
Cela t'évitera de devoir retaper le code dans les différentes pages de ton site.
En PDO le fichier ressemble à ça:
Pense aussi à récupérer PROPREMENT tes varialbes ( POST / GET / SESSION.... ) en utilisant l'écriture Ternaire.
Voir ici :
https://forums.commentcamarche.net/forum/affich-37636387-php-notice-undefined-index
Il faut également, en PDO, utiliser des blocs TRY/CATCH pour detecter les éventuelles erreurs dans les requêtes.
Une fois tout cela pris en compte... voici à quoi ressemble désormais ton code :
Cordialement,
Jordane
Déjà.. prend l'habitude de placer le code de connexion à la BDD dans un fichier à part.
Cela t'évitera de devoir retaper le code dans les différentes pages de ton site.
En PDO le fichier ressemble à ça:
<?php //fichier de connexion à la bdd : cnxbdd.php try{ $bdd =new PDO('mysql:host=localhost;dbname=aide-systeme; charset=utf8', 'root', ''); $bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $bdd->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC); } catch(PDOException $e) { // en cas d'erreur lors de la connexion à la bdd die('Erreur : ' . $e->getMessage()); }
Pense aussi à récupérer PROPREMENT tes varialbes ( POST / GET / SESSION.... ) en utilisant l'écriture Ternaire.
Voir ici :
https://forums.commentcamarche.net/forum/affich-37636387-php-notice-undefined-index
Il faut également, en PDO, utiliser des blocs TRY/CATCH pour detecter les éventuelles erreurs dans les requêtes.
Une fois tout cela pris en compte... voici à quoi ressemble désormais ton code :
<?php //Affichage des erreurs PHP error_reporting(E_ALL); ini_set('display-errors','on'); //connexion à la BDD require_once 'cnxbdd.php'; //récupération PROPRE des variables $pseudo = !empty($_SESSION['pseudo']) ? $_SESSION['pseudo'] : NULL; //début du traitement : if($pseudo){ $sql = "SELECT COUNT(pseudo) as nb FROM cpt_connectes WHERE pseudo=:pseudo"; $datas = array(':pseudo'=>$pseudo); try{ $requete = $bdd -> prepare($sql) ; $requete->execute($datas) ; } catch(PDOException $e) { // en cas d'erreur dans la requete echo 'Erreur : ' . $e->getMessage(); } $res = $requete->fetchAll(); if(!empty($res)){ if($res[0]['nb']>0){ $sql = "update cpt_connectes set timestamp="'.time().'" where pseudo=:pseudo"; } else { $sql = "insert into cpt_connectes (pseudo, timestamp) values (:pseudo";,'".time()."'); } $datas = array(':pseudo'=>$pseudo); try{ $requete = $bdd -> prepare($sql) ; $requete->execute($datas) ; } catch(PDOException $e) { // en cas d'erreur dans la requete echo 'Erreur : ' . $e->getMessage(); } } } $times_m_5mins = time()-(60*5); $sql = 'detete from cpt_connectes where timestamp<"'.$times_m_5mins.'"'; try{ $requete = $bdd -> prepare($sql) ; $requete->execute() ; } catch(PDOException $e) { // en cas d'erreur dans la requete echo 'Erreur : ' . $e->getMessage(); } $sql = "SELECT pseudo FROM cpt_connectes "; try{ $requete = $bdd -> prepare($sql) ; $requete->execute() ; } catch(PDOException $e) { // en cas d'erreur dans la requete echo 'Erreur : ' . $e->getMessage(); } $res = $requete->fetchAll(); $nbConnecte = !empty($res) ? count($res) : 0; echo 'Il y a actuellement <strong>'.$nbConnecte.'</strong> membre(s) connecté(s)'; if($nbConnecte > 0 ){ $arr_pseudo = join(",",$res); echo $arr_pseudo; } ?>
Cordialement,
Jordane
jordane45
Messages postés
38304
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
23 novembre 2024
4 705
30 déc. 2016 à 18:03
30 déc. 2016 à 18:03
Histoire d'alléger un peu le code (et éviter des TRY/CATCH partout...) voici ton code refait en utilisant une FONCTION pour l'éxécution des requêtes
<?php //-------------------------------------------------------------------// //Affichage des erreurs PHP //-------------------------------------------------------------------// error_reporting(E_ALL); ini_set('display-errors','on'); //-------------------------------------------------------------------// //connexion à la BDD //-------------------------------------------------------------------// require_once 'cnxbdd.php'; //-------------------------------------------------------------------// //-------- FONCTION DE REQUETE -----------// //-------------------------------------------------------------------// function pdoQuery($sql,$datas=NULL){ glob $bdd; //instance de connexion à la BDD if(!empty($sql) && !empty($bdd)){ try{ $requete = $bdd -> prepare($sql) ; $requete->execute($datas) ; } catch(PDOException $e) { // en cas d'erreur dans la requete echo 'Erreur : ' . $e->getMessage(); $requete = NULL; } }else { //pas de requete ou de connexion à la bdd $requete = NULL; } return $requete; } //-------------------------------------------------------------------// //récupération PROPRE des variables //-------------------------------------------------------------------// $pseudo = !empty($_SESSION['pseudo']) ? $_SESSION['pseudo'] : NULL; //-------------------------------------------------------------------// //début du traitement : //-------------------------------------------------------------------// if($pseudo){ $sql = "SELECT COUNT(pseudo) as nb FROM cpt_connectes WHERE pseudo=:pseudo"; $datas = array(':pseudo'=>$pseudo); $requete = pdoQuery($sql,$datas); $res = !empty($requete) ? $requete->fetchAll() : NULL; if(!empty($res)){ if($res[0]['nb']>0){ $sql = "update cpt_connectes set timestamp="'.time().'" where pseudo=:pseudo"; } else { $sql = "insert into cpt_connectes (pseudo, timestamp) values (:pseudo";,'".time()."'); } $datas = array(':pseudo'=>$pseudo); $requete = pdoQuery($sql,$datas); } } $times_m_5mins = time()-(60*5); $sql = 'detete from cpt_connectes where timestamp<"'.$times_m_5mins.'"'; $requete = pdoQuery($sql); $sql = "SELECT pseudo FROM cpt_connectes "; $requete = pdoQuery($sql); $res = !empty($requete) ? $requete->fetchAll() : NULL; $nbConnecte = !empty($res) ? count($res) : 0; echo 'Il y a actuellement <strong>'.$nbConnecte.'</strong> membre(s) connecté(s)'; if($nbConnecte > 0 ){ foreach($res as $P){ echo $P['pseudo'] . "<br>"; } } ?>
Rebonjour, j'aimerais juste savoir ce que vous en pensez :
C'est pour une déconnexion automatique
Merci
Nils0
Bonne année et bonne santé
function deco_auto(){ if(isset($_SESSION['id'])){ if(!isset($bdd)){ $bdd = connexion_bdd(); } $pseudo = !empty($_SESSION['pseudo']) ? $_SESSION['pseudo'] : NULL; $get_id = htmlspecialchars($_SESSION['id']); $times_limit = time()-(60*10); $requete2 = $bdd->prepare("SELECT * FROM cpt_connectes") ; $requete2->execute(); $res = $requete2->fetch(); if(!empty($res['timestamp']) AND $res['timestamp'] < $times_limit){ // deconnexion auto $requete = $bdd->prepare("DELETE FROM cpt_connectes WHERE timestamp < ".$times_limit."") ; $requete->execute(); $reqco = $bdd->prepare('UPDATE membres SET co = 0 WHERE id = ?'); $reqco->execute(array($get_id)); $reqdco = $bdd->prepare('UPDATE membres SET derniere_co = NOW() WHERE id = ?'); $reqdco->execute(array($get_id)); $_SESSION = array(); session_destroy(); header('Location: connexion.php'); } else { // réactualiation du temps $requete = $bdd->prepare("SELECT COUNT(pseudo) AS nb FROM cpt_connectes WHERE pseudo=?"); $requete->execute(array($pseudo)); $res = $requete->fetchAll(); if(!empty($res)){ if($res[0]['nb']>0){ $sql = "UPDATE cpt_connectes SET timestamp=".time()." WHERE pseudo=?"; } else { $sql = "INSERT INTO cpt_connectes (pseudo, timestamp) VALUES (?,".time().")"; } $requete = $bdd->prepare($sql); $requete->execute(array($pseudo)); $reqco = $bdd->prepare('UPDATE membres SET co = 1 WHERE id = ?'); $reqco->execute(array($get_id)); } } } }
C'est pour une déconnexion automatique
Merci
Nils0
Bonne année et bonne santé
jordane45
Messages postés
38304
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
23 novembre 2024
4 705
>
Utilisateur anonyme
Modifié par jordane45 le 31/12/2016 à 15:00
Modifié par jordane45 le 31/12/2016 à 15:00
Moi je découperai en plusieurs sous fonctions ...
Un truc du style :
Tu places tout ça dans un fichier nommé par exemple fonctions_connexion.php
et tu l'inclus dans tes pages via un require_once
bon après... y'a peut être un peu plus simple que le mécanisme que tu as voulu mettre en place ....
par exemple,
Stocker la valeur du dernier affichage d'une page de ton site dans une variable de session pour ne pas avoir à faire une requête pour aller chercher le dernier timestamp ...
Un truc du genre :
pour moi... je ne pense pas que ton champ "co" de ta table membres soit nécéssaire:
Pour savoir si un utilisateur est connecté .. il suffit de regarder si son champ "timestamp" est inférieur à ton $times_limit (ce qui rend ta table cpt_connectes innutile...)
enfin bon.. à toi de voir.
Un truc du style :
<?php //démarrage des sessions si pas déjà démarrées if(session_id() == '') { session_start(); } //-----------------------------------------------------------// // ********** FONCTIONS ************ //-----------------------------------------------------------// function pdoQuery($sql,$datas=NULL){ glob $bdd; //instance de connexion à la BDD if(!empty($sql) && !empty($bdd)){ try{ $requete = $bdd -> prepare($sql) ; $requete->execute($datas) ; } catch(PDOException $e) { // en cas d'erreur dans la requete echo 'Erreur : ' . $e->getMessage(); $requete = NULL; } }else { //pas de requete ou de connexion à la bdd $requete = NULL; } return $requete; } function delete_old_cpt(){ $res = pdoQuery("DELETE FROM cpt_connectes WHERE timestamp < ".$times_limit."") ; return $res; } function update_co_by_id($id,$status=1){ $res = pdoQuery('UPDATE membres SET co = :status WHERE id = :id', array(':status'=>$status,':id'=>$get_id)); return $res; } function set_derniere_co_by_id($id){ $res = pdoQuery('UPDATE membres SET derniere_co = NOW() WHERE id = :id', array(':id'=>$get_id)); return $res; } function get_Nnb_connectes($pseudo){ $requete = pdoQuery("SELECT COUNT(pseudo) AS nb FROM cpt_connectes WHERE pseudo=:pseudo",array(':pseudo'=>$pseudo)); $res = !empty($requete) ? $requete->fetchAll() : NULL; return $res; } function actualise_co_user($id,$pseudo){ $res = get_Nnb_connectes($pseudo); if(!empty($res)){ if($res[0]['nb']>0){ $sql = "UPDATE cpt_connectes SET timestamp=".time()." WHERE pseudo=?"; } else { $sql = "INSERT INTO cpt_connectes (pseudo, timestamp) VALUES (?,".time().")"; } $requete = pdoQuery($sql,array($pseudo)); update_co_by_id($get_id,1); } return $res; } function get_last_co_user_by_id($id){ $req = pdoQuery("SELECT * FROM cpt_connectes WHERE id = :id",array(':id'=>$get_id)) ; $res = !empty($req) ? $req->fetch() : NULL; return !empty($res['timestamp']) ? $res['timestamp'] : NULL; } function destroyAndRedirect($urlToRedirect="index.php"){ session_destroy(); header('Location: '.$urlToRedirect); exit(); //toujours mettre un EXIT après une redirection php } /** * Fonction de déconnexion auto */ function deco_auto(){ //Récupération PROPRE des variables $get_id = !empty($_SESSION['id']) ? $_SESSION['id'] : NULL; $pseudo = !empty($_SESSION['pseudo']) ? $_SESSION['pseudo'] : NULL; //autres variables $bdd = !empty($bdd) ? $bdd : connexion_bdd(); $times_limit = time()-(60*10); // on sépare les requêtes et les datas .. de leux exécution et on n'oublie pas les TRY/CATCH à moins d'utiliser la fonction que je t'avais donné ! $timestampUser = get_last_co_user_by_id($get_id); if(!empty($timestampUser) AND $timestampUser < $times_limit){ // deconnexion auto delete_old_cpt(); update_co_by_id($get_id,0); set_derniere_co_by_id($get_id); destroyAndRedirect("connexion.php"); } else { // réactualiation du temps actualise_co_user($get_id,$pseudo); } }
Tu places tout ça dans un fichier nommé par exemple fonctions_connexion.php
et tu l'inclus dans tes pages via un require_once
//fichier de fonctions require_once "fonctions_connexion.php"; // deco auto deco_auto();
bon après... y'a peut être un peu plus simple que le mécanisme que tu as voulu mettre en place ....
par exemple,
Stocker la valeur du dernier affichage d'une page de ton site dans une variable de session pour ne pas avoir à faire une requête pour aller chercher le dernier timestamp ...
Un truc du genre :
$get_id = !empty($_SESSION['id']) ? $_SESSION['id'] : NULL; $times_limit = (60*10); if(($_SESSION['timeout']!="") && ($_SESSION['timeout'] + $times_limit <= time())) { //déco session_destroy(); // on detruit la session en cours. } else { set_derniere_co_by_id($get_id); $_SESSION['timeout'] = time(); }
pour moi... je ne pense pas que ton champ "co" de ta table membres soit nécéssaire:
Pour savoir si un utilisateur est connecté .. il suffit de regarder si son champ "timestamp" est inférieur à ton $times_limit (ce qui rend ta table cpt_connectes innutile...)
enfin bon.. à toi de voir.
Modifié par Nils0 le 30/12/2016 à 17:13
Il y a une erreur dans de ce bloc de code :
L'erreur :
Notice: Array to string conversion in ... on line 107
Merci
Nils0
Modifié par jordane45 le 30/12/2016 à 17:32
30 déc. 2016 à 17:44
30 déc. 2016 à 17:53
31 déc. 2016 à 11:26