Sitemap en php

Résolu
info1121 Messages postés 19 Date d'inscription   Statut Membre Dernière intervention   -  
info1121 Messages postés 19 Date d'inscription   Statut Membre Dernière intervention   -
Bonjour, j'essai de faire un sitemap de mon site en allant chercher la Reference dans une base de données, il me semble que ce code devrait fonctionner. Est-ce que j'ai trop de références dans la bd ( environ 12000 )

$xml = '<?xml version="1.0" encoding="UTF-8"?>';
$xml .= '
<urlset xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.sitemaps.org/schemas/sitemap/0.9 http://www.sitemaps.org/schemas/sitemap/0.9/sitemap.xsd" xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">';

$sql = 'SELECT Reference FROM personnes';
$ref = lect_sql($sql);

$resultat = $ref->fetch(PDO::FETCH_ASSOC);
foreach($resultat AS $Num) {
$xml .= '
<url>
<loc>Fiche_Fam_Pers.php?Refer='.$Num->Reference.'</loc>
<changefreq>monthly</changefreq>
<priority>0.5</priority>
</url>';
}
$xml .= '</urlset>';
$file = fopen('sitemap.xml', 'r+');
fputs($file, $xml);
A voir également:

1 réponse

yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   Ambassadeur 1 584
 
1° peux-tu utiliser la coloration syntaxique quand tu partages du code?
2° pourquoi mentionnes-tu "devrait fonctionner" et "trop de références": message d'erreur, comportement inattendu? penses-tu avoir partagé toutes les information utiles?
0
info1121 Messages postés 19 Date d'inscription   Statut Membre Dernière intervention  
 
Vraiement désolé pour la coloration, le problème est que rien ne s'écrit dans le fichier sitemap.xml et je me demande ou est mon erreur
0
yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   1 584 > info1121 Messages postés 19 Date d'inscription   Statut Membre Dernière intervention  
 
as-tu fait print_r de $resultat juste après le fetch, et de $xml après le foreach?
as-tu vérifié combien de fois le foreach s’exécutait, par exemple en faisant un echo à chaque tour?
0
info1121 Messages postés 19 Date d'inscription   Statut Membre Dernière intervention  
 
Dans les 2 cas, rien ne se produit.
Est-ce que le code suivant est approprié, je ne suis pas trop familier avec
$resultat = $ref->fetch(PDO::FETCH_ASSOC);
Merci
0
yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   1 584 > info1121 Messages postés 19 Date d'inscription   Statut Membre Dernière intervention  
 
ce n'est probablement pas approprié. cependant, nous ignorons ce que retourne lect_sql. as-tu fait print_r de $ref?
0
info1121 Messages postés 19 Date d'inscription   Statut Membre Dernière intervention  
 
Bonjour, lect_sql est une fonction créée dans un autre fichier pour ouvrir et lire dans ma bd.
J'ai changé le foreach par un While et changé le fetch comme ceci et cela fonctionne parfaitement.
Merci

while ($row = $ref->fetch()){

$xml .= '
<url>
<loc>Fiche_Fam_Pers.php?Refer='.$row['Reference'].'</loc>
</url>';
}
0