In diesem Tutorial zeigen wir Ihnen, wie Sie das Hochladen von Dateien mit der Implementierung von Jersey, JAX-RS durchführen.
1. Multipart-Abhängigkeit von Jersey
Um Multipart (Datei-Upload) in Jersey zu unterstützen, müssen Sie lediglich " jersey-multipart.jar " in die Maven-Datei "pom.xml" einfügen.
<project ...> <repositories> <repository> <id>maven2-repository.java.net</id> <name>Java.net Repository for Maven</name> <url>http://download.java.net/maven/2/</url> <layout>default</layout> </repository> </repositories> <dependencies> <dependency> <groupId>com.sun.jersey</groupId> <artifactId>jersey-server</artifactId> <version>1.8</version> </dependency> <dependency> <groupId>com.sun.jersey.contribs</groupId> <artifactId>jersey-multipart</artifactId> <version>1.8</version> </dependency> </dependencies> </project>
2. Datei-Upload-HTML-Formular
Einfaches HTML-Formular zum Auswählen und Hochladen einer Datei.
<html> <body> <h1>File Upload with Jersey</h1> <form action="rest/file/upload" method="post" enctype="multipart/form-data"> <p> Select a file : <input type="file" name="file" size="45"/> </p> <input type="submit" value="Upload It"/> </form> </body> </html>
3. Upload-Service mit Jersey
Verwenden Sie in Jersey @ FormDataParam, um die hochgeladene Datei zu erhalten. Um den hochgeladenen Dateinamen oder die Kopfzeilendetails abzurufen, passen Sie ihn "FormDataContentDisposition" an.
import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import javax.ws.rs.Consumes; import javax.ws.rs.POST; import javax.ws.rs.Path; import javax.ws.rs.core.MediaType; import javax.ws.rs.core.Response; import com.sun.jersey.core.header.FormDataContentDisposition; import com.sun.jersey.multipart.FormDataParam; @Path("/file") public class UploadFileService { @POST @Path("/upload") @Consumes(MediaType.MULTIPART__FORM__DATA) public Response uploadFile( @FormDataParam("file") InputStream uploadedInputStream, @FormDataParam("file") FormDataContentDisposition fileDetail) { String uploadedFileLocation = "d://uploaded/" + fileDetail.getFileName(); //save it writeToFile(uploadedInputStream, uploadedFileLocation); String output = "File uploaded to : " + uploadedFileLocation; return Response.status(200).entity(output).build(); } //save uploaded file to new location private void writeToFile(InputStream uploadedInputStream, String uploadedFileLocation) { try { OutputStream out = new FileOutputStream(new File( uploadedFileLocation)); int read = 0; byte[]bytes = new byte[1024]; out = new FileOutputStream(new File(uploadedFileLocation)); while ((read = uploadedInputStream.read(bytes)) != -1) { out.write(bytes, 0, read); } out.flush(); out.close(); } catch (IOException e) { e.printStackTrace(); } } }
4. Demo
Wählen Sie eine Datei aus und klicken Sie auf die Schaltfläche zum Hochladen. Die ausgewählte Datei wird an einen vordefinierten Ort hochgeladen.
URL: http://localhost : 8080/RESTfulExample/FileUpload.html
URL: http://localhost : 8080/RESTfulExample/rest/file/upload
Quellcode herunterladen
Download es - JAX-RS-FileUpload-Jersey-Example.zip (6 KB)
Referenzen
-
link://webservices/jax-rs/file-upload-beispiel-in-resteasy/[Datei-Upload
Beispiel in RESTEasy]
Link://Tag/Datei-Upload/[Dateiupload]Link://Tag/Jax-rs/[Jax-Rs] jersey