【问题标题】:ireport 3.7.4 on netbeans 6.9.1 won't executenetbeans 6.9.1 上的 ireport 3.7.4 不会执行
【发布时间】:2011-10-19 06:57:40
【问题描述】:

我是 java 和 jasperreport 的新手。我很难执行一个小报告。我已经添加了所有必需的 jar 文件并且没有遇到任何错误。

如何使用 netbeans 自动生成的 jbutton 的“mouseclicked”事件生成 pdf 文件? 以下是我在 thainetbeans 和 ireport 教程网站上编写的代码:

import net.sf.jasperreports.engine.*;
import net.sf.jasperreports.engine.design.*;
import net.sf.jasperreports.view.*;
import net.sf.jasperreports.engine.xml.*;

public class MyiReportViewer extends javax.swing.JFrame {

    /** Creates new form MyiReportViewer */
    final String JDBC = "com.mysql.jdbc.Driver";
    final String DB = "jdbc:mysql://localhost/afemdb?user=root&password";
    private Connection con;
    /** Creates new form NewJPanel */
    public MyiReportViewer() {
        initComponents();
        try{
            Class.forName(JDBC).newInstance();
             con =DriverManager.getConnection(DB);
        }
        catch(Exception e){

        }
    }

    /** This method is called from within the constructor to
     * initialize the form.
     * WARNING: Do NOT modify this code. The content of this method is
     * always regenerated by the Form Editor.
     */
    @SuppressWarnings("unchecked")
    // <editor-fold defaultstate="collapsed" desc="Generated Code">                          
    private void initComponents() {

        jButton1 = new javax.swing.JButton();

        setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);

        jButton1.setText("jButton1");
        jButton1.addMouseListener(new java.awt.event.MouseAdapter() {
            public void mouseClicked(java.awt.event.MouseEvent evt) {
                jButton1MouseClicked(evt);
            }
        });
        jButton1.addActionListener(new java.awt.event.ActionListener() {
            public void actionPerformed(java.awt.event.ActionEvent evt) {
                jButton1ActionPerformed(evt);
            }
        });

        javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
        getContentPane().setLayout(layout);
        layout.setHorizontalGroup(
            layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGroup(layout.createSequentialGroup()
                .addGap(95, 95, 95)
                .addComponent(jButton1)
                .addContainerGap(230, Short.MAX_VALUE))
        );
        layout.setVerticalGroup(
            layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGroup(layout.createSequentialGroup()
                .addGap(72, 72, 72)
                .addComponent(jButton1)
                .addContainerGap(205, Short.MAX_VALUE))
        );

        pack();
    }// </editor-fold>                        


    private void jButton1MouseClicked(java.awt.event.MouseEvent evt) {                                      
        // TODO add your handling code here:
       try{
            //JasperDesign jasperDesign = JRXmlLoader.load("C:\\Documents and Settings\\Lelou\\Desktop\\presentation\\InstructorQuestionaire.jrxml");
            //JasperReport jasperReport = JasperCompileManager.compileReport(jasperDesign);
            //JasperViewer.viewReport(jasperPrint, true);


              JasperReport report = JasperCompileManager.compileReport("C:\\Documents and Settings\\Lelou\\Desktop\\presentation\\InstructorQuestionaire.jrxml");
              JasperPrint print = JasperFillManager.fillReport(report, null, con);
              JRViewer viewer = new JRViewer(print);
              viewer.setOpaque(true);
              viewer.setVisible(true);

            }
        catch(Exception e){

        }
    }                                     

    private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {                                         
            // TODO add your handling code here:
            // try{
           // JasperDesign jasperDesign = JRXmlLoader.load("C:\\Documents and Settings\\Lelou\\Desktop\\presentation\\InstructorQuestionaire.jrxml");
            // JasperReport jasperReport = JasperCompileManager.compileReport(jasperDesign);
           // JasperPrint  jasperPrint = JasperFillManager.fillReport(jasperReport, null, con);
           // JasperViewer.viewReport(jasperPrint, true);


          //JasperReport report = JasperCompileManager.compileReport("C:\\Documents and Settings\\Lelou\\Desktop\\presentation\\InstructorQuestionaire.jrxml");
          //JasperPrint print = JasperFillManager.fillReport(report,null, con);
          //JRViewer viewer = new JRViewer(print);
          //viewer.setOpaque(true);
          //viewer.setVisible(true);

          //  }
          // catch(Exception e){
          //}
    }                                        

    /**
    * @param args the command line arguments
    */
    public static void main(String args[]) {
        java.awt.EventQueue.invokeLater(new Runnable() {
            public void run() {
                new MyiReportViewer().setVisible(true);
            }
        });
    }

    // Variables declaration - do not modify                     
    private javax.swing.JButton jButton1;
    // End of variables declaration                   

}

【问题讨论】:

    标签: netbeans jasper-reports ireport netbeans-6.9 jbutton


    【解决方案1】:

    将此添加到您的 jButton1ActionPerformed 方法中。您不需要 MouseClickedEvent。

    try {
        URL reportFileURL = getClass().getResource("C:/Documents and Settings/Lelou/Desktop/presentation/InstructorQuestionaire.jrxml");
        File reportFile = new File(reportFileURL.toURI());
        JasperDesign jasperDesign = JRXmlLoader.load(reportFile);
        JasperReport jasperReport = JasperCompileManager.compileReport(jasperDesign);
        JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, null, con);
        JasperViewer jv = new JasperViewer(jasperPrint);
        JDialog viewer = new JDialog(this, "Batch Report", true);
        viewer.setBounds(jv.getBounds());
        viewer.getContentPane().add(jv.getContentPane());
        viewer.setResizable(true);
        viewer.setIconImage(jv.getIconImage());
        viewer.setVisible(true);
    } catch (JRException exc) {
       System.out.println(exc.getMessage());
    } catch (URISyntaxException exs) {
       System.out.println(exs.getMessage());
    } 
    

    (*) 注意路径名中的斜杠。摆脱双反斜杠!

    这是您的导入:

    import java.io.File;
    import java.net.URISyntaxException;
    import java.net.URL;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.SQLException;
    import javax.swing.JDialog;
    
    import net.sf.jasperreports.engine.JRException;
    import net.sf.jasperreports.engine.JasperCompileManager;
    import net.sf.jasperreports.engine.JasperFillManager;
    import net.sf.jasperreports.engine.JasperReport;
    import net.sf.jasperreports.engine.design.JasperDesign;
    import net.sf.jasperreports.engine.xml.JRXmlLoader;
    import net.sf.jasperreports.view.JasperViewer;
    import net.sf.jasperreports.engine.JasperPrint;
    

    这里是你需要的库(我使用 iReport 4.0.1):


    其中大部分都在这里:C:\Program Files\JasperSoft\iReport-4.0.1\ireport\modules\ext

    检查您的连接字符串。有疑问使用这个构造函数:

    public MyiReportViewer() {
        initComponents();
        try {
            Class.forName(JDBC);
            //con =DriverManager.getConnection(DB);
            try {
                con = DriverManager.getConnection(
                        "jdbc:mysql://localhost:3306/afemdb?useUnicode=true&characterEncoding=UTF-8",
                        "root", "password");
            } catch (SQLException e) {
                System.out.println("Con " + e);
            }
    
        } catch (ClassNotFoundException e) {
            System.out.println("SQL" + e);
        }
    }
    

    如果还是不行,那你的 iReport 肯定有问题。

    【讨论】:

    • 我需要导入一个包吗...得到这个错误符号:class URL URL reportFileURL = getClass().getResource("C:\\Documents and Settings\\Lelou\\Desktop\\演示文稿\\InstructorQuestionaire.jrxml");和符号: class URISyntaxException } catch (URISyntaxException exs) { 对我的布局道歉
    • 发生另一个错误...线程“AWT-EventQueue-0”中的异常 java.lang.NullPointerException...感谢 Costis 帮助我解决这个问题 ^^
    • LOC上没有错误...按下按钮后发生...输出错误太大,无法在此处发布...T_T
    • Con java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: YES) 你的权利......连接有问题......我会的明天去我的队友,他做了架构并要求正确的字符串..希望之后我的 ireport 会工作......再次感谢 Cotis 的详细帮助^^
    • 太棒了!如果连接正确,它将起作用。处理数据库时,切勿将 catch 块留空。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-07-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多