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
|
public final class AjouterPhotoForm {
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() ) {
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." );
}
}
else
{
throw new FormValidationException( "Vous n'avez sélectionné aucune photo." );
}
} 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 2Mo." );
} 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