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

Langage PHP Discussion :

erreur: "Notice: Undefined offset:"


Sujet :

Langage PHP

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 9
    Points : 6
    Points
    6
    Par défaut erreur: "Notice: Undefined offset:"
    Salut à tous,

    Voilà, j'ai un petit problème avec un script de vérification de champs que j'ai créer.

    Pour résumer l'application, il s'ajit d'une zone d'administration qui met à jour un site internet de musique.

    Je suis actuellement bloquer sur la vérification de l'ajout d'une actualité. Actuellement une actualité peut contenir jusqu'à 5 images (cette quantité n'est pas figer et est dynamique).
    Mon problème est le suivant, si je ne remplit pas tous les champs des 5 images, PHP me renvoie l'erreur suivante sur les champs non rempli une fois l'actu inséré dans la DB:

    Notice: Undefined offset: 2 in c:\utilitaires\developpement\easyphp1-8\www\infuseprod\admin\adminprotect\verif.php on line 357

    Notice: Undefined offset: 3 in c:\utilitaires\developpement\easyphp1-8\www\infuseprod\admin\adminprotect\verif.php on line 357

    Notice: Undefined offset: 4 in c:\utilitaires\developpement\easyphp1-8\www\infuseprod\admin\adminprotect\verif.php on line 357

    Notice: Undefined offset: 5 in c:\utilitaires\developpement\easyphp1-8\www\infuseprod\admin\adminprotect\verif.php on line 357


    L'insertion a été correctement effectuée.
    Voici le code de vérification des champs saisi dans un formulaire:

    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
    	case 'addnews':
    		//--------------------------------------------------------------------------------------------------------------		
    		//Page Vérification d'ajout d'une news ou un évènement biographie
    		//--------------------------------------------------------------------------------------------------------------			
    		session_start();
    		if ($_SESSION['auth'] == 1)
    		{						
    			require("hautacces.php");
    			$cnx = @mysql_connect("$serveur","$user","$password");// Connection à la base de données 
    			if (!$cnx)// Vérification de la connection à la base de données 
    			{
    				?>
    				<p class="alert"><? echo erreurServeurMySQL(); ?></p>
    				<?
    			}
    			else
    			{
    			   //Récupération des données renvoyé par le formulaire
    			   //Titre:
    				$titre = (isset($_POST['titre']))?$_POST['titre']:"";
    				$titre = replink($titre);
    				//Texte:
    				$texte = (isset($_POST['texte']))?$_POST['texte']:"";
    				$texte = replink($texte);
    				//Date:
    				$date = date("Y/m/d H:i");
    				//Ariste
    				$arti = (isset($_POST['arti']))?$_POST['arti']:"";
    				//Biographie	
    				$bio = (isset($_POST['bio']))?$_POST['bio']:"";	
    				//Image
    				$if=1;												
    				while ($if<=$nbimgn) //Tant que If est inferieur ou égal on nombre d'image maximum affichable dans l'actualité faire...
    				{
    					//Vérification du format du fichier à télécharger
    					switch($_FILES['img'.$if]['type']) 
    					{
    						case 'image/gif' :
    								break;
    						case 'image/jpg' :
    								break;
    						case 'image/jpeg' :
    								break;
    						case 'image/pjpeg' :
    								break;
    						case 'image/png' :
    								break;
    						case 'image/x-png':
    								break;
    						case '':
    								break;
    						default:
    								?>
    								<table width="100%" cellpadding="0" cellspacing="0" border="0" align="center" bgcolor="#a6d6fc" >
    								  <tr>
    									<td align="center">
    									<table  border="0" cellspacing="0" cellpadding="0" bgcolor="#a6d6fc" >
    										<tr>
    										  <td align="center" class="alert"> 
    												<? echo erreur('50001'); ?><br><br>
    										  </td>
    										</tr>
    									</table>
    									</td>
    									</tr>
    								</table>	
    								<?
    					}
    					//Création d'un fichier temporaire
    					if (is_uploaded_file($HTTP_POST_FILES['img'.$if]['tmp_name']))
    					{
    						//$fichier_temp = $HTTP_POST_FILES['img'.$if]['tmp_name'];
    						$nom_fichier = $HTTP_POST_FILES['img'.$if]['name'];
    						//Copie du fichier temporaire
    						copy($HTTP_POST_FILES['img'.$if]['tmp_name'], $nom_fichier );
    						// Copie du fichier copié dans son répertoire définitif
    						if ((isset($_FILES['img'.$if]['tmp_name'])&&($_FILES['img'.$if]['error'] == UPLOAD_ERR_OK))) 
    							{
    							//Construction du chemin définitif
    							switch ($arti) 
    								{
    									case 1:		
    										$chemin = 'images/bobalbum/';
    									break;	
    									case 2:		
    										$chemin = 'images/laualbum/';
    									break;		
    									default:		
    										$chemin = 'images/actu/';
    									break;	
    								} 	
    							$chemori[$if] = '../../'.$chemin.$_FILES['img'.$if]['name'];
    							$chem[$if] = $chemin.$_FILES['img'.$if]['name'];
    							$bool = move_uploaded_file($_FILES['img'.$if]['tmp_name'], $chemori[$if]);
    							if ($bool == '1')
    								{
    								//Effacement du fichier temporaire
    								unlink($_FILES['img'.$if]['name']);
    								}
    							else
    								{
    								?>
    								<table width="100%" cellpadding="0" cellspacing="0" border="0" align="center" bgcolor="#a6d6fc" >
    								  <tr>
    									<td align="center">
    									<table  border="0" cellspacing="0" cellpadding="0" bgcolor="#a6d6fc" >
    										<tr>
    										  <td align="center" class="alert"> 
    												<? echo erreur('50006'); ?><br><br>
    										  </td>
    										</tr>
    									</table>
    									</td>
    									</tr>
    								</table>
    								<?
    								$bool = unlink($_FILES['fichier']['tmp_name']);
    								if ($bool == '1')
    									{
    									?>
    									<table width="100%" cellpadding="0" cellspacing="0" border="0" align="center" bgcolor="#a6d6fc" >
    									  <tr>
    										<td align="center">
    										<table  border="0" cellspacing="0" cellpadding="0" bgcolor="#a6d6fc" >
    											<tr>
    											  <td align="center" class="alert"> 
    													<? echo erreur('50007'); ?><br><br>
    											  </td>
    											</tr>
    										</table>
    										</td>
    										</tr>
    									</table>
    									<?
    									}
    								else
    									{
    									?>
    									<table width="100%" cellpadding="0" cellspacing="0" border="0" align="center" bgcolor="#a6d6fc" >
    									  <tr>
    										<td align="center">
    										<table  border="0" cellspacing="0" cellpadding="0" bgcolor="#a6d6fc" >
    											<tr>
    											  <td align="center" class="alert"> 
    													<? echo erreur('50006'); ?><br><br>
    											  </td>
    											</tr>
    										</table>
    										</td>
    										</tr>
    									</table>
    									<?									
    									}
    								}
    							}
    						else
    							{
    							?>
    							<table width="100%" cellpadding="0" cellspacing="0" border="0" align="center" bgcolor="#a6d6fc" >
    							  <tr>
    								<td align="center">
    								<table  border="0" cellspacing="0" cellpadding="0" bgcolor="#a6d6fc" >
    									<tr>
    									  <td align="center" class="alert"> 
    											<? echo erreur('50008'); ?><br><br>
    									  </td>
    									</tr>
    								</table>
    								</td>
    								</tr>
    							</table>
    							<?
    							return false;
    							}
    						}												
    					$if++;
    				}				
    			   //Vérification de la saisie des champs
    				if (($texte == "Saisissez votre texte ici....")||($titre == "Saisissez votre titre ici...")||($texte == "")||($titre == ""))
    				{
    						?>
    						<table width="100%" cellpadding="0" cellspacing="0" border="0" align="center" bgcolor="#a6d6fc" >
    						  <tr>
    							<td align="center">
    							<table  border="0" cellspacing="0" cellpadding="0" bgcolor="#a6d6fc" >
    								<tr>
    								  <td align="center" class="alert"> 
    										<? echo erreur('30007'); ?><br><br>
    								  </td>
    								</tr>
    							</table>
    							</td>
    							</tr>
    						</table>	
    						<?
    						echo '<script language="javascript">';
    						echo 'setTimeout("redirect(\'admin.php?pg=Actualité&mod=Ajouter\')",1500); // delai en millisecondes';
    						echo '</script>';
    						require("basacces.htm");		
    				}					
    		  		else
    				{
    					//création de la requête SQL:
    					$sql = 'INSERT  INTO '.$tablenews.' (titrenews, textenews, datenews';
    					$if=1;												
    					while ($if<=$nbimgn)
    					{
    						$sql = $sql .', img'.$if.'news';
    						$if++;
    					}
    					$sql = $sql.', actunews, bionews, artnews) VALUES (\''.$titre.'\',\''.$texte.'\',\''.$date.'\'';
    					$if=1;												
    					while ($if<=$nbimgn)
    					{
    line 357						$sql = $sql.',\''.$chem[$if].'\'';
    						$if++;
    					}							 
    					$sql = $sql.',\''.$news.'\',\''.$bio.'\',\''.$arti.'\')' ;
    					
    					//exécution de la requête SQL:
    					$result = mysql_db_query("$base","$sql",$cnx) or die( mysql_error());
    					  
    					  //affichage des résultats, pour savoir si l'insertion a marchée:
    					 if($result)
    					  {
    						echo $result;
    						echo '<center><br><br>L\'insertion a été correctement effectuée.<center>' ;
    					  }
    					  else
    					  {
    						echo $result;
    						echo'<center><br><br><strong>L\'insertion à échouée.</strong></center>' ;
    					  }
    				}
    			}
    		}
    		else
    		{
    			require("hautlog.htm");
    			?>
    			<table width="100%" cellpadding="0" cellspacing="0" border="0" align="center" bgcolor="#a6d6fc" >
    			  <tr>
    				<td align="center">
    					<table  border="0" cellspacing="0" cellpadding="0" bgcolor="#a6d6fc" >
    						<tr>
    						  <td align="center" class="alert"> 
    								<? echo erreur('20010'); ?><br><br>
    						  </td>
    						</tr>
    					</table>
    				</td>
    			  </tr>
    			</table>	
    			<?
    			echo '<script language="javascript">';
    			echo 'setTimeout("redirect(\''.$log.'\')",3000); // delai en millisecondes';
    			echo '</script>';			
    			require("baslog.htm");
    		}
    	break;
    J'espère que vous pourrez m'aider car j'ai essayer pas mal de solution intermédiaire qui ont toutes abouti au même message d'erreur .

  2. #2
    Membre expert Avatar de Amara
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    2 688
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 2 688
    Points : 3 115
    Points
    3 115
    Par défaut
    C'est normal parce que apparement $nbimgn vaut toujours le maximum d'images autorisées soit 5, alors que dans tes boucles il faut le nombre exact d'images effectivement traitées. Il faut que tu trouves un moyen de récupérer ce nombre.

    Et au passage faire des cases avec des dizaines de lignes de code c'est vraiment pas terrible, il est préférable de mettre ce code dans des fonctions et d'appeler ces fonctions dans les cases.
    Pas de questions techniques par MP, le forum est là pour ça et est plus efficace.

    Orthographe : une connexion (avec un x), un langage (sans u), une requête (un seul t), 'une quote' (avec qu), une syntaxe (sans h)

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 9
    Points : 6
    Points
    6
    Par défaut
    Mais oui, logique .

    Merci pour votre réponse, cela faisait plus d'une journée que j'étais bloqué, et je n'y avais même pas fait gaffe. A trop chercher la solution on finit par ne pas voir le problème sous notre nez

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

Discussions similaires

  1. Erreur php : "Notice: Undefined offset: 1"
    Par bobette16 dans le forum Langage
    Réponses: 3
    Dernier message: 08/04/2013, 09h44
  2. [MySQL] Erreur de programmation PHP & MySQL (Notice: Undefined offset: 890)
    Par petit.quent dans le forum PHP & Base de données
    Réponses: 11
    Dernier message: 29/12/2011, 14h38
  3. [MySQL] Notice: Undefined offset
    Par gaetanc15 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 30/04/2009, 16h16

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