IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

Conserver donnée saisie en POST [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de fazpedro
    Homme Profil pro
    Inscrit en
    Août 2009
    Messages
    506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2009
    Messages : 506
    Par défaut Conserver donnée saisie en POST
    Bonjour,

    j'ai voulu faire une vérification sur une zone de texte "textarea" (POST['comments) de façon à dire qu'il y a plus de 500 caractères...çela fonctionne bien, seulement voilà, la zone "textarea" se vide.. alors qu'avant elle affichait bien la sasie qui était effectuée..(si on oubliait une zone saisie par exemple...) je ne vois pas où se situe mon erreur ?
    merci.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    261
    262
    263
    264
    265
    266
    267
    268
    269
    270
    271
    272
    273
    274
    275
    276
    277
    278
    279
    280
    281
    282
    283
    284
    285
    286
    287
    288
    289
    290
    291
    292
    293
    294
    295
    296
    297
    298
    299
    300
    301
    302
    303
    304
    305
    306
    307
    308
    309
    310
    311
    312
    313
    314
    315
    316
    317
    318
    319
    320
    321
    322
    323
    324
    325
    326
    327
    328
    329
    330
    331
    332
    333
    334
    335
    336
    337
    338
    339
    340
    341
    342
    343
    344
    345
    346
    347
    348
    349
    350
    351
    352
    353
    354
    355
    356
    357
    358
    359
    360
    361
    362
    363
    364
    365
    366
    367
    368
    369
    370
    371
    372
    373
    374
    375
    376
    377
    378
    379
    380
    381
    382
    383
    384
    385
    386
    387
    388
    389
    390
    391
    392
    393
    394
    395
    396
    397
    398
    399
    400
    401
    402
    403
    404
    405
    406
    407
    408
    409
    410
    411
    412
    413
    414
    415
    416
    417
    418
    419
    420
    421
    422
    423
    424
    425
    426
    427
    428
    429
    430
    431
    432
    433
    434
    435
    436
    437
    438
    439
    440
    441
    442
    443
    444
    445
    446
    447
    448
    449
    450
    451
    452
    453
    454
    455
    456
    457
    458
    459
    460
    461
    462
    463
    464
    465
    466
    467
    468
    469
    470
    471
    472
    473
    474
    <?php session_start();
    $nompage = "annoncer2.php";
    require ('./_protection_page.php'); 
    require ("configuration.php"); //accès à la base de données
    $sql = connect_sql();
    $sql2 = detection_mobile();
    $sql3 = bandeau_detection();
    $pseudo_membre = $_SESSION['pseudo'];
    $requete = mysql_query("SELECT * FROM pdf_membre WHERE `pseudo`='$pseudo_membre'"); 
    $result = mysql_fetch_array ($requete);
    $id = $result['id'];
    $pseudo = $result['pseudo'];
    $mail = $result['mail'];
    $mail_destinataire = $email_admin;
    ?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" lang="fr">
    <head>
    <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />	
    <title><?php echo $nom_site ?></title>
    <link rel="stylesheet" type="text/css" href="<?php echo $nom_style ?>" />
    <script type="text/javascript" src="jquery-1.2.1.pack.js"></script>
     
     <!-- début de tarif caché si gratuit -->
    <script type="text/javascript">
    function showT()
    {	var elem = document.getElementById("idSelect");
    	var elem2 = document.getElementById("idInput");
    	var elem3 = document.getElementById("idlabel");
    	if(elem.value.match("Gratuit"))
    {	elem2.style.display='none';
    	elem3.style.display='none';
    	}	else	{
    	elem2.style.display='inline';tabindex=8;
    	elem3.style.display='inline'}
    	}
    <!-- fin de tarif caché si gratuit -->
     
    <!-- affichage du lieu -->
    	function lookup(inputString) {
    		if(inputString.length == 0) { // si le champs txte est vide
    			$('#suggestions').hide(); // on cache les suggestions
    		} else { // sinon
    			$.post("ajax_lieu.php", {queryString: ""+inputString+""}, function(data){ 
    			// on envoie la valeur du champ texte dans la variable post queryString au fichier ajax_lieu.php
    				if(data.length >0) {
    					$('#suggestions').show(); // si il y a un retour, on affiche la liste
    					$('#autoSuggestionsList').html(data); // et on remplit la liste des données
    				}
    			});
    		}
    	}
    	function fill(thisValue) { // remplir le champ texte si une suggestion est cliquée
    		$('#inputString').val(thisValue);
    		setTimeout("$('#suggestions').hide();", 200);
    	}
    	$(document).ready( function () {
    		$("input#inputString").keyup( function() { // si on presse une touche du clavier en étant dans le champ texte qui a pour id inputString
    			lookup($(this).val()) 
    		});
    		$("input#inputString").blur( function() { // si le champ texte perd le focus
    			fill() 
    		});
    	});
    </script>
    <!-- FIN de  : affichage du lieu -->
     
    <!-- début de la vérification si tout est saisi -->
    <script type="text/javascript">
    function valide(txt, err_id)
    { document.getElementById(err_id).innerHTML= (txt.value=="") ? "Attention &agrave; bien remplir toutes les cases !" : "&nbsp;"; }
    </script>
    <!-- fin de la vérification si tout est saisi -->
     
    </head>
    <body>
    <?php include($bandeau); ?> <!-- insère le bandeau principal en haut en fonction de la connexion -->
    <div id="mainContent">
    <br />
    <p>Retrouvez &eacute;galement <br />
    <a href="annoncer_plusieurs.php">Annoncer sur plusieurs journ&eacute;es (exposition, festival...)</a>&nbsp;&nbsp;&nbsp;&nbsp;
    <a href="contact_ev.php">Annoncer plusieurs &eacute;v&eacute;nements (envoi de fichier...)</a>&nbsp;&nbsp;&nbsp;&nbsp;
    </p>
     
    <?php
    // -------------------------------
    // TRAITEMENT si formulaire envoye
    // -------------------------------
    $validform = 0;
    $msgerreur = '';
    $reponse = '';
    // nettoyage des zones avant saisie
    $montant_recupere = '';$lieu_recupere = '';$heure_debut_recupere = '';$nom_artiste_recupere = '';$site_web_recupere = '';$designation_recupere = '';
    if( isset($_POST['boutonEnvoiFormulaire']) ) 
    {
    	// ----------------------------------------------------------------------------------------
    	// 1- RECUPERATION DES DONNEES DU FORMULAIRE et Protection des donnees contre injection SQL
    	// ----------------------------------------------------------------------------------------
    	$IPClient = $_SERVER[REMOTE_ADDR];  // recup de l'ip du client
    	$type_evenement_recupere			= mysql_real_escape_string($_POST['evenement2']);
    	$type_lieu_recupere					= mysql_real_escape_string($_POST['lieu2']);
    	$secteur_recupere					= mysql_real_escape_string($_POST['secteur']);
    	$jour_recupere						= mysql_real_escape_string($_POST['jour']);
    	$mois_recupere						= mysql_real_escape_string($_POST['mois']);
    	$tarif_recupere						= mysql_real_escape_string($_POST['tarif']);
    	$montant_recupere					= mysql_real_escape_string($_POST['montant']);
    	$lieu_recupere						= mysql_real_escape_string($_POST['lieu3']);
    	$heure_debut_recupere				= mysql_real_escape_string($_POST['debut']);
    	$nom_artiste_recupere				= mysql_real_escape_string($_POST['nom4']);
    	$site_web_recupere					= mysql_real_escape_string($_POST['webinfos']);
    	$designation_recupere				= mysql_real_escape_string($_POST['comments']);
     
    	// si tarif gratuit mettre à zéro le montant
    	if($tarif_recupere == 'Gratuit') {$montant_pour_sql="0";} elseif($tarif_recupere == 'Payant') {$montant_pour_sql=tarif_recupere;}
    	// requete pour recuperer la connexion ip du client
    	$IPClient2 = $_SERVER[REMOTE_ADDR];
    	// DEBUT on récupère l'année et le mois du formulaire
    	$affich_form_mois_2 = "SELECT * FROM mois2 WHERE Nb='$mois_recupere'" ;
    	$resultat_mois_2 = mysql_query($affich_form_mois_2) or die ('Erreur : '.mysql_error() );
    	$list_mois_2 = mysql_fetch_array( $resultat_mois_2 );
    	$numero_mois_form_2 = $list_mois_2['num_mois'];
    	$mois_pour_affichage_apres_post = $list_mois_2['mois'];
    	$affich_form_annee_2 = "SELECT annee FROM mois2 WHERE Nb='$mois_recupere'" ;
    	$resultat_annee_2 = mysql_query($affich_form_annee_2) or die ('Erreur : '.mysql_error() );
    	$list_annee_2 = mysql_fetch_array( $resultat_annee_2 );
    	$numero_annee_form_2 = $list_annee_2['annee'];
    	// FIN on récupère l'année et le mois du formulaire de début
    	// création de la date de départ au format date MySQL
    	$date_ev=$numero_annee_form_2.'-'.$numero_mois_form_2.'-'.$jour_recupere;
     
    	// -----------------------------------------
    	// 2- GESTION des ERREURS
    	// -----------------------------------------
    	// On verifie les champs obligatoires
    	if ($type_evenement_recupere=='' || $type_lieu_recupere=='' || $secteur_recupere=='' || $jour_recupere=='' || $mois_recupere=='' 
    	|| $tarif_recupere=='' || $lieu_recupere=='' || $heure_debut_recupere=='' || $nom_artiste_recupere=='' || $designation_recupere=='') 
    	{
    		if ($type_evenement_recupere=='')	 	{	$msgerreur .= 'Champ obligatoire : '.'<b>'.' Type d\'&eacute;v&eacute;nement'.'</b>'.'<br />'; }
    		if ($type_lieu_recupere=='') 			{	$msgerreur .= 'Champ obligatoire : '.'<b>'.' Type de lieu'.'</b>'.'<br />'; }
    		if ($secteur_recupere=='') 				{	$msgerreur .= 'Champ obligatoire : '.'<b>'.' Secteur'.'</b>'.'<br />'; }
    		if ($jour_recupere=='') 				{	$msgerreur .= 'Champ obligatoire : '.'<b>'.' Jour'.'</b>'.'<br />'; }
    		if ($mois_recupere=='') 				{	$msgerreur .= 'Champ obligatoire : '.'<b>'.' Mois'.'</b>'.'<br />'; }
    		if ($tarif_recupere=='') 				{	$msgerreur .= 'Champ obligatoire : '.'<b>'.' Tarif'.'</b>'.'<br />'; }
    		if ($lieu_recupere=='') 				{	$msgerreur .= 'Champ obligatoire : '.'<b>'.' Lieu'.'</b>'.'<br />'; }
    		if ($heure_debut_recupere=='') 			{	$msgerreur .= 'Champ obligatoire : '.'<b>'.' Heure de d&eacute;but'.'</b>'.'<br />'; }
    		if ($nom_artiste_recupere=='') 			{	$msgerreur .= 'Champ obligatoire : '.'<b>'.' Artiste'.'</b>'.'<br />'; }
    		if ($designation_recupere=='') 			{	$msgerreur .= 'Champ obligatoire : '.'<b>'.' D&eacute;signation'.'</b>'.'<br />'; }
    		$validform 	= 2;
     
    		// pour affichage correct si erreur ou oubli de saisie !	
    		$lieu_affiche			= stripslashes($lieu_recupere);	
    		$nom_artiste_affiche	= stripslashes($nom_artiste_recupere);	
    		$designation_affiche	= stripslashes($designation_recupere);	
    	}
     
    	if (strlen($designation_recupere)>'500')	{	$msgerreur .= 'Champ D&eacute;signation : '.'<b>'.strlen($designation_recupere).'</b>'.
    													' caract&egrave;res, il faut'.'<b>'.' moins de 500 caract&egrave;res !'.'</b>'.'<br />'; 
    													$validform 	= 2;
    												}
     
    	// description : plus de 500 caractères !
     
     
    	// pas d'erreur ?
    	if($validform != 2) $validform = 1;
    	// -----------------------------------------
    	// 3- si pas d'erreur => TRAITEMENT
    	// -----------------------------------------
    	if($validform == 1) 
    	{
    		// pour affichage correct si erreur ou oubli de saisie !	
    		$lieu_affiche			= stripslashes($lieu_recupere);	
    		$nom_artiste_affiche	= stripslashes($nom_artiste_recupere);	
    		$designation_affiche	= stripslashes($designation_recupere);	
    		// on écrit la requête sql pour verifier s'il n'existe pas déjà !
     
    		$query = "SELECT * FROM evenement WHERE nom='$nom_artiste_recupere' and lieu='$lieu_recupere' and date_ev='$date_ev'";
    		$result = mysql_query($query);
    		$res = mysql_num_rows($result);
    		// Récuperation des resultats
    		if ($res==0)
    		{
    			mysql_query("SET NAMES utf8");
    			$sql2 = "INSERT INTO evenement(type_evenement, type_etab, secteur, heure, tarif, montant, lieu, nom, description, date_ev, pseudo_ev, site_infos) 
    			VALUES('$type_evenement_recupere','$type_lieu_recupere','$secteur_recupere','$heure_debut_recupere','$tarif_recupere',
    			'$montant_recupere','$lieu_recupere','$nom_artiste_recupere','$designation_recupere','$date_ev','$pseudo','$site_web_recupere')";
    			// on insère les informations du formulaire dans la table
    			mysql_query($sql2) or die('Erreur SQL !'.$sql2.'<br>'.mysql_error());
    			//On remet la date au format français
    			setlocale (LC_TIME, 'fr_FR.UTF8');
    			$date_vue = strftime("%A %d %B",strtotime("$date_ev"));
    			// on affiche le résultat pour le visiteur
    			setlocale (LC_TIME, 'fr_FR.UTF8');
    			echo '<p>'.'</p>'."\n";
     
    			// ----------------------------------
    			// ENVOI DU MAIL A L'ADMINISTRATEUR
    			// ----------------------------------
    			$entete = "MIME-Version: 1.0\r\n";
    			$entete .= "Content-type: text/html; charset=utf-8\r\n";
    			$entete .= "From: <".$mail.">\r\n";
    			$entete .= "Reply-To: ".$mail."\r\n";
    			$message1 =  '<html><body>Bonjour <b>'.$pseudo.'</b>'.' a ins&eacute;r&eacute; un &eacute;v&eacute;nement';
    			$message1 .= '<br />';
    			$message1 .= 'Nom du groupe ou artiste : '.'<b>'.stripslashes($nom_artiste_recupere).'</b>';
    			$message1 .= '<br>'.'</br>';
    			$message1 .= 'Date : '.'<b>'.$date_vue.'</b>';
    			$message1 .= '<br>'.'</br>';
    			$message1 .= 'Description : '.'<b>'.stripslashes($designation_recupere).'</b>';
    			$message1 .= '<br>'.'</br>';
    			$message1 .= 'Site web : '.'<b>'.stripslashes($webinfos).'</b>';
    			$message1 .= '<br>'.'</br>';
    			$message1 .= 'IP de connexion : '.$IPClient;
    			$message1 .= '</body>'.'</html>';
    			mail($mail_destinataire,'Envoi de message :' .$nom_site. ' ' . $login . ' ', $message1, $entete);
     
    		///// REPONSE POSITIVE A L'ECRAN ///////
    		$reponse = '<br></br>';
    		$reponse .= 'Merci '.'<strong>'.$pseudo.' !'.'</strong>';
    		$reponse .= '<br />';
    		$reponse .= 'l\'&eacute;v&eacute;nement a bien &eacute;t&eacute; enregistr&eacute; !';
    		$reponse .= '<br />';
    		$reponse .= '<br />';
    		$reponse .= '<a href="' .$url_site. '">Retour &agrave; l\'Accueil</a>';
    		$reponse .= '<br />';
     
    		}
    		// si entrée déjà effectuée
    		else
    		{
    			$reponse = '<br></br>';
    			$reponse .= 'Attention '.'<strong>'.$pseudo.' !'.'</strong>';
    			$reponse .= '<br></br>';
    			$reponse .= '&eacute;v&eacute;nement déjà saisi dans l\'agenda !';
    		}
     
     
    	} // FIN de if($validform == 1)
     
     
    unset($_POST);
    }
    // -------------------------------
    // FIN DU  TRAITEMENT
    // -------------------------------
     
    if($validform == 2)	// affichage message d'erreur eventuel
    	{	echo $msgerreur;					} 
    	elseif	($validform == 1 && $reponse!='')	// On affiche la reponse positive ci-dessus
    	{	echo $reponse;						}	// affichage de la reponse positive à l'ecran
     
    /////////////////////////////////////////////
    ///// DEBUT   AFFICHAGE du formulaire ///////
    ////////////////////////////////////////////
    if($validform != 1)
    {	// $validform = 0 -> c'est la 1ère fois qu'on arrive sur la page (tous les $data = '')
    	// $validform = 2 -> erreur, donc RE-AFFICHAGE du formulaire, avec les $data récupérés
    ?>
    <form method="post" action="<?$PHP_SELF;?>">
    <fieldset>
    <br/>
    <legend> &nbsp; Annoncer un &eacute;v&eacute;nement sur une journ&eacute;e &nbsp; </legend>
    <br/>
    <?php
    // début de la première requête sur le type d'événement
    echo '<br />';
    echo '<br />';
    echo '<label>'.'Type d&rsquo; &eacute;v&eacute;nement &nbsp; : &nbsp;'.'</label>';
    echo '<br />';
    echo '<select name="evenement2" class="ev" tabindex="1" onfocus="this.className=\'ev_focus\';" onblur="this.className=\'ev\';">';
    // if (!empty($type_evenement_recupere)) {echo '<option value="'$type_evenement_recupere'">'.'$type_evenement_recupere'.'</option>';}
    echo '$type_evenement_recupere : '.$type_evenement_recupere;
    if (!empty($type_evenement_recupere)) {echo "<option value=\"$type_evenement_recupere\">$type_evenement_recupere</option>";}
    else {
    // connexion à la base
    $affich_form = "SELECT * FROM type_ev" ;
    $resultat = mysql_query($affich_form) or die ('Erreur : '.mysql_error() );
    $total = mysql_num_rows($resultat);
    //On vérifie que la table contient quelque chose
    if	(mysql_num_rows($resultat) == 0)
    	{	echo '<option>Aucun</option>';	} // fin si rien dans la liste de type d'événement
    	else	{				
    	while ( $list = mysql_fetch_array( $resultat ) )
    					{	echo '<option value="'.$list['Type_evenement'].'">'.$list['Type_evenement'].'</option>';	}
    			}
    }
    echo'</select>';
    // fin de la première requête sur le type d'événement
    echo '<br />';
    echo '<br />';
    // début de la deuxième requête sur le type d'établissement
    echo '<label>'.'Type d&rsquo; &eacute;tablissement &nbsp; : &nbsp;'.'</label>';
    echo '<br />';
    echo '<select name="lieu2" class="ev" tabindex="2" onfocus="this.className=\'ev_focus\';" onblur="this.className=\'ev\';">';
    if (!empty($type_lieu_recupere)) {echo "<option value=\"$type_lieu_recupere\">$type_lieu_recupere</option>";}
    else {
    $affich_form2 = "SELECT * FROM type_etab" ;
    $resultat2 = mysql_query($affich_form2) or die ('Erreur : '.mysql_error() );
    $total2 = mysql_num_rows($resultat2);
    //On vérifie que la table contient quelque chose
    if	(mysql_num_rows($resultat2) == 0)	
    	{	echo '<option>Aucun</option>';	}	// fin si rien dans la liste de type d'événement
    else
    	while ( $list2 = mysql_fetch_array( $resultat2 ) )
    	{
    		echo '<option value="'.$list2['type_etablissement'].'">'.$list2['type_etablissement'].'</option>';
    	} // fin du while
    } // fin du else
    echo'</select>';
    // fin de la première deuxième requête sur le type d'établissement
    echo '<br />';
    echo '<br />';
    // début de la troisième requête sur le secteur
    echo '<label>'.'Secteur'.'&nbsp; : &nbsp; '.'</label>';
    echo '<br />';
    echo '<select name="secteur" class="ev" tabindex="3" onfocus="this.className=\'ev_focus\';" onblur="this.className=\'ev\';">';
    if (!empty($secteur_recupere)) {echo "<option value=\"$secteur_recupere\">$secteur_recupere</option>";}
    else {
    $affich_form3 = "SELECT * FROM secteur" ;
    $resultat3 = mysql_query($affich_form3) or die ('Erreur : '.mysql_error() );
    $total3 = mysql_num_rows($resultat3);
    //On vérifie que la table contient quelque chose
    if
    (mysql_num_rows($resultat3) == 0)
    {
    echo '<option>Aucun</option>';
    } // fin si rien dans la liste
    else
    {
    while ( $list3 = mysql_fetch_array( $resultat3 ) )
    {
    echo '<option value="'.$list3['secteur_geographique'].'">'.$list3['secteur_geographique'].'</option>';
    } // fin du while
    }
    } // fin du else
    echo '</select>';
    // fin de la troisième  requête sur le secteur
    echo '<br />';
    echo '<br />';
    // début de la quatrième requête sur les jours
    echo '<label>'.'Jour &nbsp; : &nbsp; '.'</label>';
    echo '<br />';
    echo '<select name="jour" class="jj" tabindex="4" onfocus="this.className=\'jj_focus\';" onblur="this.className=\'jj\';">';
    if (!empty($jour_recupere)) {echo "<option value=\"$jour_recupere\">$jour_recupere</option>";}
    else {
    // affiche le jour actuel
    $jour_vue=date('d');
    echo '<option selected value="'.$jour_vue.'">'.$jour_vue.'</option>';
    $affich_form4 = "SELECT * FROM jours" ;
    $resultat4 = mysql_query($affich_form4) or die ('Erreur : '.mysql_error() );
    $total4 = mysql_num_rows($resultat4);
    //On vérifie que la table contient quelque chose
    if
    (mysql_num_rows($resultat4) == 0)
    {
    echo '<option>Aucun</option>';
    } // fin si rien dans la liste
    else
    {
    while ( $list4 = mysql_fetch_array( $resultat4 ) )
    {
    echo '<option value="'.$list4['jour'].'">'.$list4['jour'].'</option>';
    } // fin du while
    }
    } // fin du else
    echo '</select>';
    // fin de la quatrième requête sur les jours
     
    // début de la cinquième requête sur les mois
    mysql_query("SET NAMES utf8");
    echo '<label>'.'</label>';
    echo '<br />';
    echo '<select name="mois" class="mm" tabindex="5" onfocus="this.className=\'mm_focus\';" onblur="this.className=\'mm\';">';
    if (!empty($mois_recupere)) {echo "<option value=\"$numero_mois_form_2\">$mois_pour_affichage_apres_post</option>";}
    else {
    // DEBUT extraction du mois et de l'année du jour au format date MySQL  année  mois jour
    $mois_jour=date('n');
    $annee_jour=date('Y');
    // on cherche dans la base des mois le numéro
    $affich_form_mois = "SELECT Nb FROM mois2 WHERE num_mois='$mois_jour' AND annee='$annee_jour'" ;
    $resultat_mois = mysql_query($affich_form_mois) or die ('Erreur : '.mysql_error() );
    $list_mois = mysql_fetch_array( $resultat_mois );
    $numero_mois = $list_mois['Nb']-1;
    $affich_form4 = "SELECT * FROM mois2 LIMIT $numero_mois,7" ;
    // FIN extraction du mois et de l'année du jour au format date MySQL  année  mois jour
     
    $resultat4 = mysql_query($affich_form4) or die ('Erreur : '.mysql_error() );
    $total = mysql_num_rows($resultat4);
    //On vérifie que la table contient quelque chose
    if
    (mysql_num_rows($resultat4) == 0)
    {
    echo '<option>Aucun</option>';
    } // fin si rien dans la liste
    else
    {
    while ( $list = mysql_fetch_array( $resultat4 ) )
    {
    echo '<option value="'.$list['Nb'].'">'.$list['mois'].'</option>';
    } // fin du while
    }
    } // fin du else
    echo '</select>';
    // fin de la cinquième requête sur les mois
    echo '<br />';
    echo '<br />';
    ?>
    <label for="ev6">Tarif &nbsp; : &nbsp; </label>
    <br />
    <select name="tarif" tabindex="7" onchange="showT();" id="idSelect" onfocus="this.className='ev_focus';" onblur="this.className='ev';valide(this, 'err_id');" class="ev">
    <?php if (!empty($tarif_recupere)) {echo "<option value=\"$tarif_recupere\">$tarif_recupere</option>";} else { ?>
    <option value="Gratuit"> Gratuit </option>
    <option value="Payant"> Payant </option>
    <?php	}	?>
    </select>
    <br />
    <br />
    <label id="idlabel" style="display:none" onchange="showT();" for="ev12">Montant &nbsp; : &nbsp; </label>
    <br />
    <input type="text" style="display:none" tabindex="9" id="idInput" name="montant" value="<?php echo stripslashes($montant_recupere) ?>" onfocus="this.className='ev_focus';" onblur="this.className='ev';valide(this, 'err_id');" class="ev" /> <span id="err_id" style="color:red"></span>
    <span id="err_id" style="color:red"></span>
    <br />
    <br />
    <label for="ev7">Nom du lieu &nbsp; : &nbsp; </label>
    <br />
     
    <!-- pour affichage des lieux -->
    <input type="text" tabindex ="10" name="lieu3" class="ev" value="<?php echo stripslashes($lieu_affiche) ?>" id="inputString" onfocus="this.className='ev_focus';" onblur="this.className='ev';valide(this, 'err_mdp');" class="ev" /><!--  champ texte à analyser pour les suggestions -->
     <div class="suggestionsBox" id="suggestions" style="display: none;"> <!-- bloc contenant les eventuelles suggestions -->
    <div class="suggestionList" id="autoSuggestionsList"><!-- liste contenant les suggestions -->
    </div>
    </div>
    <!-- FIN de : pour affichage des lieux -->
    <br />
    <br />
    <label for="ev8">Heure de d&eacute;but &nbsp; : &nbsp; </label>
    <br />
    <input type="text" tabindex="11" name="debut"  value="<?php echo stripslashes($heure_debut_recupere) ?>" onfocus="this.className='ev_focus';" onblur="this.className='ev';valide(this, 'err_id');" class="ev" /><span id="err_id" style="color:red"></span>
    <br />
    <br />
    <label for="ev9">Nom de l'artiste...&nbsp; : &nbsp; </label>
    <br />
    <input type="text" name="nom4" value="<?php echo stripslashes($nom_artiste_affiche) ?>" tabindex="12" onfocus="this.className='ev_focus';" onblur="this.className='ev';valide(this, 'err_id');"
     class="ev" /><span id="err_id" style="color:red"></span>
    <br /><br />
    <label for="ev9">Site web &nbsp; : &nbsp; </label>
    <br />
    <input type="text" name="webinfos" value="<?php echo stripslashes($site_web_recupere) ?>" tabindex="13" onfocus="this.className='ev_focus';" onblur="this.className='ev';valide(this, 'err_id');"
     class="ev" /><span id="err_id" style="color:red"></span>
    <br />
    <label for="coment">Description &nbsp; 500 caract&egrave;res maxi</label>
    <br />
    <textarea name="comments" tabindex="14" value="<?php echo stripslashes($designation_affiche) ?>" onfocus="this.className='textarea_focus';" onblur="this.className='textarea';valide(this, 'err_id');">
    </textarea>
    <p>
    <br /><br /><br />
    <input name="boutonEnvoiFormulaire" tabindex="15" type="submit" value="Envoyer" />
    </p>
    </fieldset>
    </form>
     
    <?php	
    }
    /////////////////////////////////////////////
    ///// FIN    AFFICHAGE du formulaire ///////
    ////////////////////////////////////////////
    ?>
    <br /><br />
    </div>
    <?php mysql_close($sql); //On se deconnecte ?>
    <?php include('bas_de_page.php'); ?> <!-- insère le bas de page  -->
    </body>
    </html>

  2. #2
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    Citation Envoyé par fazpedro
    je ne vois pas où se situe mon erreur ?
    avec 500 lignes de code c'est normale, commence par séparer ton application

    EDIT : la rendre cohérente aussi

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    require ('./_protection_page.php'); 
    require ("configuration.php");
    pourquoi une ligne avec les ' et l'autre avec des " ?
    pourquoi mettre ./ sur l'une et pas sur l'autre ?

  3. #3
    Membre éclairé Avatar de fazpedro
    Homme Profil pro
    Inscrit en
    Août 2009
    Messages
    506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2009
    Messages : 506
    Par défaut
    C'est la ligne 157 que j'ai modifié et qui ne fonctionne pas ... (le "textarea est vidé...) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    	if (strlen($designation_recupere)>'500')	{	$msgerreur .= 'Champ D&eacute;signation : '.'<b>'.strlen($designation_recupere).'</b>'.
    													' caract&egrave;res, il faut'.'<b>'.' moins de 500 caract&egrave;res !'.'</b>'.'<br />'; 
    													$validform 	= 2;
    												}
     // description : plus de 500 caractères !

  4. #4
    Membre éprouvé
    Homme Profil pro
    Directeur technique
    Inscrit en
    Février 2011
    Messages
    146
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : Transports

    Informations forums :
    Inscription : Février 2011
    Messages : 146
    Par défaut
    Pour moi ton problème est à la ligne 454~455 :

    Le textarea s'utilise comme ça

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <textarea rows="2" cols="20">
    At W3Schools you will find all the Web-building tutorials you need, from basic HTML to advanced XML, SQL, ASP, and PHP.
    </textarea>
    et non comme ça

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <textarea rows="2" cols="20" value="At W3Schools you will find all the Web-building tutorials you need, from basic HTML to advanced XML, SQL, ASP, and PHP."></textarea>
    Les erreurs les plus simples sont souvent celles qui nous font perdre le plus de temps.


    PS : Utilise une class pour la validation de tes formulaire car c'est du code que tu va réécrire 10000 fois dans ta vie sinon.

  5. #5
    Expert confirmé

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 418
    Par défaut
    Oui faudra vite améliorer ta façon de coder sinon t'a pas fini de t'arracher les cheveux (s'il en reste).

    Tu définis $designation_affiche = stripslashes($designation_recupere); uniquement si un des champs que tu contrôle est vide. Mais je ne vois pas que tu le défini lorsque $designation_recupere)>'500' (en plus faut pas de quote sur les nombres). Or c'est cette variable $designation_affiche que tu fais afficher dans le textarea.

    Et puis pour mettre un texte dans un texarea on le mets entre les balises du texarea et pas dans l'attribut value qui n'existe pas pour un textarea
    <textarea ...(divers attributs)...>mon texte qui apparaîtra dans le texarea</texarea> (déjà dit plus haut)

  6. #6
    Membre éclairé Avatar de fazpedro
    Homme Profil pro
    Inscrit en
    Août 2009
    Messages
    506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2009
    Messages : 506
    Par défaut
    Merci beaucoup ABCIWEB !

    ce code fonctionne bien, voici les modifications :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    	// description : plus de 500 caractères !
    	if (strlen($designation_recupere)>500)	{	$msgerreur .= 'Champ D&eacute;signation : '.'<b>'.strlen($designation_recupere).'</b>'.
    													' caract&egrave;res, il faut'.'<b>'.' moins de 500 caract&egrave;res !'.'</b>'.'<br />'; 
    													$validform 	= 2;
    													$designation_affiche	= stripslashes($designation_recupere);	
    												}
    ........
    <textarea name="comments" tabindex="14" onfocus="this.className='textarea_focus';" onblur="this.className='textarea';valide(this, 'err_id');">
    <?php echo stripslashes($designation_affiche) ?></textarea>
    par contre, quand vous dites "améliorer ta façon de coder...", vous pourriez me donner 2/3 tuyaux pour peaufiner mon code ?
    ce serait vraiment sympa

  7. #7
    Expert confirmé

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 418
    Par défaut
    Citation Envoyé par fazpedro Voir le message
    par contre, quand vous dites "améliorer ta façon de coder...", vous pourriez me donner 2/3 tuyaux pour peaufiner mon code ?
    ce serait vraiment sympa
    Déjà commencer par bien indenter ton code.

    Ensuite séparer le plus possible le code php du code html. La partie html ne doit contenir que le code php nécessaire à l'affichage.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    <?php
     
    // code php : requêtes ,traitement des formulaires etc..
     
    $données = 'résultat de ton traitement php';
    ?>
     
     
    <html>
     
    <head>
    <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />	
    <title>titre</title>
    ....
     
    <script type="text/javascript" src="jquery-1.2.1.pack.js"></script>
     
    <script type="text/javascript">
     
    // code javascrit si incorporé à la page
     
    </script>
     
     
    <style type="text/css">
     
    // code css si incorporé à la page
     
    </style>
     
    </head>
     
     
    <body>
    <div>
     
    code html
     
    <?php echo $données ?>
     
    </div>
    </body>
    </html>
    Tu verras que c'est nettement plus clair.

    Au passage je remarque que tu travaille en utf-8. Donc il ne faut pas utiliser strlen($text) mais mb_strlen($text,'utf-8') cf http://www.php.net/manual/fr/ref.mbstring.php

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 6
    Dernier message: 17/06/2014, 15h53
  2. Conserver les données passées en POST
    Par kevinf dans le forum Langage
    Réponses: 24
    Dernier message: 03/11/2006, 00h39
  3. Création dessin avec données saisies
    Par javajay dans le forum 2D
    Réponses: 5
    Dernier message: 26/10/2005, 02h55
  4. Réponses: 10
    Dernier message: 26/08/2005, 08h17
  5. Réponses: 8
    Dernier message: 19/05/2005, 16h03

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo