Affichage date dans un tchat [Résolu]

sunev - 18 juin 2017 à 23:21 - Dernière réponse : jordane45 19710 Messages postés mercredi 22 octobre 2003Date d'inscriptionModérateurStatut 18 janvier 2018 Dernière intervention
- 20 juin 2017 à 20:42
Bonjour,

Dans la page d’un tchat qui devrait s’afficher avec la date des post
Il m’est renvoyé cette erreur :

Fatal error: Call to a member function fetch() on a non-object in C:\EasyPHP-12.1\www\01_esais\mini_tchat.php on line 222 -
--- -> qui est: while($msg = $allmsg->fetch()){

Je n’arrive pas a trouver cette erreur, si qu’elqu’un a une idée, merci de vos suggestions .


Le post

try{
$bdd = new PDO('mysql:host=127.0.0.1;dbname=chatmini;charset=utf-8','root', '');
}catch (Exception $e){
die('Erreur : ' . $e->getMessage());
}
if (isset($_POST['pseudo']) AND isset($_POST['message']) AND !empty($_POST['pseudo']) AND !empty($_POST['message'])) {
$pseudo = htmlspecialchars($_POST['pseudo']);
$message = htmlspecialchars($_POST['message']);
$insertmsg = $bdd->prepare('INSERT INTO chat (pseudo, message, date_creation) VALUES(?, ?, NOW())');
$insertmsg->execute(array($pseudo,$message));




L’affichage

<div id="messages" class="vert">
<?php
$allmsg = $bdd->query('SELECT pseudo, message, DATE_FORMAT(date_creation, \'%d/%m/%Y a %Hh%i\')
AS date_creation FROM chat ORDER BY ID DESC LIMIT 0, 10');
while($msg = $allmsg->fetch()){
?>
<p>< <b><?php echo $msg['date_creation']; ?> : </b>
b><?php echo $msg['pseudo']; ?> : </b>
<?php echo $msg['message']; ?> <hr><br/></p>
<?php
}
?>
</div>


Afficher la suite 

18 réponses

Répondre au sujet
jordane45 19710 Messages postés mercredi 22 octobre 2003Date d'inscriptionModérateurStatut 18 janvier 2018 Dernière intervention - Modifié par jordane45 le 19/06/2017 à 00:10
0
Utile
Bonjour,

1 - Ta question concerne le PHP ... alors pourquoi la poster dans le forum JAVASCRIPT ?? ( je la déplace au bon endroit ! )

2- Lorsque tu postes du code.. merci d'indiquer, dans les balises de code, le langage ... histoire d'avoir la coloration syntaxique.
Explications disponibles ici: http://codes-sources.commentcamarche.net/faq/10686-le-nouveau-codes-sources-comment-ca-marche#balises-code

3 - Pour voir les éventuelles erreurs PDO .. tu dois ACTIVER l'affichage des erreurs PDO : voir ici : http://www.commentcamarche.net/faq/46512-pdo-gerer-les-erreurs

4 - Ton message d'erreur semble indiquer que ta requête contient une erreur ou ne retourne aucun résultat ou que la connexion à la bdd n'a pas été faite

5 - Au lieu d'utiliser le "query" il est préférable d'utiliser les requêtes préparées... même pour du SELECT ...


Déjà on commence par placer le code de connexion à la bdd dans un fichier
à part qu'on aura qu'à inclure dans nos différentes pages.
AU passage... on y active la gestion des erreurs PDO (voir ici : http://www.commentcamarche.net/faq/46512-pdo-gerer-les-erreurs )
  <?php
  //Fichier : cnxbdd.php
  // connexion à la bdd
  try{
    $bdd =new PDO('mysql:host=localhost;dbname=chatmini; charset=utf8', 'root', '');
    // Activation des erreurs PDO
    $bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  // mode de fetch par défaut : FETCH_ASSOC / FETCH_OBJ / FETCH_BOTH
    $bdd->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
  } catch(PDOException $e) {
    die('Erreur : ' . $e->getMessage());
  }

  ?>
 
 


Ensuite.. on place le MAXIMUM de code PHP .. AVANT le html.
.. et on n'utilise pas les fonctions comme htmlspecialchar pour l'insertion en bdd .. uniquement pour l'affichage !

<?php
//-----------------------------------------------------------//
//Affichage des erreurs
//-----------------------------------------------------------//
error_reporting(E_ALL);
ini_set('display-errors','on');

//-----------------------------------------------------------//
//connexion à la bdd
//-----------------------------------------------------------//
require_once "cnxbdd.php";

//-----------------------------------------------------------//
//traitement du submit
//-----------------------------------------------------------//

  //récupération PROPRE des variables AVANT de les utiliser :
  $message = !empty($_POST['message']) ? $_POST['message'] : NULL;
  $pseudo = !empty($_POST['pseudo']) ? $_POST['pseudo'] : NULL;
  
  //Insertion en bdd si non vide
  if ($pseudo && $message) {
    $sql = "INSERT INTO chat (pseudo, message, date_creation) VALUES(?, ?, NOW())";
    $datas = array($pseudo,$message);
    try{
      $prep = $bdd->prepare($sql);
      $prep->execute($datas);
    }catch(Exception $e){
      echo " Erreur : ".$e->getMessage();
    }    
  }

 
 
//-----------------------------------------------------------//
//Liste des messages
//-----------------------------------------------------------//
  $sql = "SELECT pseudo, 
                 message, 
                 DATE_FORMAT(date_creation, \'%d/%m/%Y a %Hh%i\') AS date_creation 
          FROM chat 
          ORDER BY ID DESC LIMIT 0, 10'";

  try{
    $prep = $bdd->prepare($sql);
    $prep->execute();
    $allmsg = $prep->fetchAll(); // on stocke les résultats dans un array
  }catch(Exception $e){
    echo " Erreur : ".$e->getMessage();
  }


 
?>

<!-- Et ensuite...le reste de ton code html -->
<!-- ...  -->

<div id="messages" class="vert">
<?php
 if(!empty($allmsg)){
  foreach($allmsg as $smg){
    echo "<p>
          <b>". $msg['date_creation'].": </b> 
          <b>".htmlspecialchars($msg['pseudo'])." : </b> 
          ".htmlspecialchars($msg['message'])."<hr><br/>
         </p> "; 
  }
} 
?>
</div>


Cordialement, 
Jordane                                                                 
Commenter la réponse de jordane45
0
Utile
1
salut jordane45 et merci de ta réponse

j'ai mis le code que tu m'a envoyé et il me renvoie l'erreur suivante:

Erreur : SQLSTATE[42000]: Syntax error or access violation: 1064 Erreur de syntaxe pr�s de '\'%d/%m/%Y a %Hh%i\') AS date_creation FROM chat ORDER ' � la ligne 3

sur la ligne:

$sql = "SELECT pseudo,
message,
DATE_FORMAT(date_creation, \'%d/%m/%Y a %Hh%i\') AS date_creation
FROM chat
ORDER BY ID DESC LIMIT 0, 10'";


juste aprés 10 il y aurait un ' de trop, mais c'est pareil en l'enlevant, j'ai essayé d'autres rajout de ' et de () mais ça renvoie toujours la méme erreur
Reivax962 3116 Messages postés jeudi 16 juin 2005Date d'inscription 16 janvier 2018 Dernière intervention - 20 juin 2017 à 09:51
Bonjour,

Il n'est pas nécessaire d'échapper les ' à l'intérieur des "
Essaie ça :
$sql = "SELECT pseudo, 
                 message, 
                 DATE_FORMAT(date_creation, '%d/%m/%Y à %Hh%i')  AS date_creation 
          FROM chat 
          ORDER BY ID DESC LIMIT 0, 10";

Xavier
Commenter la réponse de sunev
0
Utile
1
Merci Reivax962

Mais avec ton code une nouvelle erreur qui s'affiche, le casse tête chinois continue

Erreur : SQLSTATE[42S22]: Column not found: 1054 Champ 'date_creation' inconnu dans field list

j'ai simplifié le code du mini tchat au plus simple: 2 pages (3 avec la bdd)

Page d’ouverture:
essaitchat.php
<?php
//connection a la BDD
 include("mini_tchat_inc_connect_bdd.php"); 
?>
<!DOCTYPE html>
<html><head>
<title>TChat</title>  <meta charset="utf-8">
	<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
</head><body>
<?php
//-----------------------------------------------------------//
//traitement du submit
//-----------------------------------------------------------//
//récupération PROPRE des variables AVANT de les utiliser :
  $message = !empty($_POST['message']) ? $_POST['message'] : NULL;
  $pseudo = !empty($_POST['pseudo']) ? $_POST['pseudo'] : NULL;
 //Insertion en bdd si non vide
  if ($pseudo && $message) {
    $sql = "INSERT INTO chat (pseudo, message, date_creation) VALUES(?, ?, NOW())";
    $datas = array($pseudo,$message);
    try{
      $prep = $bdd->prepare($sql);
      $prep->execute($datas);
    }catch(Exception $e){
      echo " Erreur : ".$e->getMessage();
    }    
  }
//-----------------------------------------------------------//
//Liste des messages
//-----------------------------------------------------------//
 $sql = "SELECT pseudo, message, DATE_FORMAT(date_creation, '%d/%m/%Y à %Hh%i')  AS date_creation FROM chat  ORDER BY ID DESC LIMIT 0, 10";
  try{
    $prep = $bdd->prepare($sql);
    $prep->execute();
    $allmsg = $prep->fetchAll(); // on stocke les résultats dans un array
  }catch(Exception $e){
    echo " Erreur : ".$e->getMessage();
  }
?>
<!-- Et ensuite...le reste de ton code html -->
   <form name="" method="post">
       <p><input class="text" type="text" placeholder="PSEUDO" name="pseudo" value="<?php
       if (isset($pseudo)) { echo $pseudo; } ?>" /></p>
      <p><textarea type="text"  name="message"></textarea></p>
	   <p><input type="submit"  value="Envoyer"></p>
</form>

//affichage des messages
<div id="messages">
<?php
 if(!empty($allmsg)){
  foreach($allmsg as $smg){
    echo "<p>
          <b>". $msg['date_creation'].": </b> 
          <b>".htmlspecialchars($msg['pseudo'])." : </b> 
          ".htmlspecialchars($msg['message'])."<hr><br/>
         </p> "; 
  }
} 
?>
</div>
<script>
setInterval('load_messages()', 2000);
function load_messages(){
$('#messages').load('essai_mini_tchat_load_messages.php');
}
</script>
</body></html>



Page de réactualisation:
essai_mini_tchat_load_messages.php
//connection a la BDD
 include("mini_tchat_inc_connect_bdd.php"); 
//-----------------------------------------------------------//
//Liste des messages
//-----------------------------------------------------------//
 $sql = "SELECT pseudo, message, DATE_FORMAT(date_creation, '%d/%m/%Y à %Hh%i')  AS date_creation FROM chat 
          ORDER BY ID DESC LIMIT 0, 10";
  try{
    $prep = $bdd->prepare($sql);
    $prep->execute();
    $allmsg = $prep->fetchAll(); // on stocke les résultats dans un array
  }catch(Exception $e){
    echo " Erreur : ".$e->getMessage();
  }
?>

<div id="messages">
<?php
 if(!empty($allmsg)){
  foreach($allmsg as $smg){
    echo "<p>
          <b>". $msg['date_creation'].": </b> 
          <b>".htmlspecialchars($msg['pseudo'])." : </b> 
          ".htmlspecialchars($msg['message'])."<hr><br/>
         </p> "; 
  }
} 
?>
</div>


Mon premier minitchat fonctionné trés bien avec la date mais l'actualisation ne fonctionnée pas,
j'ai donc utilisé jquery pour l'actualisation qui a fonctionné avec
mais la date elle ne fonctionné plus?
Si on enleve la date et son affichage ce code marche trés bien et le minitchat fonctionne avec son actualisation automatique.
On peut voir ça sur
http://siteartpeinture.free.fr/mini_tchat.php
jordane45 19710 Messages postés mercredi 22 octobre 2003Date d'inscriptionModérateurStatut 18 janvier 2018 Dernière intervention - 20 juin 2017 à 17:57
Le message d'erreur est on ne peut plus clair ....
Erreur : SQLSTATE[42S22]: Column not found: 1054 Champ 'date_creation' inconnu dans field list 

Visiblement : Champ 'date_creation' inconnu ... cela signifie que dans ta table ... aucun champ ne porte le nom de : date_creation (attention aux majuscules/minuscules !!! )
Commenter la réponse de sunev
0
Utile
LE COPIER COLLER de la table chat de la BDD chatmini
( je sais il manque un T devant chat)


4 date_creation datetime
Commenter la réponse de sunev
0
Utile
1
donc pas de probleme de ce côté là
jordane45 19710 Messages postés mercredi 22 octobre 2003Date d'inscriptionModérateurStatut 18 janvier 2018 Dernière intervention - 20 juin 2017 à 18:19
Tu pourrais nous faire un DUMP (structure + quelques données) de ta BDD ?

De plus .. dans ta requête .. tu as mis un ALIAS portant le même nom que le champ
SELECT pseudo, message, DATE_FORMAT(date_creation, '%d/%m/%Y à %Hh%i')  AS date_creation FROM chat 
ORDER BY ID DESC LIMIT 0, 10

Evite !
Essaye :
SELECT pseudo, message, DATE_FORMAT(date_creation, '%d/%m/%Y à %Hh%i')  AS DATECREATION 
FROM chat 
ORDER BY ID DESC LIMIT 0, 10";
Commenter la réponse de sunev
0
Utile
la srtucture de la table;
1 id int(11) Non Aucune AUTO_INCREMENT
2 pseudo varchar(25) latin1_swedish_ci NonAucune
3 message text latin1_swedish_ci Non Aucune
4 date_creation datetime Non Aucune


fichier: mini_tchat_inc_connect_bdd.php
<?php
//Affichage des erreurs
error_reporting(E_ALL);
ini_set('display-errors','on');
//connexion à la bdd
 try{
    $bdd =new PDO('mysql:host=localhost;dbname=chatmini; charset=utf8', 'root', '');
    // Activation des erreurs PDO
    $bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  // mode de fetch par défaut : FETCH_ASSOC / FETCH_OBJ / FETCH_BOTH
    $bdd->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
  } catch(PDOException $e) {
    die('Erreur : ' . $e->getMessage());
  }
 ?>
Commenter la réponse de sunev
0
Utile
1
dans le champ 1 il n'est pas en PRIMARY
je le met peut être que ça vient de là
jordane45 19710 Messages postés mercredi 22 octobre 2003Date d'inscriptionModérateurStatut 18 janvier 2018 Dernière intervention - 20 juin 2017 à 18:44
Non.
Mais as tu modifié la requête comme je te l'ai dit ??
Commenter la réponse de sunev
0
Utile
j'ai changé date_creation pour creation
j'ai mis le champ id en Primary


les nouvelles erreurs qui s'affichent:

Notice: Undefined variable: msg in C:\EasyPHP-12.1\www\01_esais\essai_mini_tchat_load_messages.php on line 24

Notice: Undefined variable: msg in C:\EasyPHP-12.1\www\01_esais\essai_mini_tchat_load_messages.php on line 25

Notice: Undefined variable: msg in C:\EasyPHP-12.1\www\01_esais\essai_mini_tchat_load_messages.php on line 26
Commenter la réponse de sunev
0
Utile
oui pour la requête

SELECT pseudo, message, DATE_FORMAT(date_creation, '%d/%m/%Y à %Hh%i') AS DATECREATION
FROM chat
ORDER BY ID DESC LIMIT 0, 10";

a la place de DATECREATION j'ai mis creation au lieu de date_creation, et et mis mon champ id en PRIMARY maintenant j' ai ces nouvelles erreurs/

Notice: Undefined variable: msg in C:\EasyPHP-12.1\www\01_esais\essai_mini_tchat_load_messages.php on line 24

Notice: Undefined variable: msg in C:\EasyPHP-12.1\www\01_esais\essai_mini_tchat_load_messages.php on line 25

Notice: Undefined variable: msg in C:\EasyPHP-12.1\www\01_esais\essai_mini_tchat_load_messages.php on line 26
Commenter la réponse de sunev
0
Utile
if(!empty($allmsg)){
foreach($allmsg as $smg){
echo "<p>
24 <b>". $msg['creation'].": </b>
25 <b>".htmlspecialchars($msg['pseudo'])." : </b>
26 ".htmlspecialchars($msg['message'])."<hr><br/>
</p> ";
Commenter la réponse de sunev
0
Utile
L'erreur
Erreur : SQLSTATE[42S22]: Column not found: 1054 Champ 'date_creation' inconnu dans field list
venait bien de la requête avec date_creation puisque en changeant avec
creation ça fonctionne, mais maintenant les messages ne veulent plus s'afficher, la variable $msg n'est pas reconnue et affiche les erreurs :

Notice: Undefined variable: msg in C:\EasyPHP-12.1\www\01_esais\essai_mini_tchat_load_messages.php on line 24 25 26
pour le code
21        if(!empty($allmsg)){
22        foreach($allmsg as $smg){
23       echo "<p>
24     <b>". $msg['creation'].": </b>
25     <b>".htmlspecialchars($msg['pseudo'])." : </b><br/>
26 "   .htmlspecialchars($msg['message'])."
         </p> ";


pourtant dans: foreach($allmsg as $smg) elle devrait être prise en compte?
Commenter la réponse de sunev
0
Utile
ça y est les mecs
ça marche avec:
if(!empty($allmsg)){
  foreach($allmsg as$donnees){
  echo 
  '<P> '
  . $donnees['DATECREATION']. ':<strong> ' 
  . htmlspecialchars($donnees['pseudo']) .'</strong> : '
  . htmlspecialchars($donnees['message']) 
  . '</p>';
}
}
?>


il ne reste plus qu'à habiller le code avec du css
Merci a toi jordane45 et à Reivax962 de votre aide, je vais mettre le code en entier pour ceux que ça interresse.
Commenter la réponse de sunev
0
Utile
3 fichiers:
la connection a la bdd:
mini_tchat_inc_connect_bdd.php
<?php
//Affichage des erreurs
error_reporting(E_ALL);
ini_set('display-errors','on');
//connexion à la bdd
 try{
    $bdd =new PDO('mysql:host=localhost;dbname=chatmini; charset=utf8', 'root', '');
    // Activation des erreurs PDO
    $bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  // mode de fetch par défaut : FETCH_ASSOC / FETCH_OBJ / FETCH_BOTH
    $bdd->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
  } catch(PDOException $e) {
    die('Erreur : ' . $e->getMessage());
  }
 ?>


la page principale que l'on peut renommée en index.php ou autre:

essaitchat.php

<?php
//connection a la BDD
 include("mini_tchat_inc_connect_bdd.php"); 
?>
<!DOCTYPE html>
<html><head>
<title>TChat</title>  <meta charset="utf-8">
	<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
</head><body>
<?php
//-----------------------------------------------------------//
//traitement du submit
//-----------------------------------------------------------//
//récupération PROPRE des variables AVANT de les utiliser :
  $message = !empty($_POST['message']) ? $_POST['message'] : NULL;
  $pseudo = !empty($_POST['pseudo']) ? $_POST['pseudo'] : NULL;
 //Insertion en bdd si non vide
  if ($pseudo && $message) {
    $sql = "INSERT INTO chat ( pseudo, message, creation) VALUES(?, ?, NOW())";
    $datas = array($pseudo,$message);
    try{
      $prep = $bdd->prepare($sql);
      $prep->execute($datas);
    }catch(Exception $e){
      echo " Erreur : ".$e->getMessage();
    }    
  }
//-----------------------------------------------------------//
//Liste des messages
//-----------------------------------------------------------//
 $sql = "SELECT pseudo, message, DATE_FORMAT(creation, '%d/%m/%Y à %Hh%i')  AS DATECREATION 
FROM chat 
ORDER BY ID DESC LIMIT 0, 10";
  try{
    $prep = $bdd->prepare($sql);
    $prep->execute();
    $allmsg = $prep->fetchAll(); // on stocke les résultats dans un array
  }catch(Exception $e){
    echo " Erreur : ".$e->getMessage();
  }
?>
<!-- Et ensuite...le reste du code html -->
   <form name="" method="post">
       <p><input class="text" type="text" placeholder="PSEUDO" name="pseudo" value="<?php
       if (isset($pseudo)) { echo $pseudo; } ?>" /></p>
      <p><textarea type="text"  name="message"></textarea></p>
	   <p><input type="submit"  value="Envoyer"></p>
</form>

<div id="messages">
<?php
 if(!empty($allmsg)){
  foreach($allmsg as$donnees){
  echo 
  '<P> '
  . $donnees['DATECREATION']. ':<strong> ' 
  . htmlspecialchars($donnees['pseudo']) .'</strong> : '
  . htmlspecialchars($donnees['message']) 
  . '</p>';
}
}
?>

</div>

<script>
setInterval('load_messages()', 2000);
function load_messages(){
     $('#messages').load('essai_mini_tchat_load_messages.php');
}
</script>

</body>
</html>


La page d'actualisation automatique:

essai_mini_tchat_load_messages.php


<?php
//connection a la BDD
 include("mini_tchat_inc_connect_bdd.php"); 
//-----------------------------------------------------------//
//Liste des messages
//-----------------------------------------------------------//

 $sql = "SELECT pseudo, message, DATE_FORMAT(creation, '%d/%m/%Y à %Hh%i')  AS DATECREATION 
FROM chat 
ORDER BY ID DESC LIMIT 0, 10";
//"SELECT  pseudo, message, DATE_FORMAT(creation, '%d/%m/%Y à %Hh%i')  AS creation FROM chat 
          //ORDER BY ID DESC LIMIT 0, 10";
  try{
    $prep = $bdd->prepare($sql);
    $prep->execute();
    $allmsg = $prep->fetchAll(); // on stocke les résultats dans un array
  }catch(Exception $e){
    echo " Erreur : ".$e->getMessage();
  }
?>

<div id="messages">
<?php

if(!empty($allmsg)){
  foreach($allmsg as$donnees){
  echo 
  '<P> '
  . $donnees['DATECREATION']. ':<strong> ' 
  . htmlspecialchars($donnees['pseudo']) .'</strong> : '
  . htmlspecialchars($donnees['message']) 
  . '</p>';
}
}
?>
</div>


Il ne reste plus qu'à habiller tout ça avec du css.
Commenter la réponse de sunev
jordane45 19710 Messages postés mercredi 22 octobre 2003Date d'inscriptionModérateurStatut 18 janvier 2018 Dernière intervention - 20 juin 2017 à 20:42
0
Utile
Tu penseras à mettre le sujet en RÉSOLU.
Pour le css... on te laisse faire.
Commenter la réponse de jordane45