[php/sql] Problème pour insérer des données

aimincorps Messages postés 5 Date d'inscription   Statut Membre Dernière intervention   -  
mouf13 Messages postés 142 Date d'inscription   Statut Membre Dernière intervention   -
Bonjour, j'ai un problème avec ma base de données mysql, je vous explique.
Ce petit script est censé insérer des données dans ma bdd, mais quand j'envoie le formulaire, rien ne se passe, j'ai pourtant revérifié pas mal de fois la config de connexion ainsi que mes variables d'envoie de formulaire mais sans plus...

$avertirs = array('0', '1');
$accs = array('0', '1', '2', '3');
if($_POST['forum']) {
if($_POST['avertir'] AND in_array($_POST['avertir'], $avertirs)) {
if($_POST['acces'] AND in_array($_POST['acces'], $accs)) {
mysql_connect($host,$user,$pass);
mysql_select_db($bdd);
$forum = addslashes($_POST['forum']);
$moderateur = addslashes($_POST['moderateur']);
$avertir = $_POST['avertir'];
$acces = $_POST['acces'];
$description = preg_replace('/\n(\r)?/', '<br />', htmlspecialchars(addslashes($_POST['description'])));
$requete = "INSERT INTO forums VALUES('','$forum','$description','$acces','$moderateur','$avertir')";
mysql_query($requete);
mysql_close();
}
}
}

Et voici le html :

<form method="post">
<table>
<caption><b>Ajouter un forum</b></caption>
<tr>
<td>Nom du forum :</td>
<td><input type="text" name="forum" /></td>
</tr>
<tr>
<td>Accès au forum :</td>
<td><select name="acces">
<option value="0">Vérouillé</option>
<option value="1" selected="selected">Membres</option>
<option value="2">Modérateurs</option>
<option value="3">Admins</option>
</select></td>
</tr>
<tr>
<td>Modérateur :</td>
<td><select name="moderateur">
<option value="Aimincorp">Aimincorp</option>
</select></td>
</tr>
<tr>
<td>Fonction avertir :</td>
<td>ON <input type="radio" name="avertir" value="1" checked="checked" />
OFF <input type="radio" name="avertir" value="0" /></td>
</tr>
<tr>
<td>Description du forum :</td>
<td><textarea name="description" cols="40" rows="10"></textarea></td>
</tr>
<tr>
<td></td>
<td><input type="submit" value="Valider" /></td>
</tr>
</table>

Voila comme vous pouvez le constater ce code semble n'avoir aucun inconvéniant... Cependant il ne fonctionne pas. xD
Voila merci d'une réponse nette et précise svp, cordialement.
A voir également:

10 réponses

Mimiste Messages postés 1149 Date d'inscription   Statut Membre Dernière intervention   206
 
Bonjour

est tu certain que le script passe tes 3 IF ?

if($_POST['forum']) {
if($_POST['avertir'] AND in_array($_POST['avertir'], $avertirs)) {
if($_POST['acces'] AND in_array($_POST['acces'], $accs)) {

tu devrai faire un petit "echo" de test juste apres pour verifier
-1
Utilisateur anonyme
 
je suis pas specialement douée en php mais on devrai pas mettre un isset kke part pour voir si la variable existe?
-1
aimincorps Messages postés 5 Date d'inscription   Statut Membre Dernière intervention  
 
Mimiste, oui je suis absolument certain d'avoir complèter tous les champs et donc les if ne devraient pas posés de problème. :-(

sakura250006, cela revient au même, même sans le isset si tu met un if de toute manière cela vérifira si la variable existe quoi qu'il arrive. ^^
-1
Utilisateur anonyme
 
ah bah je m'endormirai moins bete ce soir alors ;-)
merci
-1

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
aimincorps Messages postés 5 Date d'inscription   Statut Membre Dernière intervention  
 
lol ok deriens, à ton service ^-^
-1
aimincorps Messages postés 5 Date d'inscription   Statut Membre Dernière intervention  
 
up svp aidez moi :-(
-1
aimincorps Messages postés 5 Date d'inscription   Statut Membre Dernière intervention  
 
up aidez moi svp svp
-1
dreamfeeder Messages postés 253 Date d'inscription   Statut Membre Dernière intervention   54
 
bonjour,

je me suis crée une petite table forums et ton code marche chez moi en tout cas.

bizarre.
-1
Mimiste Messages postés 1149 Date d'inscription   Statut Membre Dernière intervention   206
 
Bah a 2h du mat y a un peu moins de monde pour voir le forum ^^

Bon pour savoir ou il ce plante c'est simple il faut rajouter "or die(mysql_error());" apres chaques actions mysql

mysql_connect($host,$user,$pass) or die(mysql_error());
mysql_select_db($bdd) or die(mysql_error());

et ensuite (et c'est la que sa plante je pense)

mysql_query($requete) or die(mysql_error());

du coup il forcera l'arret du script avec un message d'erreur a l'endroit ou il plante
-1
mouf13 Messages postés 142 Date d'inscription   Statut Membre Dernière intervention   17
 
1. Je ne voit pas de balise action dans ton formulaire...
ex : <form method="post" action="<?php echo $_SERVER['PHP_SELF']; ?>">

2. Verifier les variables proprement :
Si la variable existe et qu'elle n'est pas vide
if(isset($_POST['forum']) && !empty($_POST['forum'])) {
blabla
}

3. mort au double quotes dans des chaines contenant des variables
echo "salut john"; OK
echo 'salut '.$nom; OK
le reste ça pue

4. insert propre
$requete = 'INSERT INTO forums (titre, descriptionn, acces) '.
'VALUES(\''.$forum.'\',\''.$description.'\',\''.$acces.'\')';
-1