PHP MySQL - Enregistrer valeur checkbox

Résolu
Sinistrus Messages postés 1010 Date d'inscription   Statut Membre Dernière intervention   -  
Sinistrus Messages postés 1010 Date d'inscription   Statut Membre Dernière intervention   -
Bonjour à tous !

Je souhaite enregistrer la valeur de mon checkbox dans ma table mysql. Pouvez-vous m'aider svp ?
<label><input type="checkbox" name="Fr_Pays_CI" id="Fr_Pays_CI" <?php if($data_fr['CI']==1) echo 'checked="checked" '; ?> />Côte d'Ivoire</label>
<label><input type="checkbox" name="Fr_Pays_SN" id="Fr_Pays_SN" <?php if($data_fr['SN']==1) echo 'checked="checked" '; ?> />Sénégal</label>

$Fr_Pays_CI = $_POST["Fr_Pays_CI"]; $Fr_Pays_CI = mysql_real_escape_string($Fr_Pays_CI);
$Fr_Pays_SN = $_POST["Fr_Pays_SN"]; $Fr_Pays_SN = mysql_real_escape_string($Fr_Pays_SN);


A voir également:

2 réponses

ElementW Messages postés 4814 Date d'inscription   Statut Contributeur Dernière intervention   1 223
 
'lut, première étape: tu arrêtes d'utiliser l'extension MySQL, lis cet article pour savoir pourquoi; et le remplaces par MySQLi ou PDO.
(J'insiste, il faut que tu changes)
Deuxième étape: c'est un peu de PHP et de SQL.
L'élément de
$_POST
correspondant à ta checkbox sera existant si la case est cochée, et non défini si elle ne l'est pas (donc
isset($_POST['element'])
renverra
true
si la case est cochée).
En utilisant l'opérateur ternaire, on fait court et récupère les valeurs:
$Fr_Pays_CI = isset($_POST["Fr_Pays_CI"]) ? "1" : "0";
$Fr_Pays_SN = isset($_POST["Fr_Pays_SN"]) ? "1" : "0";
Et comme tu utiliseras les requêtes préparées, pas d'atrocités genre
mysql_real_escape_string
(exemple PDO):
$req = $bdd->prepare("INSERT INTO maTable (paysCi, paysSn) VALUES (:paysCi, :paysSn)");
$req->execute(array(
    ":paysCi" => $Fr_Pays_CI,
    ":paysSn" => $Fr_Pays_SN
));

from human import idiocy
del idiocy
0
Sinistrus Messages postés 1010 Date d'inscription   Statut Membre Dernière intervention   17
 
Merci gravgun, c'est la seconde fois que tu me dis de changer en MySQLi ou PDO
Je suis en train de le faire (promis) mais c'était pour avancer un peux sur cette correction (version 2).

La version 3 (actuelle) est en cours de maintenance !
En tout cas merci infiniment de m'avoir prévenu, je l'ignorais depuis ton précédent poste.
0