Précédent   Forum des professionnels en informatique > PHP > PHP & SGBD > PHP & MySQL
PHP & MySQL Forum d'entraide sur les fonctions MySQL avec PHP. Avant de poster -> FAQ MySQL, Cours MySQL et Sources MySQL. Pour les questions concernant le moteur MySQL plutôt que les fonctions PHP, merci d'utiliser le forum MySQL.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 06/10/2011, 14h54   #1
Membre du Club
 
Avatar de fazpedro
 
Homme
Inscription : août 2009
Messages : 360
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations forums :
Inscription : août 2009
Messages : 360
Points : 64
Points : 64
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 :
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>
fazpedro est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 06/10/2011, 14h58   #2
Modérateur
 
Inscription : septembre 2010
Messages : 7 131
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 131
Points : 8 491
Points : 8 491
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 :
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 ?
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 06/10/2011, 15h12   #3
Membre du Club
 
Avatar de fazpedro
 
Homme
Inscription : août 2009
Messages : 360
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations forums :
Inscription : août 2009
Messages : 360
Points : 64
Points : 64
C'est la ligne 157 que j'ai modifié et qui ne fonctionne pas ... (le "textarea est vidé...) :

Code :
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 !
fazpedro est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 06/10/2011, 18h27   #4
Nouveau Membre du Club
 
Aurélien LEQUOY
Inscription : février 2011
Messages : 33
Détails du profil
Informations personnelles :
Nom : Aurélien LEQUOY

Informations forums :
Inscription : février 2011
Messages : 33
Points : 35
Points : 35
Pour moi ton problème est à la ligne 454~455 :

Le textarea s'utilise comme ça

Code :
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 :
<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.
Aurélien LEQUOY est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 06/10/2011, 18h40   #5
Membre Expert
 
Inscription : septembre 2010
Messages : 1 242
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 1 242
Points : 1 564
Points : 1 564
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)
__________________
- Réalisations
- Interface graphique : génération en javascript d'objets défilants, texte et/ou images, mode horizontal ou vertical.
ABCIWEB est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 06/10/2011, 21h05   #6
Membre du Club
 
Avatar de fazpedro
 
Homme
Inscription : août 2009
Messages : 360
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations forums :
Inscription : août 2009
Messages : 360
Points : 64
Points : 64
Merci beaucoup ABCIWEB !

ce code fonctionne bien, voici les modifications :
Code :
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
fazpedro est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 06/10/2011, 22h17   #7
Membre Expert
 
Inscription : septembre 2010
Messages : 1 242
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 1 242
Points : 1 564
Points : 1 564
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 :
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éalisations
- Interface graphique : génération en javascript d'objets défilants, texte et/ou images, mode horizontal ou vertical.
ABCIWEB est déconnecté   Envoyer un message privé Réponse avec citation 10
Vieux 07/10/2011, 15h41   #8
Membre du Club
 
Avatar de fazpedro
 
Homme
Inscription : août 2009
Messages : 360
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations forums :
Inscription : août 2009
Messages : 360
Points : 64
Points : 64
merci ABCIWEB, je pense avoir compris,

"c'est en faisant des erreurs que l'on apprend et..c'est fou ce que j'apprends"
je vais essayer de refaire tous mes codes proprement..
encore merci et bon week end !
fazpedro est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 01h00.


 
 
 
 
Partenaires

Hébergement Web