JasperReport usage

jasperreport tools enhance and solve the report issue for your web
一.设计jasperreport报表,编译jasperreport的jasper文件,制作jasper文件用的是IReport的一个工具.基本流程就是:
1.建立数据库连接,我们使用了mysql的数据库
2.利用向导生成xml文件.向导上的内容比较简单清楚,关键是字段的引用.
3.保存后,编译可以得到jasper文件,运行可以看到效果.
二.加入应用
一个很简单的测试.在我们自己的项目中加入报表功能.大致步骤如下:
1.将相关的库放入项目的lib目录,这些库包括jasperreports.jar,bsh.jar,itext.jar
2.在web应用的根目录下建立Reports目录,将刚刚生成的jasper文件拷贝至该文件夹.
3.建立一个网页,作一个有提交按钮的简单网页即可.提交后由servlet处理.
4.servlet的内容: 以下只写了doGet的函数
java 代码
  1. package com.aaron.kemet.servlet;   
  2.   
  3. import java.io.File;   
  4. import java.io.IOException;   
  5. import java.sql.Connection;   
  6. import java.sql.DriverManager;   
  7. import java.util.HashMap;   
  8. import java.util.Map;   
  9.   
  10. import javax.servlet.ServletContext;   
  11. import javax.servlet.ServletException;   
  12. import javax.servlet.ServletOutputStream;   
  13. import javax.servlet.http.HttpServlet;   
  14. import javax.servlet.http.HttpServletRequest;   
  15. import javax.servlet.http.HttpServletResponse;   
  16.   
  17. import net.sf.jasperreports.engine.JRException;   
  18. import net.sf.jasperreports.engine.JasperRunManager;   
  19.   
  20. /**  
  21.  *   
  22.  * @author Aaron  
  23.  * JasperReport   
  24.  *  
  25.  */  
  26. public class ReportServlet extends HttpServlet {   
  27.   
  28.     private static final long serialVersionUID = 1L;   
  29.   
  30.     public void doGet(HttpServletRequest request, HttpServletResponse response)   
  31.             throws ServletException, IOException {   
  32.         response.setContentType("application/pdf");   
  33.         response.setHeader("Content-disposition","inline; filename=classic.pdf" );   
  34.         Connection conn = null;   
  35.         try {   
  36.             Class.forName("com.mysql.jdbc.Driver");   
  37.             conn = DriverManager.getConnection("jdbc:mysql://localhost/maxtor","nike""bogie");   
  38.             ServletContext servletContext = this.getServletContext();   
  39.             File reportFile = new File(servletContext.getRealPath("Report/classic.jasper"));   
  40.             Map<String,Integer> parameters = new HashMap<String,Integer>();   
  41.             Integer i=new Integer(1);    
  42.             parameters.put("JPID", i);   
  43.             byte[] bytes = JasperRunManager.runReportToPdf(reportFile.getPath(), parameters, conn);   
  44.                
  45.             response.setContentLength(bytes.length);   
  46.             ServletOutputStream ouputStream = response.getOutputStream();   
  47.             ouputStream.write(bytes, 0, bytes.length);   
  48.             ouputStream.flush();   
  49.             ouputStream.close();   
  50.         } catch (JRException jre) {   
  51.             System.out.println("JRException:" + jre.getMessage());   
  52.         } catch (Exception e) {   
  53.             System.out.println("Exception:" + e.getMessage());   
  54.         }   
  55.     }   
  56. }   

你可能感兴趣的:(java,sql,mysql,servlet,jdbc)