Insertion dans une base de données MySQL

veronav Messages postés 3 Date d'inscription   Statut Membre Dernière intervention   -  
veronav Messages postés 3 Date d'inscription   Statut Membre Dernière intervention   -
Bonjour,
je suis débutante et je suis entrain de développer une apllication je veux connecter le formulaire avec la base de données mais j'y arrive pas.voici le formulaire:
<p align="justify">                    
  <form name="form1" method="post" action="recup.php">
    <table width="657" height="511" align="center" cellspacing="9" bgcolor="#0066FF">
      <tr>
        <td width="125" height="50">
          <span class="Style1">Nom </span>
        </td>
        <td width="443">
          <label for="nom"></label>
          <input type="text" name="name" id="name" placeholder="Entrez votre nom">
        </td>
      </tr>
      <tr>
        <td width="125" height="50">
          <span class="Style1"> Photo de profil: </span>
        </td>
        <td width="443">
            <label for="photo"> </label>
           <input type="file" name="photo">  
        </td>
      </tr>
      <tr>
        <td width="125" height="50"><span class="Style1">Prénoms</span></td>
        <td><input type="text" name="prénoms" id="prénoms" placeholder="Entrez votre prénoms"></td>
      </tr>
      <tr>
        <td width="125" height="50"><span class="Style1">Telephone</span></td>
        <td><input type="text" name="phone" id="phone"></td>
      </tr>
    </table>
  </form>
</p>


EDIT : Ajout des balises de code
A voir également:

3 réponses

yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   Ambassadeur 1 584
 
bonsoir, quel langage de programmation utilises-tu?
0
Veronav
 
se j'utilise le PHP comme langage de programmation
0
yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   1 584 > Veronav
 
peux-tu partager ton code php?
0
veronav Messages postés 3 Date d'inscription   Statut Membre Dernière intervention  
 
<?php
session_start(); # Ouverture des sessions

define('HOST', 'localhost');
define('USER','root');
define('PASSWORD','');
define('BDD','ptijob');

try
{
$bdd = new PDO('mysql:host='.HOST.';dbname='.BDD, USER, PASSWORD);
}
catch(Exception $err)
{
die('erreur ['.$err->getCode().'] '.$e->getMessage());
}
//var_dump($_POST);

if(isset($_post ['submit'])){ // si le bouton valider a été déclencher
if (isset($_post['name'],$_post ['prénoms'],$_post ['phone'],$_post ['photo'] )){

if ($_post['name']!="" && $_post ['prénoms'] !="" && $_post ['phone'] !="" && $_post ['photo'] !=" " ){


$name=$_POST['name'];
$prénoms=$_POST['prénoms'];
$phone=$_POST['phone'];
$nomphoto=$_FILES['photo'] ['name'];
$file_tmp_name=$FILES ['photo'] ['tmp_name'];
move_uploaded_file($file_tmp_name,"./photos/$nomphoto");
// enregistrement dans la base de donnée
$insertion="INSERT INTO ouvrier( nom,prenom,photo,tel,extension) VALUES ('$name','$prénoms', '$nomphoto','$phone','$extension' )";
$execute=$bdd->query($insertion);
if($execute==true){
$msgsuccess="Inscription réalisée avec sccuèes!";
}
else
{
$msgerror="l'inscription n'a pas pu être éffectuée.Verifiez que vous avez remplie tous les champs.";
}
}
}
}

?>
<html>
<meta charset="utf-8">
<body>
<table width="100%" border="1">

<tr>
<td>NOM:</td>
<td><?php echo($name)?></td>
</tr>
<tr>
<td>Prénoms:</td>
<td><?php echo( $prénoms)?></td>
</tr>
<tr>
<td>Télephone:</td>
<td><?php echo($phone)?></td>

<tr>
<td>Photo:</td>
<td><?php echo($nomphoto)?></td>
</tr>
</table>


</body>
</html>
0
yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   1 584 > veronav Messages postés 3 Date d'inscription   Statut Membre Dernière intervention  
 
"j'y arrive pas": message d'erreur, comportement inattendu (lequel)?
0
Veronav
 
Message d' erreur : variables indéfinies
0
Utilisateur anonyme
 
Bonjour

En plus de la question de yg_be :
Attention, je vois des $_post en minuscules dans ton code, alors que c'est $_POST en majuscules. PHP distingue les deux.
Et si tu veux envoyer un fichier par formulaire, il faut préciser dans la balise form l'encodage
enctype="multipart/form-data"
.
Voir https://www.php.net/manual/fr/features.file-upload.post-method.php

De plus, tu testes si un certain bouton 'submit' a été déclenché, mais je n'en vois pas dans ton formulaire.

Tu utilises aussi les champs de ton formulaire directement dans ta requête, c'est la porte ouverte aux attaques. Puisque tu utilises PDO, sers-toi des requêtes préparées.
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
Bonjour,
J'ajouterai que tu as un souci au niveau de ta requête...
et comme le dit justement Lepère... utilise les requêtes préparées.
Voici comment correctement effectuer la connexion à ta bdd ET faire une requête préparée
https://forums.commentcamarche.net/forum/affich-37584941-php-pdo-gerer-les-erreurs

Je t'invite également à lire ceci :
https://forums.commentcamarche.net/forum/affich-37584947-php-gestion-des-erreurs-debogage-et-ecriture-du-code

Ainsi que ça (afin de poster correctement ton code la prochaine fois )
https://codes-sources.commentcamarche.net/faq/10686-le-nouveau-codes-sources-comment-ca-marche#balises-code

0
veronav Messages postés 3 Date d'inscription   Statut Membre Dernière intervention  
 
jai revu ma requete sans le fichier,je peux effectuer des enregistrements maintenant,mais jai un souci au niveau du fichier, comment l'inserer dans mon code et ou le placer? le prestataire devra mettre une photo de profil lors de linscription sur le site. voici ma table ouvrier:
# Nom Type Interclassement Attributs Null Défaut Extra Action
1 idouv int(11) Non Aucune AUTO_INCREMENT Modifier Modifier
2 nom varchar(25) utf8_general_ci Non Aucune Modifier Modifier
3 prenom varchar(40) utf8_general_ci Non Aucune Modifier Modifier
4 datnais date Non Aucune Modifier Modifier Supprimer Supprimer

5 exprof varchar(10) utf8_general_ci Non Aucune Modifier Modifier
6 photo blob Non Aucune Modifier Modifier Supprimer Supprimer

7 tel int(11) Non Aucune Modifier Modifier Supprimer Supprimer


9 act varchar(25) utf8_general_ci Non Aucune Modifier Modifier Supprimer
10 sexe varchar(255) utf8_general_ci Non Aucune Modifier Modifier
11 ville varchar(255) utf8_general_ci Non Aucune Modifier Modifier Supprimer
12 qualiteprof varchar(255) utf8_general_ci Non Aucune Modifier Modifier
13 extension varchar(255) utf8_general_ci Non Aucune
voici mon code revu:
<?php
$bdd = new PDO('mysql:host=localhost;dbname=ptijob','root','');

var_dump($_POST);
if(isset($_POST ['name']) AND isset($_POST['prenoms'])AND isset($_POST['datenaissance'])AND isset($_POST['subject']) AND isset($_POST['phone']) AND isset($_POST['lieuhabitation'])AND isset($_POST['activite'])AND isset($_POST['sexe']) AND isset($_POST['ville']) AND isset($_POST['message']))
{
$req=$bdd->prepare('INSERT INTO ouvrier(nom,prenom,datnais,exprof,tel,lieuhab,act,sexe,ville,qualiteprof) VALUES(:name,:prenoms,:datenaissance,:subject,:phone,:lieuhabitation,:activite,:sexe,:ville,:message)');
$req->execute(array(
':name' => $_POST['name'],
':prenoms' => $_POST['prenoms'],
':datenaissance' => $_POST['datenaissance'],
':subject' => $_POST['subject'],
':phone' => $_POST['phone'],
':lieuhabitation' => $_POST['lieuhabitation'],
':activite' => $_POST['activite'],
':sexe' => $_POST['sexe'],
':ville' =>$_POST['ville'],
':message' => $_POST['message'],
));

$bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
echo "succes";
}
else echo(" veuillez saisir tout les champs!");

?>

merci.
0