Problème création annuaire
Fermé
Tutti
-
Modifié le 2 déc. 2019 à 22:07
jordane45 Messages postés 38288 Date d'inscription mercredi 22 octobre 2003 Statut Modérateur Dernière intervention 15 novembre 2024 - 11 déc. 2019 à 19:48
jordane45 Messages postés 38288 Date d'inscription mercredi 22 octobre 2003 Statut Modérateur Dernière intervention 15 novembre 2024 - 11 déc. 2019 à 19:48
A voir également:
- Problème création annuaire
- Annuaire inversé - Guide
- Annuaire maroc telecom particulier ✓ - Forum Mobile
- Creation compte gmail - Guide
- Annuaire inversé suisse ✓ - Forum Mail
- Annuaire sfr ✓ - Forum SFR
5 réponses
yg_be
Messages postés
23327
Date d'inscription
lundi 9 juin 2008
Statut
Contributeur
Dernière intervention
15 novembre 2024
Ambassadeur
1 551
2 déc. 2019 à 21:48
2 déc. 2019 à 21:48
bonjour, merci d'utiliser les balises de code, et d'indiquer à quelle ligne l'erreur se produit.
jordane45
Messages postés
38288
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
15 novembre 2024
4 703
2 déc. 2019 à 22:49
2 déc. 2019 à 22:49
Bonjour,
Pour commencer, comme te l'a indiqué Yg_be, il faut correctement utiliser les balises de code
explications disponibles ici :
https://codes-sources.commentcamarche.net/faq/11288-poster-un-extrait-de-code
Ensuite, tu sembles utiliser l'ancienne extension mysql ... qui est désormais OBSOLETE.
https://www.commentcamarche.net/faq/43261-php-l-extension-mysql-est-obsolete#top
Il faut donc réécrire ton code en PDO ou en mysqli.
Il serait bien également d'utiliser l'écriture ternaire histoire de rendre ton code un peu plus lisible.
Par exemple;.. à la place de :
écrire :
et lorsque tu as besoin de IF/ELSE .. la bonne présentation du code est la façon suivante (avec les retours à la ligne... et l'indentation )
je t'invite également à lire et à appliquer le contenu de ce lien :
https://forums.commentcamarche.net/forum/affich-37584947-php-gestion-des-erreurs-debogage-et-ecriture-du-code
Pour commencer, comme te l'a indiqué Yg_be, il faut correctement utiliser les balises de code
explications disponibles ici :
https://codes-sources.commentcamarche.net/faq/11288-poster-un-extrait-de-code
Ensuite, tu sembles utiliser l'ancienne extension mysql ... qui est désormais OBSOLETE.
https://www.commentcamarche.net/faq/43261-php-l-extension-mysql-est-obsolete#top
Il faut donc réécrire ton code en PDO ou en mysqli.
Il serait bien également d'utiliser l'écriture ternaire histoire de rendre ton code un peu plus lisible.
Par exemple;.. à la place de :
if($nbM!='0') { $ok='1'; } else { $ok='0'; }
écrire :
$ok = $nbM!='0' ? '1' : 0 ;
et lorsque tu as besoin de IF/ELSE .. la bonne présentation du code est la façon suivante (avec les retours à la ligne... et l'indentation )
if( condition ) { //code si vrai }else{ // code si faux }
je t'invite également à lire et à appliquer le contenu de ce lien :
https://forums.commentcamarche.net/forum/affich-37584947-php-gestion-des-erreurs-debogage-et-ecriture-du-code
Bonjour,
Voila j'ai modifié le code jordane45. Mon extension php est obsolète mais en faite mon site tourne avec du php 5.3 ( du coup j'aurais voulu trouvé une solution au code ci-dessous en attendant de devoir modifier mon code en PDO).
( je pense que l'erreur vient aussi d'un select au niveau de la base de donnée ou d'une variable = genre les variable 1 ou 2).
merci d'avance,
Voila j'ai modifié le code jordane45. Mon extension php est obsolète mais en faite mon site tourne avec du php 5.3 ( du coup j'aurais voulu trouvé une solution au code ci-dessous en attendant de devoir modifier mon code en PDO).
( je pense que l'erreur vient aussi d'un select au niveau de la base de donnée ou d'une variable = genre les variable 1 ou 2).
merci d'avance,
<?php echo '<div class="carnet-adresses">'; /* recup les vals */ /* if(isset($_POST['nom'])) { $nom = $_POST['nom']; } if(isset($_POST['dept'])) { $dept = $_POST['dept']; } if(isset($_POST['type'])) { $type = $_POST['type']; } else { $type = 'tous'; } if(isset($_POST['style'])) { $style = $_POST['style']; } /**/ $depts=array(); $types =array(); $styles =array(); if(isset($_POST['nom'])) { $nom = $_POST['nom']; } if(isset($_POST['dept'])) { $depts = $_POST['dept']; } if(isset($_POST['type'])) { $types = $_POST['type']; } else { $type = 'tous'; } if(isset($_POST['style'])) { $styles = $_POST['style']; } $nom = str_replace("é","é",$nom); $nom = str_replace("è","è",$nom); $nom = str_replace("à","à",$nom); if($nom!='') { $needNom = ' and nom like "%'.$nom.'%" '; } else { $needNom=''; } $needDept=''; $needType=''; if( !empty($depts) && !in_array("tous",$depts) ){ foreach($depts as $dept){ $needDept .= ($needDept =="")? " AND ( " : " OR "; $needDept .= " departement='".$dept."' "; } $needDept .=" ) "; } if( !empty($types) && !in_array("tous",$types) ){ foreach($types as $type){ $needType .= ($needType =="")? " AND ( " : " OR "; $needType .= " type = '".$type."' "; } $needType .=" ) "; } /* if($dept!='tous') { $needDept = ' and departement="'.$dept.'" '; } else { $needDept=''; } if($type!='tous') { $needType = ' and type="'.$type.'" '; } else { $needType=''; } if($style!='tous') { $needStyle = ' and nom="%'.$style.'%" '; } else { $needStyle=''; } /**/ $where = $needNom.$needDept.$needType; $l=0; $query='SELECT * FROM membre where public=1 and actif = 1 and departement < 5 '.$where.' ORDER BY nom asc'; $res = $modx->db->query( $query ); //var_dump($query); $nb = $modx->db->getRecordCount($res); for($k=0;$k<$nb;$k++) { $okreq = '0'; $ok='0'; $row = $modx->db->getRow($res); $type2=$row['type']; $needStyle=''; if( !empty($styles) && !in_array("tous",$styles) ){ foreach($styles as $style){ $needStyle .= ($needStyle =="")? " AND ( " : " OR "; $needStyle .= " style_musical='".$style."' "; } $needStyle .=" ) "; } if( !in_array("tous",$styles) && $type2!='') { /* filtre style musical */ $table_details = 'membre_'.$type2; $selectD = $modx->db->query('select * from '.$table_details); $colDnb = mysql_num_fields($selectD); for($i=0; $i<$colDnb; $i++) { $field_name = mysql_field_name($selectD,$i); if($field_name=='style_musical') { $okreq='1';} } if($okreq=='1') { if($row['idmembre'] != null && strlen($row['idmembre']) > 0){ echo "plop".$row['idmembre']; die(); $idm = $row['idmembre']; //$resMusic = $modx->db->query('select * from '.$table_details.' where IDmembre='.$idm.' and style_musical='.$style); $queryMusic = 'select * from '.$table_details.' where IDmembre=0'.$idm.$needStyle; $resMusic = $modx->db->query($queryMusic); $nbM = mysql_num_rows($resMusic); } else { $nbM = 0 } $ok = $nbM!='0' ? '1' : 0 ; else { if($row['idmembre'] != null && strlen($row['idmembre']) > 0){ echo "plop".$row['idmembre']; die(); $idm = $row['idmembre']; $resMusic = $modx->db->query('select * from '.$table_details.' where IDmembre=0'.$idm); $nbM = mysql_num_rows($resMusic); } else { $nbM = 0 } $ok = $nbM!='0' ? '1' : 0 ; if($ok=='1' && $nb!=0) { $idm = $row['idmembre']; $nom = utf8_encode($row['nom']); $tel = utf8_encode($row['telephone']); $ville = utf8_encode($row['ville']); $email = utf8_encode($row['mail']); if($row['site']!='') { $siteweb = 'http://'.utf8_encode($row['site']); } else { $siteweb=''; } /* get type fullname */ $getType = $modx->db->query('select * from polca_sous_type_membre_db_name where value="'.$type2.'" '); $rowgetType = $modx->db->getRow($getType); $typeId = $rowgetType['internalKey_soustype']; $getTypeName = $modx->db->query('select * from polca_type_sous_membre where id='.$typeId); $rowgetTypeName = $modx->db->getRow($getTypeName); $nameType = utf8_encode($rowgetTypeName['value']); echo '<div class="col-sm-4"><div class="un_contact">'; if($nom!=NULL) { echo '<a class="manage plus" href="[~188~]&idm='.$idm.'" title="'.utf8_decode($nom).'">Voir</a>'; } if($nom!=NULL) { echo '<a class="manage nom" href="[~188~]&idm='.$idm.'" title="'.utf8_decode($nom).'">'.ucwords(strtolower(utf8_decode($nom))).'</a>'; } if($nom!=NULL) { echo '<a class="manage type" href="[~188~]&idm='.$idm.'" title="'.$type2.'">'.$nameType.'</a>'; } if($ville!=NULL) { echo '<a class="manage ville" href="[~188~]&idm='.$idm.'" title="'.utf8_decode($nom).'"><span></span>'.$ville.'</a>'; } if($tel!=NULL) { echo '<a class="manage phone" href="[~188~]&idm='.$idm.'" title="'.utf8_decode($nom).'"><span></span>'.$tel.'</a>'; } echo '<a class="manage mail" href="[~190~]&idm='.$idm.'" title="'.utf8_decode($nom).'"><span></span>Écrire</a>'; if($siteweb!='') { echo '<a href="'.$siteweb.'" title="'.$nom.'" class="siteweb" onclick="window.open(this.href,\'_blank\');return false;"><span></span>Visiter le site</a></div></div>'; } else { echo '</div></div>'; } echo '</tr>'; } } if($nb==0){ echo '<p id="no_results_p">Aucun résultat de recherche. Élargissez votre requête pour obtenir plus de résultats.</p>'; } echo '</div>'; ?>
yg_be
Messages postés
23327
Date d'inscription
lundi 9 juin 2008
Statut
Contributeur
Dernière intervention
15 novembre 2024
1 551
>
Tutti
3 déc. 2019 à 18:58
3 déc. 2019 à 18:58
et maintenant, tout fonctionne?
Tutti
>
yg_be
Messages postés
23327
Date d'inscription
lundi 9 juin 2008
Statut
Contributeur
Dernière intervention
15 novembre 2024
3 déc. 2019 à 19:04
3 déc. 2019 à 19:04
Non j'ai toujours le même problème.
jordane45
Messages postés
38288
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
15 novembre 2024
4 703
3 déc. 2019 à 19:27
3 déc. 2019 à 19:27
D'où vient ta fonction $modx->db->query ?
Gères tu les éventuelles erreurs sql ?
Gères tu les éventuelles erreurs sql ?
<?php $host = "Mon serveur"; $user = "utilisateur"; $password = "mot de passe"; $bdd = "ma base de donnée"; mysql_connect($host, $user, $password) or die ("Connexion au serveur impossible"); // on choisit la bonne base mysql_select_db($bdd) or die ("Connexion a la base impossible"); $nom = $_POST['nom']; echo " <html> <head> <title>Résultat de la recherche</title> </head> <body>"; if (($Mot == "")||($Mot == "%")) { // Si aucun mot clé n'a été saisi, // le script demande à l'utilisateur // de bien vouloir préciser un mot clé echo " Aucun résultat de recherche. Élargissez votre requête pour obtenir plus de résultats. <p>"; } else { // On selectionne les enregistrements contenant le mot clé $query = "SELECT distinct nom FROM membre WHERE nom LIKE \"%$nom%\" "; $result = mysql_query($query); $row = mysql_fetch_row($result); $Nombre = $row[0]; // Si aucun enregistrement n'est retourné, // on affiche un message adéquat if ($Nombre == "0") { echo " <h2>Aucun résultat ne correspond à votre recherche</h2> <p> "; } // Sinon, on affiche le nombre d'enregistrements correspondant // et les résultats eux-mêmes else { $query = "SELECT distinct nom, titre FROM membre WHERE nom LIKE \"%$nom%\" ORDER by titre ASC"; $result = mysql_query($query); // Si un seul enregistrement est trouvé, on affiche un message au singulier if ($Nombre == "1") { echo " <a name=\"#resultat\"><h2>Résultat: Un article trouvé</h2></a> <p>"; } // Dans le cas contraire le message est au pluriel... else { echo " <a name=\"#resultat\"><h2>Résultat: $Nombre articles trouvés</h2></a> <p>"; } while($row = mysql_fetch_row($result)) { echo " <p>\n <b>$row[2]</b>\n <br><a href=\"../$row[0]\">Visualiser l'article</a>\n <p>\n "; } } } // on ferme la base mysql_close(); ?> </body> </html>
J'ai essayé d'adapter mon code en sql. Je n'ai plus de problème d'erreur. Cependant quand je tape un mot ( il m'affiche tous le temps " Aucun résultat ne correspond à votre recherche. ( est ce que j'ai oublié une requète ? )
PS : j'ai limité mon retour que au nom
jordane45
Messages postés
38288
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
15 novembre 2024
4 703
Modifié le 9 déc. 2019 à 23:27
Modifié le 9 déc. 2019 à 23:27
Visiblement ... tu n'as pas envie de suivre les consignes qu'on te donne.
Je t'ai "fortement" invité à lire ET à appliquer le contenu de ce lien : https://forums.commentcamarche.net/forum/affich-37584947-php-gestion-des-erreurs-debogage-et-ecriture-du-code
.. mais tu ne sembles pas décidé à le faire...
Tu as également de grosses lacunes sur l'écriture du code html en plus du code php...
bref... ton code devrait ressembler à ceci :
Je t'ai "fortement" invité à lire ET à appliquer le contenu de ce lien : https://forums.commentcamarche.net/forum/affich-37584947-php-gestion-des-erreurs-debogage-et-ecriture-du-code
.. mais tu ne sembles pas décidé à le faire...
Tu as également de grosses lacunes sur l'écriture du code html en plus du code php...
bref... ton code devrait ressembler à ceci :
<?php $host = "Mon serveur"; $user = "utilisateur"; $password = "mot de passe"; $bdd = "ma base de donnée"; mysql_connect($host, $user, $password) or die ("Connexion au serveur impossible :" . . mysql_error()); mysql_select_db($bdd) or die ("Erreur :" . mysql_error()); // récupération PROPRE des variables AVANT de les utiliser $nom = !empty($_POST['nom']) ? $_POST['nom'] : NULL; if(!$nom){ $error = "Vous devez rensigner un mot pour la recherche"; } else { // On selectionne les enregistrements contenant le mot clé $query = "SELECT distinct nom ,titre FROM membre WHERE nom LIKE '%$nom%' ORDER BY titre ASC"; $result = mysql_query($query) or die('Requête invalide : ' . mysql_error()); $Nombre = mysql_num_rows($result); //Retourne le nombre de lignes d'un résultat MySQL // Si aucun enregistrement n'est retourné, // on affiche un message adéquat if ($Nombre == "0") { $error = "<h2>Aucun résultat ne correspond à votre recherche</h2>"; } ?> <html> <head> <title>Résultat de la recherche</title> <meta charset="utf-8"> </head> <body> <?php if(!empty($error)){ echo "<p><span class='error'>".$error."</span></p>"; }else{ $txtNbResult = ($Nombre==1) ? "Un article trouvé" : "$Nombre articles trouvés " ; echo "<p><a name=\"#resultat\"><h2>Résultat: " . $txtNbResult ."</h2></a></p>"; while($row = mysql_fetch_row($result)) { echo "<div id='resultat'><p> <b>".$row['titre']."</b>\n <br><a href=\"../".htmlspecialchars($row['nom'])".\">".htmlspecialchars($row['titre'])."</a> </p> </div>"; } } // on ferme la base mysql_close(); ?> </body> </html>
jordane45
Messages postés
38288
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
15 novembre 2024
4 703
>
Tutti
6 déc. 2019 à 16:40
6 déc. 2019 à 16:40
et tu as quoi à la ligne 43 ?
jordane45
Messages postés
38288
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
15 novembre 2024
4 703
>
Tutti
6 déc. 2019 à 18:55
6 déc. 2019 à 18:55
Tu ne veux toujours pas appliquer les consignes pour poster ton code ??
Il faut utiliser les BALISES DE CODE !!!
Grrrrr !!!!
Mais non.. je ne pense pas que ça soit cette ligne qui pose problème
Sûrement celle d'avant...
Au pire, tu peux déjà la remplacer par :
Il faut utiliser les BALISES DE CODE !!!
Grrrrr !!!!
Mais non.. je ne pense pas que ça soit cette ligne qui pose problème
Sûrement celle d'avant...
Au pire, tu peux déjà la remplacer par :
echo '<p><a name="#resultat"><h2>Résultat: ' . $txtNbResult . '</h2></a></p>';
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
J'ai essayé comme tu m'as dis mais ça marchais pas (c'est pour cela que j'avais laissé comme cela). ( j'ai regardé au niveau de l'encodage et tout est bien en utf 8 sans bom.
<?php $host = "Mon serveur"; $user = "utilisateur"; $password = "mot de passe"; $bdd = "ma base de donnée"; mysql_connect($host, $user, $password) or die ("Connexion au serveur impossible :" . . mysql_error()); mysql_select_db($bdd) or die ("Erreur :" . mysql_error()); // récupération PROPRE des variables AVANT de les utiliser $nom = !empty($_POST['nom']) ? $_POST['nom'] : NULL; if(!$nom){ $error = "Vous devez rensigner un mot pour la recherche"; } else { // On selectionne les enregistrements contenant le mot clé $query = "SELECT distinct nom ? titre FROM membre WHERE nom LIKE '%$nom%' ORDER BY titre ASC"; $result = mysql_query($query) or die('Requête invalide : ' . mysql_error()); $Nombre = mysql_num_rows($result); //Retourne le nombre de lignes d'un résultat MySQL // Si aucun enregistrement n'est retourné, // on affiche un message adéquat if ($Nombre == "0") { $error = "<h2>Aucun résultat ne correspond à votre recherche</h2>"; } ?> <html> <head> <title>Résultat de la recherche</title> <meta charset="utf-8"> </head> <body> <?php if(!empty($error)){ echo "<p><span class='error'>".$error."</span></p>"; }else{ $txtNbResult = ($Nombre==1) ? "Un article trouvé" : "$Nombre articles trouvés " ; echo '<p><a name="#resultat"><h2>Résultat: ' . $txtNbResult . '</h2></a></p>'; while($row = mysql_fetch_row($result)) { echo "<div id='resultat'><p> <b>".$row['titre']."</b>\n <br><a href=\"../".htmlspecialchars($row['nom'])".\">".htmlspecialchars($row['titre'])."</a> </p> </div>"; } } // on ferme la base mysql_close(); ?> </body> </html>
jordane45
Messages postés
38288
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
15 novembre 2024
4 703
9 déc. 2019 à 14:54
9 déc. 2019 à 14:54
Y'a une erreur sur cette ligne :
A corriger par :
<br><a href=\"../".htmlspecialchars($row['nom'])".\">".htmlspecialchars($row['titre'])."</a>
A corriger par :
<br><a href='../".htmlspecialchars($row['nom']) ."'>".htmlspecialchars($row['titre'])."</a>
Tutti
>
jordane45
Messages postés
38288
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
15 novembre 2024
9 déc. 2019 à 23:20
9 déc. 2019 à 23:20
merci ça marche mais j'ai un petit problème quand je fais ma recherche ( il m'affiche juste le nombre d'articles trouvés, j'aurais voulu faire une petite mise en page pour les résultats et qui me les affiche aussi ( genre le nom) )
jordane45
Messages postés
38288
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
15 novembre 2024
4 703
>
Tutti
9 déc. 2019 à 23:28
9 déc. 2019 à 23:28
Je viens de voir une erreur dans ton code
Tu as un point d'interrogation à la place d'une virgule
A remplacer par :
C'est étonnant qu'il ne t'ait pas affiché une erreur....
Car ben.. c'est bien grace à cette requête que tu affiches la liste des résultats trouvés...
via cette boucle
Tu as un point d'interrogation à la place d'une virgule
$query = "SELECT distinct nom ? titre FROM membre WHERE nom LIKE '%$nom%' ORDER BY titre ASC";
A remplacer par :
$query = "SELECT distinct nom , titre FROM membre WHERE nom LIKE '%$nom%' ORDER BY titre ASC";
C'est étonnant qu'il ne t'ait pas affiché une erreur....
Car ben.. c'est bien grace à cette requête que tu affiches la liste des résultats trouvés...
via cette boucle
while($row = mysql_fetch_row($result)) { echo "<div id='resultat'><p> <b>".$row['titre']."</b>\n <br><a href=\"../".htmlspecialchars($row['nom'])".\">".htmlspecialchars($row['titre'])."</a> </p> </div>"; }
tutti
>
jordane45
Messages postés
38288
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
15 novembre 2024
10 déc. 2019 à 09:33
10 déc. 2019 à 09:33
J'ai remplacé par une virgule ( et j'ai changé titre par idmembre au 3 emplacements car je n'avais pas de colonne titre) et j'ai le problème suivant quand je tape dans ma requête un mot ( il me reprend ce que j'ai écris dans la barre de recherche ? )
jordane45
Messages postés
38288
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
15 novembre 2024
4 703
>
tutti
10 déc. 2019 à 09:56
10 déc. 2019 à 09:56
car je n'avais pas de colonne titre)
Je me suis appuyé sur ce que tu nous avais donné
il me reprend ce que j'ai écris dans la barre de recherche ?
Et ;... avec une explication plus claire et détaillée ça donne quoi ?