<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    spring 生成Excel和PDF文件

    HTML頁面并不總是向用戶顯示數(shù)據(jù)輸出的最好方式,有時(shí)候需要生成不可改變的文件打印,PDF可能是種不錯(cuò)的選擇。

    Spring支持從數(shù)據(jù)動(dòng)態(tài)生成PDF或Excel文件

    下面這個(gè)簡單實(shí)現(xiàn)的例子實(shí)現(xiàn)了spring輸出PDF和Excel文件,為了使用Excel電子表格,你需要在你的classpath中加入poi-2.5.1.jar庫文件,而對(duì)PDF文件,則需要iText.jar文件。它們都包含在Spring的主發(fā)布包中。

    下面是測(cè)試項(xiàng)目代碼:


    1、控制器配置代碼
    <?xml?version="1.0"?encoding="UTF-8"?>
    <!DOCTYPE?beans?PUBLIC?"-//SPRING//DTD?BEAN//EN"?"http://www.springframework.org/dtd/spring-beans.dtd">

    <beans>
    ????
    <bean?id="beanNameViewResolver"
    ????????class
    ="org.springframework.web.servlet.view.BeanNameViewResolver"?/>

    ????
    <bean?id="viewController"?class="com.zhupan.spring.ViewController"?/>
    ????
    <bean?id="urlMapping"
    ????????class
    ="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
    ????????
    <property?name="mappings">
    ????????????
    <props>
    ????????????????
    <prop?key="/view*.shtml">viewController</prop>
    ????????????
    </props>
    ????????
    </property>
    ????
    </bean>
    </beans>

    ?3、用于Excel視圖的視圖子類化
    為了在生成輸出文檔的過程中實(shí)現(xiàn)定制的行為,我們將繼承合適的抽象類。對(duì)于Excel,這包括提供一個(gè) org.springframework.web.servlet.view.document.AbstractExcelView的子類,并實(shí)現(xiàn) buildExcelDocument方法。
    package?com.zhupan.view;

    import?java.util.Date;
    import?java.util.Map;
    import?javax.servlet.http.HttpServletRequest;
    import?javax.servlet.http.HttpServletResponse;

    import?org.apache.poi.hssf.usermodel.HSSFCell;
    import?org.apache.poi.hssf.usermodel.HSSFCellStyle;
    import?org.apache.poi.hssf.usermodel.HSSFDataFormat;
    import?org.apache.poi.hssf.usermodel.HSSFRow;
    import?org.apache.poi.hssf.usermodel.HSSFSheet;
    import?org.apache.poi.hssf.usermodel.HSSFWorkbook;
    import?org.springframework.web.servlet.view.document.AbstractExcelView;


    public?class?ViewExcel?extends?AbstractExcelView?{

    ??
    public?void?buildExcelDocument(
    ?????????????Map?model,?HSSFWorkbook?workbook,
    ?????????????HttpServletRequest?request,?HttpServletResponse?response)
    ????
    throws?Exception?{
    ??
    ???????HSSFSheet?sheet?
    =?workbook.createSheet("list");
    ???????sheet.setDefaultColumnWidth((
    short)?12);
    ???????
    ???????
    ???????HSSFCell?cell?
    =?getCell(sheet,?0,?0);
    ???????setText(cell,?
    "Spring?Excel?test");
    ??
    ???????HSSFCellStyle?dateStyle?
    =?workbook.createCellStyle();
    ???????dateStyle.setDataFormat(HSSFDataFormat.getBuiltinFormat(
    "m/d/yy"));
    ???????cell?
    =?getCell(sheet,?1,?0);
    ???????cell.setCellValue(
    new?Date());
    ???????cell.setCellStyle(dateStyle);
    ???????getCell(sheet,?
    2,?0).setCellValue(458);
    ??
    ???????HSSFRow?sheetRow?
    =?sheet.createRow(3);
    ???????
    for?(short?i?=?0;?i?<?10;?i++)?{
    ?????????????sheetRow.createCell(i).setCellValue(i?
    *?10);
    ???????}


    ??}

    ??
    }


    4、用于PDF視圖的視圖子類化
    需要象下面一樣繼承org.springframework.web.servlet.view.document.AbstractPdfView,并實(shí)現(xiàn)buildPdfDocument()方法。
    package?com.zhupan.view;

    import?java.util.List;
    import?java.util.Map;

    import?javax.servlet.http.HttpServletRequest;
    import?javax.servlet.http.HttpServletResponse;

    import?org.springframework.web.servlet.view.document.AbstractPdfView;

    import?com.lowagie.text.Document;
    import?com.lowagie.text.Paragraph;
    import?com.lowagie.text.pdf.PdfWriter;

    public?class?ViewPDF?extends?AbstractPdfView?{
    ????
    public?void?buildPdfDocument(Map?model,?Document?document,
    ????????????PdfWriter?writer,?HttpServletRequest?request,
    ????????????HttpServletResponse?response)?
    throws?Exception?{

    ????????List?list?
    =?(List)?model.get("list");

    ????????
    for?(int?i?=?0;?i?<?list.size();?i++)
    ????????????document.add(
    new?Paragraph((String)?list.get(i)));
    ????}


    }

    5、其他文件
    1)控制器ViewController
    package?com.zhupan.spring;

    import?java.util.ArrayList;
    import?java.util.HashMap;
    import?java.util.List;
    import?java.util.Map;

    import?javax.servlet.http.HttpServletRequest;
    import?javax.servlet.http.HttpServletResponse;

    import?org.springframework.web.servlet.ModelAndView;
    import?org.springframework.web.servlet.mvc.multiaction.MultiActionController;

    import?com.zhupan.view.ViewExcel;
    import?com.zhupan.view.ViewPDF;


    public?class?ViewController?extends?MultiActionController{
    ?????
    ?????
    public?ModelAndView?viewPDF(HttpServletRequest?request,?HttpServletResponse?response)?throws?Exception?{
    ???????List?list?
    =?new?ArrayList();
    ???????Map?model
    =new?HashMap();
    ???????list.add(
    "test1");
    ???????list.add(
    "test2");
    ???????model.put(
    "list",list);
    ???????ViewPDF?viewPDF
    =new?ViewPDF();
    ???????
    return?new?ModelAndView(viewPDF,model);
    ??}

    ?????
    ??????
    public?ModelAndView?viewExcel(HttpServletRequest?request,?HttpServletResponse?response)?throws?Exception?{
    ????????????List?list?
    =?new?ArrayList();
    ????????Map?model
    =new?HashMap();
    ????????list.add(
    "test1");
    ????????list.add(
    "test2");
    ????????model.put(
    "list",list);
    ????????ViewExcel?viewExcel
    =new?ViewExcel();
    ????????
    return?new?ModelAndView(viewExcel,model);
    ??????}

    }
    2)web.xml
    <?xml?version="1.0"?encoding="UTF-8"?>
    <web-app?version="2.4"?xmlns="http://java.sun.com/xml/ns/j2ee"
    ????xmlns:xsi
    ="http://www.w3.org/2001/XMLSchema-instance"
    ????xsi:schemaLocation
    ="http://java.sun.com/xml/ns/j2ee?
    ????http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
    >

    ????
    <display-name>springPDFTest</display-name>
    ????
    <servlet>
    ????????
    <servlet-name>springPDFTest</servlet-name>
    ????????
    <servlet-class>
    ????????????org.springframework.web.servlet.DispatcherServlet
    ????????
    </servlet-class>
    ????????
    <load-on-startup>1</load-on-startup>
    ????
    </servlet>

    ????
    <servlet-mapping>
    ????????
    <servlet-name>springPDFTest</servlet-name>
    ????????
    <url-pattern>*.shtml</url-pattern>
    ????
    </servlet-mapping>

    ????
    <welcome-file-list>
    ????????
    <welcome-file>index.jsp</welcome-file>
    ????
    </welcome-file-list>

    </web-app>

    3)index.jsp
    <%@?page?contentType="text/html;?charset=gb2312"%>

    <a?href="viewPDF.shtml">PDF視圖打開?</a>
    <br>
    <a?href="viewExcel.shtml">Excel視圖打開</a>


    posted on 2006-10-07 13:29 nbt 閱讀(640) 評(píng)論(0)  編輯  收藏 所屬分類: Spring框架

    <2006年10月>
    24252627282930
    1234567
    891011121314
    15161718192021
    22232425262728
    2930311234

    導(dǎo)航

    統(tǒng)計(jì)

    常用鏈接

    留言簿(3)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    相冊(cè)

    收藏夾

    Java技術(shù)網(wǎng)站

    友情鏈接

    國內(nèi)一些開源網(wǎng)站

    最新隨筆

    搜索

    積分與排名

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

    主站蜘蛛池模板: 亚洲精品无播放器在线播放| 免费无码一区二区| 丰满妇女做a级毛片免费观看 | 亚洲Av永久无码精品黑人| 亚洲AV无码专区在线播放中文| 999久久久免费精品播放| 亚洲国产精品yw在线观看| 成人免费视频小说| 蜜桃AV无码免费看永久| 免费无码又爽又刺激一高潮| 亚洲第一页综合图片自拍| 91免费资源网站入口| 99re在线视频免费观看| 国产猛男猛女超爽免费视频| 无码AV动漫精品一区二区免费| 亚洲爆乳少妇无码激情| 亚洲精品456人成在线| 亚洲精品和日本精品| 女人被男人桶得好爽免费视频| 国产免费区在线观看十分钟| 1区1区3区4区产品亚洲| 亚洲av无码成h人动漫无遮挡| 久久久久噜噜噜亚洲熟女综合 | 国产成人亚洲精品91专区高清| 国产成人亚洲综合一区| 亚洲国产成人99精品激情在线| 亚洲日韩VA无码中文字幕| 亚洲av无码成人精品区在线播放| 99re免费99re在线视频手机版| 免费人成黄页在线观看日本| 永久免费av无码网站yy| 美女视频黄a视频全免费网站色窝| 亚洲最大的成人网| 亚洲欧美日韩中文字幕一区二区三区 | 亚洲动漫精品无码av天堂| 成人亚洲性情网站WWW在线观看 | 免费无码又爽又刺激一高潮| 亚洲日本VA午夜在线影院| 亚洲欧美日韩综合久久久久| 国产成人亚洲精品电影| 亚欧洲精品在线视频免费观看 |