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

Jasper Discussion :

[Java] Générer un rapport PDF avec Jasper Report et iReport


Sujet :

Jasper

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    septembre 2003
    Messages
    90
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : septembre 2003
    Messages : 90
    Points : 53
    Points
    53
    Par défaut [Java] Générer un rapport PDF avec Jasper Report et iReport
    Bonjour,

    J'ai lu l'article.
    Je ne connais que trop peu Java. J'ai voulu faire un essai de cette librairie pour voir ce qu'il était possible de faire grace à Japser.


    J'ai suivi le tuto à la lettre. J'ai modifier 2/3 trucs pour que ca puisse logiquement fonctionner en utilisant Oracle en lieu et place de Mysql.
    Voici le code complet que j'ai utiliser pour ma classe GeneratePDF :

    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
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
     
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.SQLException;
    import java.util.HashMap;
    import java.util.Map;
     
    import net.sf.jasperreports.engine.JRException;
    import net.sf.jasperreports.engine.JasperCompileManager;
    import net.sf.jasperreports.engine.JasperExportManager;
    import net.sf.jasperreports.engine.JasperFillManager;
    import net.sf.jasperreports.engine.JasperPrint;
    import net.sf.jasperreports.engine.JasperReport;
    import net.sf.jasperreports.engine.design.JasperDesign;
    import net.sf.jasperreports.engine.xml.JRXmlLoader;
     
    import oracle.jdbc.driver.OracleDriver;
     
    public class GeneratePDF {
     
        public static void main(String[] args) {
     
            // - Paramètres de connexion à la base de données
            String url = "jdbc:oracle:thin:@XXX.XXX.XXX.XXX:YYYY:mybase";
            String login = "mylogin";
            String password = "mypassword";
     
            Connection connection = null;                
        try {
            // - Connexion à la base
        	OracleDriver monDriver = new oracle.jdbc.driver.OracleDriver();
            DriverManager.registerDriver(monDriver);
            connection = DriverManager.getConnection(url, login, password);
     
            // - Chargement et compilation du rapport
            JasperDesign jasperDesign = JRXmlLoader.load("C:\\classic.jrxml");
            JasperReport jasperReport = JasperCompileManager.compileReport(jasperDesign);
     
            // - Paramètres à envoyer au rapport
            Map parameters = new HashMap();
            parameters.put("Titre", "Titre");
     
            // - Execution du rapport
            JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, parameters, connection);
     
            // - Création du rapport au format PDF
            JasperExportManager.exportReportToPdfFile(jasperPrint, "C:\\classic.pdf");
        } catch (JRException e) {
     
            e.printStackTrace();
        } catch (SQLException e) {
     
            e.printStackTrace();
        } finally {
            connection.close();
        }
        }
    }
    Déjà Eclipse me dit dans Problems :
    connection ne peut pas être résolu
    Il m'indique ceci sur la ligne "connection.close();"

    Si je compile et démarre Generate.java comme indiqué dans le tuto,

    j'obtiens:
    Exception in thread "main" java.lang.Error: Problème de compilation non résolu :
    connection ne peut pas être résolu

    at GeneratePDF.main(GeneratePDF.java:53)
    Si je mets le "connection.close();" en commentaire et que j'execute, j'obtiens :
    java.io.IOException: CreateProcess: javac -classpath "C:\Documents and Settings\chtom\workspace\JasperTest\bin;C:\Documents and Settings\chtom\workspace\JasperTest\lib\classes12.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\commons-beanutils-1.5.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\commons-collections-2.1.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\commons-digester-1.7.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\commons-logging-1.0.2.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\commons-logging-api-1.0.2.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\itext-1.3.1.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\jasperreports-1.2.5.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\ojdbc14.jar" "C:\Documents and Settings\chtom\workspace\JasperTest\classic_1153310463593_477980.java" error=2
    at java.lang.ProcessImpl.create(Native Method)
    at java.lang.ProcessImpl.<init>(Unknown Source)
    at java.lang.ProcessImpl.start(Unknown Source)
    at java.lang.ProcessBuilder.start(Unknown Source)
    at java.lang.Runtime.exec(Unknown Source)
    at java.lang.Runtime.exec(Unknown Source)
    at net.sf.jasperreports.engine.design.JRJavacCompiler.compileClasses(JRJavacCompiler.java:62)
    at net.sf.jasperreports.engine.design.JRAbstractClassCompiler.compileUnits(JRAbstractClassCompiler.java:67)
    at net.sf.jasperreports.engine.design.JRAbstractCompiler.compileReport(JRAbstractCompiler.java:189)
    at net.sf.jasperreports.engine.design.JRDefaultCompiler.compileReport(JRDefaultCompiler.java:105)
    at net.sf.jasperreports.engine.JasperCompileManager.compileReport(JasperCompileManager.java:211)
    at GeneratePDF.main(GeneratePDF.java:35)

    NESTED BY :
    java.io.IOException: CreateProcess: javac -classpath "C:\Documents and Settings\chtom\workspace\JasperTest\bin;C:\Documents and Settings\chtom\workspace\JasperTest\lib\classes12.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\commons-beanutils-1.5.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\commons-collections-2.1.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\commons-digester-1.7.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\commons-logging-1.0.2.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\commons-logging-api-1.0.2.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\itext-1.3.1.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\jasperreports-1.2.5.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\ojdbc14.jar" "C:\Documents and Settings\chtom\workspace\JasperTest\classic_1153310463593_477980.java" error=2
    at java.lang.ProcessImpl.create(Native Method)
    at java.lang.ProcessImpl.<init>(Unknown Source)
    at java.lang.ProcessImpl.start(Unknown Source)
    at java.lang.ProcessBuilder.start(Unknown Source)
    at java.lang.Runtime.exec(Unknown Source)
    at java.lang.Runtime.exec(Unknown Source)
    at net.sf.jasperreports.engine.design.JRJavacCompiler.compileClasses(JRJavacCompiler.java:62)
    at net.sf.jasperreports.engine.design.JRAbstractClassCompiler.compileUnits(JRAbstractClassCompiler.java:67)
    at net.sf.jasperreports.engine.design.JRAbstractCompiler.compileReport(JRAbstractCompiler.java:189)
    at net.sf.jasperreports.engine.design.JRDefaultCompiler.compileReport(JRDefaultCompiler.java:105)
    at net.sf.jasperreports.engine.JasperCompileManager.compileReport(JasperCompileManager.java:211)
    at GeneratePDF.main(GeneratePDF.java:35)

    NESTED BY :
    net.sf.jasperreports.engine.JRException: Error compiling report java source files : C:\Documents and Settings\chtom\workspace\JasperTest\classic_1153310463593_477980.java
    at net.sf.jasperreports.engine.design.JRJavacCompiler.compileClasses(JRJavacCompiler.java:93)
    at net.sf.jasperreports.engine.design.JRAbstractClassCompiler.compileUnits(JRAbstractClassCompiler.java:67)
    at net.sf.jasperreports.engine.design.JRAbstractCompiler.compileReport(JRAbstractCompiler.java:189)
    at net.sf.jasperreports.engine.design.JRDefaultCompiler.compileReport(JRDefaultCompiler.java:105)
    at net.sf.jasperreports.engine.JasperCompileManager.compileReport(JasperCompileManager.java:211)
    at GeneratePDF.main(GeneratePDF.java:35)
    Caused by: java.io.IOException: CreateProcess: javac -classpath "C:\Documents and Settings\chtom\workspace\JasperTest\bin;C:\Documents and Settings\chtom\workspace\JasperTest\lib\classes12.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\commons-beanutils-1.5.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\commons-collections-2.1.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\commons-digester-1.7.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\commons-logging-1.0.2.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\commons-logging-api-1.0.2.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\itext-1.3.1.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\jasperreports-1.2.5.jar;C:\Documents and Settings\chtom\workspace\JasperTest\lib\ojdbc14.jar" "C:\Documents and Settings\chtom\workspace\JasperTest\classic_1153310463593_477980.java" error=2
    at java.lang.ProcessImpl.create(Native Method)
    at java.lang.ProcessImpl.<init>(Unknown Source)
    at java.lang.ProcessImpl.start(Unknown Source)
    at java.lang.ProcessBuilder.start(Unknown Source)
    at java.lang.Runtime.exec(Unknown Source)
    at java.lang.Runtime.exec(Unknown Source)
    at net.sf.jasperreports.engine.design.JRJavacCompiler.compileClasses(JRJavacCompiler.java:62)
    ... 5 more
    Je débute complétement en Java.
    Mon but étant d'avoir un editeur de report gratuit (iReport) et d'executer des reports pré-établi en passant des paramètres à partir de PHP.
    Si vous avez des solutions plus simple que de passer par un serveur d'application java, je suis preneur.

    Merci de m'avoir lu jusqu'au bout

  2. #2
    Membre habitué Avatar de agougeon
    Inscrit en
    mai 2005
    Messages
    253
    Détails du profil
    Informations forums :
    Inscription : mai 2005
    Messages : 253
    Points : 147
    Points
    147
    Par défaut
    Bonjour,
    J'ai la meme erreur.... il y a t'il une solution?
    Merci

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    mars 2006
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : mars 2006
    Messages : 10
    Points : 10
    Points
    10
    Par défaut
    Il manque sans doute la librairie jdt-compiler.jar qui est essentiel pour développer sous eclipse.

  4. #4
    Membre expérimenté
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    avril 2003
    Messages
    1 292
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Service public

    Informations forums :
    Inscription : avril 2003
    Messages : 1 292
    Points : 1 376
    Points
    1 376
    Par défaut
    Je pense aussi qu'il s'agit de classpath j'ai souvent dû le modifier pour JaspertReports.
    Christophe

    Pensez à mettre quand c'est le cas.

  5. #5
    Nouveau Candidat au Club
    Inscrit en
    mai 2007
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : mai 2007
    Messages : 1
    Points : 1
    Points
    1
    Par défaut
    Il y a un jar présent dans le dossier d'install de jasper ireport à inclure en plus dans le classpath :
    jdt-compiler-3.1.1.jar

  6. #6
    Futur Membre du Club
    Inscrit en
    juillet 2005
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : juillet 2005
    Messages : 9
    Points : 5
    Points
    5
    Par défaut
    Merci beaucoup vash06 ! deepuis le temps que je n'y comprenais rien ...

  7. #7
    Rédacteur
    Avatar de JauB
    Homme Profil pro
    Freelancer
    Inscrit en
    octobre 2005
    Messages
    1 785
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Maroc

    Informations professionnelles :
    Activité : Freelancer
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : octobre 2005
    Messages : 1 785
    Points : 2 912
    Points
    2 912
    Par défaut
    Déjà quel article tu as suivi?tu n'as pas mis de lien à ce que je sache!
    pour le connection ne peut pas être résolu tu es sûr d'avoir ajouté le JAR de ton driver d'ORACLE au CLASSPATH?

    Citation Envoyé par chtom Voir le message
    Bonjour,

    J'ai lu l'article.
    Je ne connais que trop peu Java. J'ai voulu faire un essai de cette librairie pour voir ce qu'il était possible de faire grace à Japser.


    J'ai suivi le tuto à la lettre. J'ai modifier 2/3 trucs pour que ca puisse logiquement fonctionner en utilisant Oracle en lieu et place de Mysql.
    Voici le code complet que j'ai utiliser pour ma classe GeneratePDF :

    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
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
     
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.SQLException;
    import java.util.HashMap;
    import java.util.Map;
     
    import net.sf.jasperreports.engine.JRException;
    import net.sf.jasperreports.engine.JasperCompileManager;
    import net.sf.jasperreports.engine.JasperExportManager;
    import net.sf.jasperreports.engine.JasperFillManager;
    import net.sf.jasperreports.engine.JasperPrint;
    import net.sf.jasperreports.engine.JasperReport;
    import net.sf.jasperreports.engine.design.JasperDesign;
    import net.sf.jasperreports.engine.xml.JRXmlLoader;
     
    import oracle.jdbc.driver.OracleDriver;
     
    public class GeneratePDF {
     
        public static void main(String[] args) {
     
            // - Paramètres de connexion à la base de données
            String url = "jdbc:oracle:thin:@XXX.XXX.XXX.XXX:YYYY:mybase";
            String login = "mylogin";
            String password = "mypassword";
     
            Connection connection = null;                
        try {
            // - Connexion à la base
        	OracleDriver monDriver = new oracle.jdbc.driver.OracleDriver();
            DriverManager.registerDriver(monDriver);
            connection = DriverManager.getConnection(url, login, password);
     
            // - Chargement et compilation du rapport
            JasperDesign jasperDesign = JRXmlLoader.load("C:\\classic.jrxml");
            JasperReport jasperReport = JasperCompileManager.compileReport(jasperDesign);
     
            // - Paramètres à envoyer au rapport
            Map parameters = new HashMap();
            parameters.put("Titre", "Titre");
     
            // - Execution du rapport
            JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, parameters, connection);
     
            // - Création du rapport au format PDF
            JasperExportManager.exportReportToPdfFile(jasperPrint, "C:\\classic.pdf");
        } catch (JRException e) {
     
            e.printStackTrace();
        } catch (SQLException e) {
     
            e.printStackTrace();
        } finally {
            connection.close();
        }
        }
    }
    Déjà Eclipse me dit dans Problems :
    Il m'indique ceci sur la ligne "connection.close();"

    Si je compile et démarre Generate.java comme indiqué dans le tuto,

    j'obtiens:


    Si je mets le "connection.close();" en commentaire et que j'execute, j'obtiens :


    Je débute complétement en Java.
    Mon but étant d'avoir un editeur de report gratuit (iReport) et d'executer des reports pré-établi en passant des paramètres à partir de PHP.
    Si vous avez des solutions plus simple que de passer par un serveur d'application java, je suis preneur.

    Merci de m'avoir lu jusqu'au bout
    Mes articles, Mon Blog

    Rubrique Jasper/iReport :
    ------- Forum Jasper --------
    ----- FAQ Jasper/iReport -----


Discussions similaires

  1. Edition de rapport sur openERP 7 avec Jasper Reports
    Par LSDev_Noumea dans le forum Odoo (ex-OpenERP)
    Réponses: 4
    Dernier message: 25/04/2014, 19h54
  2. Erreur de compilation rapport java avec Jasper report
    Par Sylvies209 dans le forum NetBeans
    Réponses: 6
    Dernier message: 31/07/2010, 14h22
  3. Réponses: 1
    Dernier message: 24/05/2006, 18h29
  4. [CR][.Net] Exportation PDF avec Crystal Report
    Par SoaB dans le forum SAP Crystal Reports
    Réponses: 2
    Dernier message: 11/05/2005, 13h25
  5. [Java] Générer des rapports à la crystal reports
    Par Vessaz dans le forum Autres outils décisionnels
    Réponses: 4
    Dernier message: 11/10/2004, 19h07

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