Accueil > Forum > > > > Probleme avec un formulaire d'upload
Probleme avec un formulaire d'upload
mardi 1 septembre 2009 à 17:09:51 |
Probleme avec un formulaire d'upload

prog2ni
|
Bonjour,
Je suis debutant en php.
Je vous explique mon probleme :
J'ai en place un script d'upload d'image, il fonctionne, associer a ce script, j'inscris dans une base de données d'autres informations. Tout fonctionne SAUF que lorsqu'il y a une erreur avec l'upload d'image (erreur de poids ou de dimension) cela passe quand meme et cela s'inscrit dans la base de données comme si de rien n'etait... et ça je ne le veux pas !
Je me doute que dans mon script, c'est l'endroit ou se situe "Insertion dans la base".... mais je ne sais pas ou le placer, ni meme mettre la synthaxe correcte pour que cela fonctionne.
Voici le script :
<?
require("conf.php");
$db_link = @mysql_connect($sql_serveur,$sql_user,$sql_passwd);
if(!$db_link) {echo "Connexion impossible à la base de données <b>$sql_bdd</b> sur le serveur <b>$sql_server</b><br>Vérifiez les paramètres du fichier conf.php"; exit;}
$select=mysql_select_db($sql_bdd);
$requete=mysql_query("select * from membre where id=\"$id\"",$db_link) or die(mysql_error());
if(mysql_num_rows($requete)==0)
{
header("Location:$url_erreur");
exit;
}
// LIGNE FACULTATIVE : RECUPERATION DU PSEUDO
$pseudo_membre=mysql_result($requete,0,"pseudo");
//$email=mysql_result($requete,0,"email");
/************************************************************
* Upload image
*************************************************************/
if ($action=="upload")
{
/************************************************************
* Ajout du texte dans la base
*************************************************************/
if(empty($titre) OR empty($texte_news) OR empty($auteur))
{
mysql_close();
header("Location:gestion_news.php?id=$id&message=mes1"); exit;
}
/************************************************************
* Definition des constantes / tableaux et variables
*************************************************************/
// Constantes
define('TARGET', '../images_si/'); // Repertoire cible
define('MAX_SIZE', 300000); // Taille max en octets du fichier
define('WIDTH_MAX', 400); // Largeur max de l'image en pixels
define('HEIGHT_MAX', 300); // Hauteur max de l'image en pixels
// Tableaux de donnees
$tabExt = array('jpg','gif','png','jpeg'); // Extensions autorisees
$infosImg = array();
// Variables
$extension = '';
$message = '';
$timeline = time();
$image = $timeline . "-" . $_FILES['fichier']['name'];
$date= date("Y-m-d");
$heure= date("H:i:s");
/************************************************************
* Changement nom image
*************************************************************/
if (empty($fichier))
{
$image = $_FILES['fichier']['name'];
}
else
{
$image = $timeline . "-" . $_FILES['fichier']['name'];
}
/************************************************************
* Creation du repertoire cible si inexistant
*************************************************************/
if( !is_dir(TARGET) ) {
if( !mkdir(TARGET, 0755) ) {
exit('Erreur : le répertoire cible ne peut-être créé ! Vérifiez que vous diposiez des droits suffisants pour le faire ou créez le manuellement !');
}
}
/************************************************************
* Insertion dans la base
*************************************************************/
$sql = "INSERT INTO news VALUES('','".strtoupper($titre)."','$image','$texte_news','$auteur','$date','$heure')";
mysql_query($sql) or die('Erreur SQL !'.$sql.'<br>'.mysql_error());
/************************************************************
* Script d'upload
*************************************************************/
if(!empty($_POST))
{
// On verifie si le champ est rempli
if( !empty($_FILES['fichier']['name']) )
{
// Recuperation de l'extension du fichier
$extension = pathinfo($_FILES['fichier']['name'], PATHINFO_EXTENSION);
// On verifie l'extension du fichier
if(in_array(strtolower($extension),$tabExt))
{
// On recupere les dimensions du fichier
$infosImg = getimagesize($_FILES['fichier']['tmp_name']);
// On verifie le type de l'image
if($infosImg[2] >= 1 && $infosImg[2] <= 14)
{
// On verifie les dimensions et taille de l'image
if(($infosImg[0] <= WIDTH_MAX) && ($infosImg[1] <= HEIGHT_MAX) && (filesize($_FILES['fichier']['tmp_name']) <= MAX_SIZE))
{
// Parcours du tableau d'erreurs
if(isset($_FILES['fichier']['error'])
&& UPLOAD_ERR_OK === $_FILES['fichier']['error'])
{
// Si c'est OK, on teste l'upload
if(move_uploaded_file($_FILES['fichier']['tmp_name'], TARGET.$image))
{
header("Location:gestion_news.php?id=$id&message=mes3"); exit;
}
else
{
// Sinon on affiche une erreur systeme
header("Location:gestion_news.php?id=$id&message=mes4"); exit;
}
}
else
{
header("Location:gestion_news.php?id=$id&message=mes5"); exit;
}
}
else
{
// Sinon erreur sur les dimensions et taille de l'image
header("Location:gestion_news.php?id=$id&message=mes6"); exit;
}
}
else
{
// Sinon erreur sur le type de l'image
header("Location:gestion_news.php?id=$id&message=mes7"); exit;
}
}
else
{
// Sinon on affiche une erreur pour l'extension
header("Location:gestion_news.php?id=$id&message=mes8"); exit;
}
}
else
{
// Sinon on affiche une erreur pour le champ vide
header("Location:gestion_news.php?id=$id&message=mes9"); exit;
}
}
}
mysql_close($db_link);
?>
|
|
mardi 1 septembre 2009 à 17:33:34 |
Re : Probleme avec un formulaire d'upload

coach759
|
Bonjour,
Si j'ai bien compris, tu veux insérer les infos dans la base que lorsque l'upload a réussi...
Dans ce cas là, il faut que tu déplace la partie "* Insertion dans la base *", ici:
Code PHP : // Si c'est OK, on teste l'upload
if(move_uploaded_file($_FILES['fichier']['tmp_name'], TARGET.$image))
{
/************************************************************
* Insertion dans la base
*************************************************************/
$sql = "INSERT INTO news VALUES('','".strtoupper($titre)."','$image','$texte_news','$auteur','$date','$heure')";
mysql_query($sql) or die('Erreur SQL !'.$sql.'<br>'.mysql_error());
header("Location:gestion_news.php?id=$id&message=mes3"); exit;
}
La fonction move_uploaded_file return TRUE si le fichier a été correctement déplacé. C'est donc dans ce IF que l'on doit faire l'insertion dans la base.
A+
________________________________________________________________
Si à la Saint Valentin elle te caresse la main, vivement la Sainte Marguerite...
|
|
mardi 1 septembre 2009 à 23:13:28 |
Re : Probleme avec un formulaire d'upload

prog2ni
|
Merci de ta reponse !
Bah en fait, le script fonctionne bien sauf... quand il y a une erreur au niveau de l'image (c'est a dire si elle est trop lourde ou si elle est trop grande)... le script n'empeche pas l'inclusion dans la base de données. A croire que les controles sont inopérants... j'espere bien me faire comprendre 
|
|
mercredi 2 septembre 2009 à 11:07:13 |
afficher des fichiers sous forme de lien

siwil
|
Salut a tous !!
J'ai pu recuperer des fichiers du repertoire "C:\willy" dans mon disque dur serveur et je parviens a les afficher sur l'interface client,j'utilise le code:
<?php
$dir='C:\willy';
if(@is_dir($dir)){// On vérifit que le dossier existe
$dh = opendir($dir);// On ouvre le repertoire
while(($file = readdir($dh)) !== false){// Boucle pour parcourir le repertoire
echo 'Fichier : ',$file,'<br />';
}
closedir($dh);// On ferme le repertoire
unset($nomFich,$dir,$dh);// On supprime les variables qui servent à rien
}else{
echo '<p style="text-align: center;">Le dossier <strong>',$dir,'</strong> n\'existe pas.</p>';
}
?>
mon probleme est que je veux afficher ces fichiers sous forme de lien de tel sorte que lorsqu'on clique dessus mon script download.php est appele pour faire le telechargement,mais je ne sais vraiment pas comment m'y prendre.
Merci pour votre aide
|
|
Cette discussion est classée dans : fichier, mysql, upload, image, if
Répondre à ce message
Sujets en rapport avec ce message
upload +insert bdd :( [ par ksinteractive ]
bonjour et merci d'avance :)jai fais une petite admin avec insertion d'une fiche avec le nom du modele et un champ upload pour uploader une image qui
Upload :) [ par GuilleW ]
Bonjour bonjour,Je souhaite faire un Upload de fichier.pour cela j'ai un image , et je souhaiterai que lorsque l'on click sur cette image, elle lance
pb de upload [ par filrouge13 ]
Bonjour,Petit problème de upload et de vérification de l'existence du fichier.J'ai récupéré ce code sur un forum, il devrait me permetre lors d'un upl
Variable dans une URL [ par L0rD59 ]
Bonjours j'ai un petit souci avec une variable et une URLje vous explique le contexte J'ai une fichier PHP qui permet d'upload des image (grace au bou
Upload de fichier txt sur MySql [ par pierreot ]
J'ai un problème à uploader un fichier txt sur PhpMyAdmin. Le but est d'insérer des données d'un fichier txt dans une table vierge, mais cela me donne
Upload d'une image sans formulaire [ par djangoboy ]
Bonjour à tous, Vous vous dites surement "encore un upload" mais c'est pas tout a fait pareil que les autre post. Imaginons qui j'ai une variable dan
(upload d'image) marche une fois sur deux??? [ par kenru ]
Bonjour à tous. Dans un dernier post précédemment écrit par moi même je réussi, grâce à l'aide de certains d'entre vous, à résoudre mon problème d'upl
Problème Transfert de fichier (input type=file) [ par Hector78 ]
Hello !J'ai le code suivant qui devrait m'être utile pour "simuler" un ftp interne à un site. Dans les grandes lignes, il est sensé :- permettre la sé
Gros problème d'upload d'image...encore un [ par kenru ]
Bonjour à tous, voilà j'ai un petit souci pour un upload d'image.//Fonction d'upload$nom_fichier = $_FILES['userfile']['name'];$tmp_fichier = $_FILES[
upload debutant [ par thrmgs ]
bonjour a tous j aimerai savoir comment puije uploader dans un repertoire predefinit par moi meme (par exemple: c:\image\foto.jpg) a l aide de se scri
Livres en rapport
|
Derniers Blogs
POUR RAPPEL ! LES SPéCIFICATIONS DES PROTOCOLES OFFICE ET SHAREPOINT SONT DISPONIBLES SUR MSDNPOUR RAPPEL ! LES SPéCIFICATIONS DES PROTOCOLES OFFICE ET SHAREPOINT SONT DISPONIBLES SUR MSDN par neodante
Quelle est le point commun entre : Microsoft il y a 10 ans et Apple aujourd'hui ? Réponse: avoir une politique de protocoles propriétaires et fermés :) Car pour rappel (si si je vous assure c'est important de le rappeler), la majorité des spécifications e...
Cliquez pour lire la suite de l'article par neodante JOYEUX ANNIVERSAIRE NIXJOYEUX ANNIVERSAIRE NIX par ebartsoft
Souhaitons un bon et joyeux anniversaire à notre hôte à tous, Nix.
Je ne le répéterais jamais assez mais sans lui rien ne serait possible. Il défit en permanence les lois de la gravité et comme il le dit si bien, si tu lui fais confiance ça devra...
Cliquez pour lire la suite de l'article par ebartsoft IMAGINE CUP 2012, MAKE A SIGN EN FINALEIMAGINE CUP 2012, MAKE A SIGN EN FINALE par junarnoalg
Voilà qui est fait, la nouvelle est officielle ! L'équipe belge "Make a Sign" va au pays des kangourous défendre son projet dans la catégorie Software Design. http://www.imaginecup.com/CompetitionsContent/Competition/WorldwideFinalists.aspx V...
Cliquez pour lire la suite de l'article par junarnoalg KINECT 1.5 IS OUT !KINECT 1.5 IS OUT ! par Vko
La version 1.5 du Kinect For Microsoft vient tout juste de sortir ! Plein de nouveautés: Tracking de squelette en Near Mode Détection en position assise Détection faciale avec un SDK dédié Documentation et des guideline (enfin) Un out...
Cliquez pour lire la suite de l'article par Vko LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) par richardc
Mise à jour des Web API du 14 Mai
Réservez dès maintenant votre journée du 20 juin pour le Windows Azure Dev Camp 2012 à Paris
Mise à jour de Team Foundation Service
MechCommander 2 sur Windows 8
Entity Framework 5 Release Candidate e...
Cliquez pour lire la suite de l'article par richardc
Logiciels
sDEVIS-FACTURES vlPRO (8.1.0.3)SDEVIS-FACTURES VLPRO (8.1.0.3)sDEVIS-FACTURES vlPRO a été mis au point pour les particuliers, créateurs, entrepreneurs, artisa... Cliquez pour télécharger sDEVIS-FACTURES vlPRO 974 Application Server (12.2.4.6)974 APPLICATION SERVER (12.2.4.6)Développez de puissantes applications dans un environnement de 'cloud computing', clusterisé, séc... Cliquez pour télécharger 974 Application Server vPicture (1.4.2.1)VPICTURE (1.4.2.1)Avec vPicture, hébergez vos images facilement et rapidement.
vPicture est un utilitaire simple, ... Cliquez pour télécharger vPicture Easy-Planning (2.2.1.6)EASY-PLANNING (2.2.1.6)Easy-Planning permet de créer des plannings sous la représentation de diagrammes et est adapté au... Cliquez pour télécharger Easy-Planning COM-BACKUP (2.0)COM-BACKUP (2.0)
COM-BACKUP est un logiciel de sauvegarde qui permet de planifier les sauvegardes de vos dossiers ...
Cliquez pour télécharger COM-BACKUP
|