Servlet zum speichern einer Datei in einer Datenbank

eolith421

Mitglied
Hallo!
Ich versuche derzeit gerade ein Servlet zu schreiben welches von einer GWT Anwendung eine Datei entgegen nimmt und diese in einer Datenabnk speichert. Ich habe das Servlet ausd verschiedenen Quellen aus dem Internet zusammengebastelt und es funktioniert auch in der Entwicklungsumgebung. Alelrdings hat das Servlet noch einen Fehler: Die Datei wird zunächst im Dateisystem gespeichert und erst dann in der DB. Das will ich aber nicht, die Datei soll gleich in der DB gespeichert werden.

Was muss ich dafür ändern? Hier ist der Quellcode:

Java:
public class ImageUpload extends HttpServlet {
	
	private static final long serialVersionUID = -5938868593144607557L;
	private Logger log = Logger.getLogger(ImageUpload.class);
	private FileInputStream inputStream;
	private String content_type = null;
		
	@SuppressWarnings("unchecked")
	public void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		
		log.debug("service has been called");
		
		if(!ServletFileUpload.isMultipartContent(request))
			return;
		
		FileItemFactory factory = new DiskFileItemFactory();
		ServletFileUpload servletUpload = new ServletFileUpload(factory);
		
		List fileItems = null;
		try {
			fileItems = servletUpload.parseRequest(request);
		}
		catch(FileUploadException e){
			log.error(e);
			return;
		}
		
		for(java.util.Iterator i = fileItems.iterator(); i.hasNext();){
			
			FileItem item = (FileItem) i.next();
			
			if(item.isFormField())
				continue;
			
			String fileName = item.getName();
			
			int slash = fileName.lastIndexOf("/");
			if(slash == -1){
				slash = fileName.lastIndexOf("\\");
			}
			if(slash != -1) {
				fileName = fileName.substring(slash+1);
			}
			
			try {
				
				int galleryId = -1; 
				galleryId = Integer.parseInt(request.getParameter("galleryId"));
				log.debug("Gallery ID: "+galleryId);
				
				if(galleryId != -1){
					
					Gallery temp = new Gallery();
	                temp.setPID(galleryId);
	                Gallery gallery = new Gallery(temp);
	                log.debug("Gallery Name: "+gallery.getName());
					
					content_type = item.getContentType();
					
	                File uploadedFile = new File(fileName);
	                item.write(uploadedFile);
	                
	                inputStream = new FileInputStream(uploadedFile);
	               
	                byte[] b = new byte[(int) uploadedFile.length()];
	                
	                inputStream.read(b);

	                JImage image = new JImage();
	                image.setCreationDate(new Date());
	                image.setDeleted(false);
	                image.setImageTyp(content_type);
	                image.setName(fileName);
	                image.setSubtitle("");
	                image.setGallery(gallery);
	                image.setViews(0);
	                image.setImage(b);
	                
	                image.addImage();
	                
	                gallery.getImages().add(image);
	                gallery.update();
	                
	                response.setContentType("text/html");
	                response.getWriter().print(image.getPID());
				}
			}
			catch (Exception e) {
				log.error(e);
			}
		}
	}

}

Vielen Dank für eure Hilfe, wäre super wenn ihr mir helft!

Florian
 

ARadauer

Top Contributor
das FileItem ist das von apache commons... hohl dir von dem objekt den inputstream und schreibe es mit einem bytearrayoutputstream in ein byte[]

Java:
 InputStreamReader in =   new InputStreamReader(item.getInputStream());
               	ByteArrayOutputStream bos = new ByteArrayOutputStream();
            	int c;
            	while ((c = in.read()) != -1) {
            		bos.write((byte) c);
            	}
            	
            	byte[] b = bos.toByteArray();
versuch das mal... falls es nicht klappt, hab ich funktionierenden Code in der Firma, den kann ich dir morgen posten
 

ARadauer

Top Contributor
ok wie sieht der code hier in der firma aus...
ich verwende da IOUtils von Apache Commons... das würd ich mir runter laden..
ein auszug daraus:

Java:
private static final int DEFAULT_BUFFER_SIZE = 1024 * 4;
public static byte[] toByteArray(InputStream input) throws IOException {
        ByteArrayOutputStream output = new ByteArrayOutputStream();
        copy(input, output);
        return output.toByteArray();
    }
 public static int copy(InputStream input, OutputStream output) throws IOException {
        long count = copyLarge(input, output);
        if (count > Integer.MAX_VALUE) {
            return -1;
        }
        return (int) count;
    }
public static long copyLarge(InputStream input, OutputStream output)
            throws IOException {
        byte[] buffer = new byte[DEFAULT_BUFFER_SIZE];
        long count = 0;
        int n = 0;
        while (-1 != (n = input.read(buffer))) {
            output.write(buffer, 0, n);
            count += n;
        }
        return count;
    }
 

eolith421

Mitglied
Hallo!
Tut mir leid, dass ich erst jetzt antworte! Ich wollte mich bei dir herzlich bedanken, deine Codeschnipsel haben wunderbar funktioniert das Servlet läuft jetzt 1A! Damit alle davon etwa haben werde ich im folgenden den wichtigsten Teil des Codes online stellen. Wenn jemand interesse am kompletten Code hat, einfach melden!

Java:
.
.
.
public void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		
		log.debug("imageUpload has been called");
		
		if(!ServletFileUpload.isMultipartContent(request))
			return;
		
		FileItemFactory factory = new DiskFileItemFactory();
		ServletFileUpload servletUpload = new ServletFileUpload(factory);
		
		List fileItems = null;
		try {
			fileItems = servletUpload.parseRequest(request);
		}
		catch(FileUploadException e){
			log.error(e);
			return;
		}
		
		InputStream in;
		ByteArrayOutputStream out = new ByteArrayOutputStream();
		
		for(java.util.Iterator i = fileItems.iterator(); i.hasNext();){
			
			FileItem item = (FileItem) i.next();
			
			if(item.isFormField())
				continue;
			
			String fileName = item.getName();
			
			int slash = fileName.lastIndexOf("/");
			if(slash == -1){
				slash = fileName.lastIndexOf("\\");
			}
			if(slash != -1) {
				fileName = fileName.substring(slash+1);
			}
			
			try {
				
				int galleryId = -1; 
				galleryId = Integer.parseInt(request.getParameter("galleryId"));
				log.debug("Gallery ID: "+galleryId);
				
				if(galleryId != -1){
					
					Gallery temp = new Gallery();
	                temp.setPID(galleryId);
	                Gallery gallery = new Gallery(temp);
	                log.debug("Gallery Name: "+gallery.getName());
					
					content_type = item.getContentType();
					
					in =   item.getInputStream();
					out = new ByteArrayOutputStream();
					
					// this method (copy) is defined beneath the current method
					copy(in, out);
					
					byte[] b = out.toByteArray();

	                JImage image = new JImage();
	                image.setCreationDate(new Date());
	                image.setDeleted(false);
	                image.setImageTyp(content_type);
	                image.setName(fileName);
	                image.setSubtitle("");
	                image.setGallery(gallery);
	                image.setViews(0);
	                image.setImageFile(b);
	                
	                image.addImage();
	                
	                gallery.getImages().add(image);
	                gallery.update();
	                
	                response.setContentType("text/html");
	                response.getWriter().print(image.getPID());
				}
			}
			catch (Exception e) {
				log.error(e);
			}
		}
	}
	
	private static final int DEFAULT_BUFFER_SIZE = 1024 * 4;
	private static int copy(InputStream input, OutputStream output) throws IOException {
        long count = copyLarge(input, output);
        if (count > Integer.MAX_VALUE) {
            return -1;
        }
        return (int) count;
	}
	private static long copyLarge(InputStream input, OutputStream output)
    throws IOException {
		byte[] buffer = new byte[DEFAULT_BUFFER_SIZE];
        long count = 0;
        int n = 0;
        while (-1 != (n = input.read(buffer))) {
            output.write(buffer, 0, n);
            count += n;
        }
        return count;
	}
.
.
.

Liebe Grüße,
Florian
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
W Servlet SPEICHERN UNTER-Dialog für mehrere Dateien Web Tier 4
E Java Servlet doPost request, Mehrere Parameter mit demselben Namen aus Tabellenzeilen Web Tier 2
R servlet-mapping führt zu 404-Fehlern Web Tier 0
B Servlet mit TomCat9 Web Tier 0
A redirect mit servlet-mapping in web.xml Web Tier 4
J Wie Mouse Event in Servlet einbinden? Web Tier 1
D JSF Servlet Mapping Web Tier 3
J Session Servlet - JavaScript Web Tier 6
D Servlet 1 Servlet für alles - Wie Cookies per Ajax? Web Tier 1
S Problem mit Checkboxen im Servlet erkennen Web Tier 3
Todesbote Servlet MVC Design Pattern Web Tier 1
A Anfänger-Frage Servlet/Applet/JSP Web Tier 0
Shams Allgemeine Verständnisfrage zum Thema Servlet (in Vaadin) Web Tier 2
H File Output Servlet Web Tier 6
I vTiger Astersik Connector: NO JSP Support for , did not find org.apache.jasper.servlet.JspServlet Web Tier 0
OnDemand Servlet oder JSP Web Tier 12
H Servlet/JSP und OSGI Web Tier 2
L Servlet Datenbank Web Tier 0
D Java EE Servlet login Problem Web Tier 1
A Faces Context nicht mehr erreichbar nach Servlet Aufruf Web Tier 1
S Java Bean und Java Servlet Web Tier 2
D Servlet Servlet Weiterleitung static html Web Tier 5
G GWT 404 - Servlet nicht gefunden Web Tier 6
H Applet wirft AccessControlException bei File von Servlet Web Tier 3
H Servlet lässt sich nicht deployen Web Tier 7
C Kommunkation Servlets/Browseraufruf Servlet Web Tier 4
F.S.WhiTeY Servlet Servlet wird nicht angesprochen Web Tier 3
J Servlet Zugriff Servlet Web Tier 11
A JSON von JavaScript an Servlet Web Tier 9
K Servlet + JSP: JSP-Seite ein Array/ArrayList überliefern vom Controller-Servlet Web Tier 8
0 Servlet.Properties Web Tier 3
P Servlet Wo gibt es das javax.servlet.Servlet? Web Tier 2
H Servlet Servlet nimmt HTTP-GET mit Parameter entgegen Web Tier 2
5 Bild Pfad Servlet Web Tier 2
D Datenbankzugriff im Servlet Web Tier 5
H Servlet Apache Geronimo: Servlet nicht erreichbar Web Tier 2
S Ich brauche Buchempfehlung über JSP und Servlet Web Tier 2
A Parameterübergabe an Servlet und Aufruf von Servlets per Java Code Web Tier 7
S Auswahl eine Zeile von einer HTML Tabelle im Servlet Web Tier 4
K Servlet URL Mapping Web Tier 3
S ClassPath für Servlet Web Tier 3
reibi Servlet Logging - Standard Servlet Web Tier 5
K Portlet, Servlet doGet und doPost Web Tier 4
reibi Servlet Alleinlaufendes Servlet bauen Web Tier 6
P Servlet wird nicht gefunden - HTTP Error 503 Web Tier 7
lukas24680 Servlet pro Request Web Tier 2
C Pageing mit JSp&Servlet Web Tier 5
D JSP JSP integriert ein Servlet... Wie? Web Tier 7
I Servlet vor Browser URL-Direktzugriff schützen Web Tier 3
N Servlet ausführen Web Tier 26
B statische Html Seite als response erhalten (Servlet) Web Tier 3
A javax/servlet/jsp/jstl/core/Config Web Tier 1
F Servlet mapping ;-) Web Tier 3
H Servlet Mapping mit JSF Web Tier 8
B (JSP)+(Struts2)+(Servlet) Konfiguration web.xml Web Tier 2
W MVC mit Bean, JSP und Servlet Web Tier 6
T Button im Servlet - Werte übergeben Web Tier 2
J werte per post an servlet übergeben und auswerten Web Tier 3
ruutaiokwu HttpServletRequest-instanz in servlet und JSP unterschiedlich? Web Tier 5
T Bild durch anderes Bild ersetzen mit Servlet Web Tier 3
E Mein erstes Servlet Web Tier 8
S Servlet automatisch aufrufen Web Tier 2
J Kommunikation zwischen Servlet und EJB Web Tier 6
C Image in Servlet Web Tier 2
S Servlet File Upload (API oder JSPSmart download) Web Tier 4
N API Nutzung SERVLET Web Tier 12
J Memory Leak in Servlet nach längere Laufzeit Web Tier 6
ruutaiokwu template engine gesucht ohne abhängigkeit zum servlet container Web Tier 2
G Servlet Ausgabe richtig benutzen Web Tier 4
W Servlet auf sich selbst verweisen lassen (Anfängerfrage) Web Tier 6
M Servlet Ausführungsfehler Web Tier 4
D Servlet alle 6h ausführen Web Tier 5
M Servlet & JSP Organisation Web Tier 2
J seltsames Auslastungsproblem bei Servlet Web Tier 7
ruutaiokwu JSF - läuft ausserhalb des servlet-containers? Web Tier 5
R Direkten Servlet-Aufruf verhindern (JSP) Web Tier 3
K Formularweiterleitung an Servlet Web Tier 5
N Servlet: Problem mit getParameterValues Web Tier 4
J Dateiupload- Servlet Web Tier 14
H Probleme beim Aufrufen von Java- oder Servlet-Methoden aus Javascript Web Tier 2
G Kommunikation Servlet + Applikation Web Tier 4
megachucky Welche Servlet-Version benötigt GWT 2.0? Web Tier 13
X Servlet Select box Web Tier 6
S Java Servlet Content Type Web Tier 3
M Servlet neuladen Web Tier 2
H Wie wurde ein Servlet aufgerufen Web Tier 2
J Servlet soll XML ausgeben und Javascript soll dieses einlesen Web Tier 3
H servlet fehlermeldung Web Tier 3
W JSP/Servlet Web Applikation programmierung Web Tier 9
J Faces response aus einem anderen Servlet heraus rendern Web Tier 4
E Servlet mit einem Link aufrufen? Web Tier 13
D Servlet FacesServlet is not available und Web Tier 3
S servlet bedienen mit get und post parameter Web Tier 10
S Laden von globalen Resourcen im Servlet Container..? Web Tier 3
T JBoss + Servlet + HTML Fileupload + Encoding Web Tier 1
2 Servlet: Pfad zu Webcontent Web Tier 6
J Servlet Sicherheit Web Tier 4
J struts2: vom value stack zum servlet Web Tier 14
D Servlet-Klassen und Templates trennen? Web Tier 18
MQue Servlet destroy Web Tier 11

Ähnliche Java Themen

Neue Themen


Oben