IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Servlets/JSP Java Discussion :

afficher un fichier pdf enregistré dans une base dans une jsp


Sujet :

Servlets/JSP Java

  1. #1
    Membre régulier
    Inscrit en
    Octobre 2007
    Messages
    160
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 160
    Points : 77
    Points
    77
    Par défaut afficher un fichier pdf enregistré dans une base dans une jsp
    salut les gars ,
    je veux afficher un fichier pdf enregistré dans une base de données MySQL(c'est à dire que j'ai pas un fichier .pdf mais un objet de type File),
    je fais cela :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
     
    <%@ page language="java" contentType="text/html,application/pdf; charset=UTF-8" autoFlush="false" buffer="10000kb"
        pageEncoding="UTF-8" %>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <%@ page import = "ch.unige.cui.examples.spline_anim.ConnectionDao"%>
    <%@ page import = "java.sql.Connection"%>
    <%@ page import = "java.sql.PreparedStatement"%>
    <%@ page import = "java.sql.ResultSet"%>
    <%@ page language="java" session="false" %>
    <meta http-equiv="Content-Type" content="text/html,application/pdf; charset=UTF-8">
    <title>Insert title here</title>
    </head>
    <body>
    <%
    Connection conn = ConnectionDao.getConnection();
     
    PreparedStatement stmt = null;
    ResultSet rs = null;
    String fileId = (String)request.getParameter("name");
    String sqlQuery = "select f.file from File f where f.fileId="+fileId;
    try {
                /////////////
                    stmt = conn.prepareStatement(sqlQuery);
                    rs = stmt.executeQuery();
                    
                    rs.next();
                    %><%=rs.getString("file") %>
     	        	<%
                    rs.close();
                    stmt.close();
    } catch(Exception e){
              System.out.println(">>>>>>>>>>>>>>>>>>> getRelationshipWithRecurrence query exception : " + e.getMessage());
    }
     
     
    %>
    </body>
    </html>
    avec ce code, j'ai une page sous la forme d'un fichier pdf mais je ne sais pas pourquoi le fichier est vide !!!

  2. #2
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    C'est quoi ca pour un contentType?
    text/html,application/pdf
    C'est du html ou du pdf que t'essaie d'envoyer au client? Et ton file c'est quoi dans ta base de données, le non d'un fichier?

  3. #3
    Membre régulier
    Inscrit en
    Octobre 2007
    Messages
    160
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 160
    Points : 77
    Points
    77
    Par défaut
    merci pour ta réponse assez rapide,
    en fait t'as raison le contenttype c'est juste application/pdf; charset=UTF-8
    mais même avec ce changement ça marche pas,
    mon fichier en fait est dans une base de données MySQL de type longBlob

  4. #4
    Membre régulier
    Inscrit en
    Octobre 2007
    Messages
    160
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 160
    Points : 77
    Points
    77
    Par défaut
    C'est bon j'ai trouvé la solution :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
     
    Blob myblob = null;
    		String name = null;
    		ResultSet resultat = null;
    		Statement statement = null;
    		try{
    		//lien vers la base de données
    		Connection connection = ConnectionDao.getConnection();
    		statement= connection.createStatement();
    		String fileId = (String)request.getParameter("name");
    		String sql = "select f.file from File f where f.fileId="+fileId;
    		//préparation de l'instruction SQL
    		resultat = statement.executeQuery(sql);
     
    		//récupération de l'image (BLOB)
     
    		while(resultat.next()) {
    			myblob = resultat.getBlob("file");
    		}
    		}
    			catch(Exception e){
    			e.printStackTrace();}
     
    		BufferedInputStream bis =null;
    		BufferedOutputStream bos = null;
     
    		response.setContentType("application/pdf");
    		response.setHeader("Content-Disposition", "inline; filename=monFichier.pdf");
     
    		try{InputStream streamDuBlob = myblob.getBinaryStream();
     
    			bis = new BufferedInputStream(streamDuBlob);
    			bos = new BufferedOutputStream(response.getOutputStream());
    		}
    		catch(Exception e){
    			e.printStackTrace();
    		}
     
    		byte[] input = new byte[1024];
    		boolean eof = false;
    		while (!eof) {
    			int length = bis.read(input);
    			if (length == -1) {eof = true;}
    			else {bos.write(input, 0, length);}
    		}
    		bos.flush();
    j'espère que ça sera utile pour les autres
    ciao

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 3
    Dernier message: 24/07/2011, 00h06
  2. Réponses: 7
    Dernier message: 25/03/2011, 10h52
  3. Copie d'une table d'une base dans une autre
    Par LDPDC dans le forum Oracle
    Réponses: 3
    Dernier message: 21/04/2009, 16h40
  4. Réponses: 7
    Dernier message: 22/01/2009, 09h39
  5. Copier une table d'une base dans une autre
    Par Ste20 dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 15/10/2007, 16h36

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo