<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 閱讀(649) 評(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)論排行榜

    主站蜘蛛池模板: 国产亚洲AV无码AV男人的天堂| 精品免费国产一区二区| 亚洲色成人中文字幕网站| 免费人成大片在线观看播放电影| 在线免费观看一级片| 亚洲欧美综合精品成人导航| 成人au免费视频影院| 亚洲av无码一区二区三区在线播放| 日韩电影免费在线| 国产精品亚洲二区在线| 亚洲人成电影在线播放| 久草免费福利在线| 亚洲韩国精品无码一区二区三区| 久久精品免费观看| 7777久久亚洲中文字幕蜜桃 | 亚洲综合激情另类小说区| 亚洲电影在线免费观看| 亚洲国产精品综合一区在线| 免费av欧美国产在钱| 亚洲AV无码国产一区二区三区 | 日韩成人免费视频| 亚洲福利视频网站| 免费无码黄十八禁网站在线观看| 亚洲国产成人久久综合| 亚洲性在线看高清h片| 日本一道本不卡免费 | 6080午夜一级毛片免费看6080夜福利| 亚洲国产精品白丝在线观看| 成人在线免费观看| 国产精品免费久久久久久久久| 亚洲91av视频| 国外成人免费高清激情视频| CAOPORM国产精品视频免费| 亚洲三级电影网站| 成人免费视频国产| 少妇性饥渴无码A区免费 | 国产精品成人亚洲| 久久久久亚洲AV成人无码| 成年轻人网站色免费看| 国产免费久久精品丫丫| 亚洲国产成人超福利久久精品|