le 06/01/2010 à 09:51
morgan.b
J'ai amélioré le script pour permettre de poster avec la news 5 photos. S'est une moyenne des mes news, elles ont toujours plus ou moin 5 photos. Le probleme est que dans mon amélioration je suis obligé de charger les 5 photos. Je n'arrive pas à laisser des champs vide. De plus si aucune photo est charger le site affiche quand meme, un carré avec la croix rouge pour signaler que l'affichage n'est pas bon. Je n'arrive pas a appliquer a ce que j'ai fais la valeur si pas de photo charger, ne rien afficher .
Merci
Le fichier insert_news.php
Le fichier news.php
Le fichier index.php
Merci
Le fichier insert_news.php
<?php
// on teste si le formulaire a été validé
if (isset($_POST['go']) && $_POST['go']=='Poster la news') {
// on se connecte à notre base
$base = mysql_connect ('localhost', 'root', '');
mysql_select_db('news', $base);
// on teste la déclaration de nos variables
if (!isset($_POST['auteur']) || !isset($_POST['titre']) || !isset($_POST['news']) || !isset($_POST['image']) || !isset($_POST['image2']) || !isset($_POST['image3']) || !isset($_POST['image4']) || !isset($_POST['image5'])) {
$erreur = 'Les variables nécessaires au script ne sont pas définies.';
}
else {
if (empty($_POST['auteur']) || empty($_POST['titre']) || empty($_POST['news']) || empty($_POST['image']) || empty($_POST['image2']) || empty($_POST['image3']) || empty($_POST['image4']) || empty($_POST['image5'])) {
$erreur = '<u>Attention :</u> au moins un des champs est vide.';
}
// si tout est bon, on peut commencer l'insertion dans la base
else {
// lancement de la requête d'insertion
$sql = 'INSERT INTO news VALUES("", "'.mysql_escape_string($_POST['auteur']).'", "'.mysql_escape_string($_POST['titre']).'", "'.date("Y-m-d H:i:s").'", "'.mysql_escape_string($_POST['news']).'", "'.mysql_escape_string($_POST['image']).'", "'.mysql_escape_string($_POST['image2']).'", "'.mysql_escape_string($_POST['image3']).'", "'.mysql_escape_string($_POST['image4']).'", "'.mysql_escape_string($_POST['image5']).'")';
// on lance la requête (mysql_query) et on impose un message d'erreur si la requête ne se passe pas bien (or die)
mysql_query($sql) or die('Erreur SQL !'.$sql.'<br />'.mysql_error());
// on ferme la connexion à la base de données
mysql_close();
// on redirige vers la page d'accueil du site (attention, cette redirection ne fonctionne qui si vous avez placé cette page dans un répertoire à partir de la racine du site). Si ce n'est pas le cas, veuillez entrer ici le bon chemin d'accès afin de retomber sur la page d'accueil du site.
header('Location:index.php');
// on termine le script courant
exit();
}
}
}
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<HTML>
<HEAD>
<meta http-equiv="content-type" content="text/html; charset=iso-8859-1">
<TITLE>Titre de page</TITLE>
</HEAD>
<BODY>
<H2>Poster une news :</H2>
<!-- on fait pointer le formulaire vers la page traitant les données -->
<?php
// on affiche les erreurs éventuelles
if (isset($erreur)) echo '',$erreur,'<br /><br />';
?>
<form action="insert_news.php" method="post">
<table>
<tr><td>
<span class="gras">Auteur :</span>
</td><td>
<input type="text" name="auteur" maxlength="15" size="25" value="<?php if (isset($_POST['auteur'])) echo htmlentities(trim($_POST['auteur'])); ?>">
</td></tr><tr><td>
<span class="gras">Titre :</span>
</td><td>
<input type="text" name="titre" maxlength="45" size="45" value="<?php if (isset($_POST['titre'])) echo htmlentities(trim($_POST['titre'])); ?>">
</td></tr><tr><td>
<span class="gras">News :</span>
</td><td>
<textarea name="news" cols="55" rows="15"><?php if (isset($_POST['news'])) echo htmlentities(trim($_POST['news'])); ?></textarea>
</td></tr><tr><td>
<span class="gras"><u>Info :</u></span>
</td><td>
</td></tr><tr><td>
<span class="gras">Image n°1 :</span>
</td><td>
<input type="text" name="image" maxlength="50" size="50" value="<?php if (isset($_POST['image'])) echo htmlentities(trim($_POST['image'])); ?>">
</td></tr><tr><td>
<span class="gras">Image n°2 :</span>
</td><td>
<input type="text" name="image2" maxlength="50" size="50" value="<?php if (isset($_POST['image2'])) echo htmlentities(trim($_POST['image2'])); ?>">
</td></tr><tr><td>
<span class="gras">Image n°3 :</span>
</td><td>
<input type="text" name="image3" maxlength="50" size="50" value="<?php if (isset($_POST['image3'])) echo htmlentities(trim($_POST['image3'])); ?>">
</td></tr><tr><td>
<span class="gras">Image n°4 :</span>
</td><td>
<input type="text" name="image4" maxlength="50" size="50" value="<?php if (isset($_POST['image4'])) echo htmlentities(trim($_POST['image4'])); ?>">
</td></tr><tr><td>
<span class="gras">Image n°5 :</span>
</td><td>
<input type="text" name="image5" maxlength="50" size="50" value="<?php if (isset($_POST['image5'])) echo htmlentities(trim($_POST['image5'])); ?>">
</td></tr><tr><td>
<span class="gras"><u>Info :</u></span>
</td><td>
</td></tr><tr><td><td align="left">
<input type="submit" name="go" value="Poster la news">
</td></tr></table>
</form>
</body>
</html>
Le fichier news.php
<?php
// on se connecte à notre base
$base = mysql_connect ('localhost', 'root', '');
mysql_select_db('news', $base);
// lancement de la requête. on sélectionne les news que l'on va ordonner suivant l'ordre "inverse" des dates (de la plus récente à la plus vieille : DESC) tout en ne sélectionnant que le nombre voulu de news à afficher (LIMIT)
$sql = 'SELECT auteur, titre, date, texte_news, image, image2, image3, image4, image5 FROM news ORDER BY date DESC;';
// on lance la requête (mysql_query) et on impose un message d'erreur si la requête ne se passe pas bien (or die)
$req = mysql_query($sql) or die('Erreur SQL !<br />'.$sql.'<br />'.mysql_error());
// on compte le nombre de news stockées dans la base de données
$nb_news = mysql_num_rows($req);
if ($nb_news == 0) {
echo 'Aucune news enregistrée.';
}
else {
// si on a au moins une news, on l'affiche
while ($data = mysql_fetch_array($req)) {
// on décompose la date
sscanf($data['date'], "%4s-%2s-%2s %2s:%2s:%2s", $an, $mois, $jour, $heure, $min, $sec);
// on affiche les résultats
echo '<br /><H2>' , htmlentities(trim($data['titre'])) , '</H2>';
echo '<H3>Posté par : ' , htmlentities(trim($data['auteur']));
echo ' le ' , $jour , '/' , $mois , '/' , $an , '</H3>';
echo ' ' , nl2br(htmlentities(trim($data['texte_news']))) , '<br />';
echo '<br /><a href="' , htmlentities(trim($data['image'])) , '.jpg" target="_blank"><img src="' , htmlentities(trim($data['image'])) , '.png" border=0></a> ';
echo '<a href="' , htmlentities(trim($data['image2'])) , '.jpg" target="_blank"><img src="' , htmlentities(trim($data['image2'])) , '.png" border=0></a><br />';
echo '<br /><a href="' , htmlentities(trim($data['image3'])) , '.jpg" target="_blank"><img src="' , htmlentities(trim($data['image3'])) , '.png" border=0></a> ';
echo '<a href="' , htmlentities(trim($data['image4'])) , '.jpg" target="_blank"><img src="' , htmlentities(trim($data['image4'])) , '.png" border=0></a><br />';
echo '<br /><a href="' , htmlentities(trim($data['image5'])) , '.jpg" target="_blank"><img src="' , htmlentities(trim($data['image5'])) , '.png" border=0></a><br />';
}
}
// on libère l'espace mémoire alloué à cette requête
mysql_free_result ($req);
// on ferme la connexion à la base de données
mysql_close ();
?>
Le fichier index.php
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<HTML>
<HEAD>
<meta http-equiv="content-type" content="text/html; charset=iso-8859-1">
<TITLE>Titre de page</TITLE>
</HEAD>
<!-- code HTML avant l'affiche des news (tout dépend comment est constitué votre site) -->
<?php
// on inclut l'affichage de nos news
include ('news.php');
?>
<!-- code HTML après l'affiche des news (tout dépend comment est constitué votre site) -->
</body>
</html>