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
| package forms;
import java.util.Collection;
import javax.servlet.ServletException;
import eu.medsea.mimeutil.MimeUtil;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.Part;
import beans.Candidat;
import dao.CandidatDao;
import dao.DAOException;
public final class AjouterPhotoForm {
private static final String CHAMP_EMAIL = "email";
private static final String CHAMP_PHOTO = "photo";
private static final int TAILLE_TAMPON = 10240; // 10ko
private String resultat;
private Map<String, String> erreurs = new HashMap<String, String>();
private CandidatDao candidatDao;
public AjouterPhotoForm( CandidatDao candidatDao ) {
this.candidatDao = candidatDao;
}
public Map<String, String> getErreurs() {
return erreurs;
}
public String getResultat() {
return resultat;
}
public Candidat creerCandidat( HttpServletRequest request, String chemin ) {
String email = getValeurChamp( request, CHAMP_EMAIL );
System.out.println("le mail est vraiment: "+email);
Candidat candidat = new Candidat();
candidat.setEmail(email);
traiterPhoto( candidat, request, chemin );
try {
if ( erreurs.isEmpty() ) {
candidatDao.insererEtude( candidat,email );
candidat = candidatDao.trouver(email);
resultat = "Succès de la création de votre compte.";
} else {
resultat = "<div class=\"resultat_echec\">Échec de la création de votre compte. Corrigez les erreurs ci-dessous!</div> <br><br>";
}
} catch ( DAOException e ) {
setErreur( "imprévu", "Erreur imprévue lors de la création." );
resultat = "<div class=\"resultat_echec2\">Échec de la création de votre profil : une erreur imprévue est survenue, merci de réessayer dans quelques instants.</div><br><br>";
e.printStackTrace();
}
return candidat;
}
private void traiterPhoto( Candidat candidat, HttpServletRequest request, String chemin ) {
String photo = null;
try {
photo = validationPhoto( request, chemin );
} catch ( FormValidationException e ) {
setErreur( CHAMP_PHOTO, e.getMessage() );
}
candidat.setPhoto( photo );
}
private String validationPhoto( HttpServletRequest request, String chemin ) throws FormValidationException {
/*
* Récupération du contenu du champ image du formulaire. Il faut ici
* utiliser la méthode getPart().
*/
String nomFichier = null;
InputStream contenuFichier = null;
try {
Part part = request.getPart( CHAMP_PHOTO );
System.out.println("la photo est: "+part);
nomFichier = getNomFichier( part );
/*
* Si la méthode getNomFichier() a renvoyé quelque chose, il s'agit
* donc d'un champ de type fichier (input type="file").
*/
if ( nomFichier != null && !nomFichier.isEmpty() ) {
/*
* Antibug pour Internet Explorer, qui transmet pour une raison
* mystique le chemin du fichier local à la machine du client...
*
* Ex : C:/dossier/sous-dossier/fichier.ext
*
* On doit donc faire en sorte de ne sélectionner que le nom et
* l'extension du fichier, et de se débarrasser du superflu.
*/
nomFichier = nomFichier.substring( nomFichier.lastIndexOf( '/' ) + 1 )
.substring( nomFichier.lastIndexOf( '\\' ) + 1 );
/* Récupération du contenu du fichier */
contenuFichier = part.getInputStream();
/* Extraction du type MIME du fichier depuis l'InputStream */
MimeUtil.registerMimeDetector( "eu.medsea.mimeutil.detector.MagicMimeMimeDetector" );
Collection<?> mimeTypes = MimeUtil.getMimeTypes( contenuFichier );
/*
* Si le fichier est bien une image, alors son en-tête MIME
* commence par la chaîne "image"
*/
if ( mimeTypes.toString().startsWith( "image" ) ) {
/* Écriture du fichier sur le disque */
ecrireFichier( contenuFichier, nomFichier, chemin );
} else {
throw new FormValidationException( "Le fichier envoyé doit être une image." );
}
}
} catch ( IllegalStateException e ) {
/*
* Exception retournée si la taille des données dépasse les limites
* définies dans la section <multipart-config> de la déclaration de
* notre servlet d'upload dans le fichier web.xml
*/
e.printStackTrace();
throw new FormValidationException( "Le fichier envoyé ne doit pas dépasser 1Mo." );
} catch ( IOException e ) {
/*
* Exception retournée si une erreur au niveau des répertoires de
* stockage survient (répertoire inexistant, droits d'accès
* insuffisants, etc.)
*/
e.printStackTrace();
throw new FormValidationException( "Erreur de configuration du serveur." );
} catch ( ServletException e ) {
/*
* Exception retournée si la requête n'est pas de type
* multipart/form-data.
*/
e.printStackTrace();
throw new FormValidationException(
"Ce type de requête n'est pas supporté, merci d'utiliser le formulaire prévu pour envoyer votre fichier." );
}
return nomFichier;
}
/*
* Ajoute un message correspondant au champ spécifié à la map des erreurs.
*/
private void setErreur( String champ, String message ) {
erreurs.put( champ, message );
}
/*
* Méthode utilitaire qui retourne null si un champ est vide, et son contenu
* sinon.
*/
private static String getValeurChamp( HttpServletRequest request, String nomChamp ) {
String valeur = request.getParameter( nomChamp );
if ( valeur == null || valeur.trim().length() == 0 ) {
return null;
} else {
return valeur;
}
}
/*
* Méthode utilitaire qui a pour unique but d'analyser l'en-tête
* "content-disposition", et de vérifier si le paramètre "filename" y est
* présent. Si oui, alors le champ traité est de type File et la méthode
* retourne son nom, sinon il s'agit d'un champ de formulaire classique et
* la méthode retourne null.
*/
private static String getNomFichier( Part part ) {
/* Boucle sur chacun des paramètres de l'en-tête "content-disposition". */
for ( String contentDisposition : part.getHeader( "content-disposition" ).split( ";" ) ) {
/* Recherche de l'éventuelle présence du paramètre "filename". */
if ( contentDisposition.trim().startsWith( "filename" ) ) {
/*
* Si "filename" est présent, alors renvoi de sa valeur,
* c'est-à-dire du nom de fichier sans guillemets.
*/
return contentDisposition.substring( contentDisposition.indexOf( '=' ) + 1 ).trim().replace( "\"", "" );
}
}
/* Et pour terminer, si rien n'a été trouvé... */
return null;
}
/*
* Méthode utilitaire qui a pour but d'écrire le fichier passé en paramètre
* sur le disque, dans le répertoire donné et avec le nom donné.
*/
private void ecrireFichier( InputStream contenuFichier, String nomFichier, String chemin )
throws FormValidationException {
/* Prépare les flux. */
BufferedInputStream entree = null;
BufferedOutputStream sortie = null;
try {
/* Ouvre les flux. */
entree = new BufferedInputStream( contenuFichier, TAILLE_TAMPON );
sortie = new BufferedOutputStream( new FileOutputStream( new File( chemin + nomFichier ) ),
TAILLE_TAMPON );
/*
* Lit le fichier reçu et écrit son contenu dans un fichier sur le
* disque.
*/
byte[] tampon = new byte[TAILLE_TAMPON];
int longueur = 0;
while ( ( longueur = entree.read( tampon ) ) > 0 ) {
sortie.write( tampon, 0, longueur );
}
} catch ( Exception e ) {
throw new FormValidationException( "Erreur lors de l'écriture du fichier sur le disque." );
} finally {
try {
sortie.close();
} catch ( IOException ignore ) {
}
try {
entree.close();
} catch ( IOException ignore ) {
}
}
}
} |
Partager