使用JSP代码写入Excel工作表时出错

时间:2013-09-14 12:37:45

标签: java xml jsp

我的目标是在excel表上加载用户输入的用户注释。为此我使用JSP代码如下: -

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<%@page import="java.io.*" %>
<%@page import="java.util.*" %>
<%@page import="org.apache.poi.hssf.usermodel.*" %>
<%@page import="org.apache.xerces.parsers.*" %>
<%@page import="org.w3c.dom.*"%>
<%@page import="javax.xml.parsers.*"%>
<%@page import="javax.xml.parsers.DocumentBuilder"%>
<%@page import="javax.xml.parsers.DocumentBuilderFactory"%>
<%@page import="javax.xml.parsers.ParserConfigurationException"%>
<%@page import="org.xml.sax.*"%>
<%@page import="java.sql.*" %>
<%!
    private String getTextContent(Node node) {
        Node child;
        String sContent = node.getNodeValue() != null ? node.getNodeValue() : "";

        NodeList nodes = node.getChildNodes();
        for (int i = 0; i < nodes.getLength(); i++) {
            child = nodes.item(i);
            sContent += child.getNodeValue() != null ? child.getNodeValue() : "";
            if (nodes.item(i).getChildNodes().getLength() > 0) {
                sContent += getTextContent(nodes.item(i));
            }
        }
        return sContent;
    }
//Function to build Excel file

    public HSSFWorkbook genExcel(String xmlString) {
        try {
//Objects for Excel generation
            HSSFWorkbook wb = new HSSFWorkbook();
            HSSFSheet spreadSheet = wb.createSheet("spreadSheet");
            HSSFRow row;
            HSSFCell cell;
HSSFSheet spreadSheet2 = wb.createSheet("About_ClearPeaks_Export2Excel");
            HSSFRow row2;
            HSSFCell cell2;
row2 = spreadSheet2.createRow(1);
 cell2 = row2.createCell((short)1);
 cell2.setCellValue("The ClearPeaks Export2Excel solution allows users to export data to Excel by using Tomcat server.");
row2 = spreadSheet2.createRow(2);
 cell2 = row2.createCell((short)1);
 cell2.setCellValue("Copyright (C) 2009  ClearPeaks");

row2 = spreadSheet2.createRow(4);
 cell2 = row2.createCell((short)1);
 cell2.setCellValue("Please credit ClearPeaks when you publish, use or distribute this solution.");
row2 = spreadSheet2.createRow(6);
 cell2 = row2.createCell((short)1);
 cell2.setCellValue("This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation,"); 
row2 = spreadSheet2.createRow(7);
 cell2 = row2.createCell((short)1);
 cell2.setCellValue("either version 3 of the License, or (at your option) any later version.");
row2 = spreadSheet2.createRow(9);
 cell2 = row2.createCell((short)1);
 cell2.setCellValue("This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;"); 

row2 = spreadSheet2.createRow(10);
 cell2 = row2.createCell((short)1);
 cell2.setCellValue("without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more details."); 


row2 = spreadSheet2.createRow(12);
 cell2 = row2.createCell((short)1);
 cell2.setCellValue("For more information please contact ClearPeaks info@clearpeaks.com or call +34 93 272 1546."); 












// Creating a environment for XML parsing and populating the data arrays

            DOMParser parser = new DOMParser();
            parser.parse(new InputSource(new java.io.StringReader(xmlString)));
            Document doc = parser.getDocument();

            NodeList nodeList = doc.getElementsByTagName("row");
            NodeList nodeListColumn = doc.getElementsByTagName("column");

// Loop to fill in data into workbook objects
            int numcol = 0;
            for (int i = 0; i < nodeList.getLength(); i++) {
                row = spreadSheet.createRow(i);
                for (int j = 0; j < nodeListColumn.getLength() / nodeList.getLength(); j++) {
                    cell = row.createCell((short) j);
                    cell.setCellValue(getTextContent(nodeListColumn.item(numcol)));
                    numcol += 1;
                }
            }

            Calendar calendar = Calendar.getInstance();
            return wb;
        } catch (java.lang.Exception e) {
            System.out.println("Exception: " + e.getMessage());
            return null;
        }
    }

%>
<%
// Get data from URL and create new file to hold data
                request.setCharacterEncoding("UTF-8");
        BufferedReader urlLine = request.getReader();
        String exported = (String) urlLine.readLine();
    while (urlLine.ready()) {
    exported += (String) urlLine.readLine();
}

        response.setContentType("text/xml");
        response.setHeader("Content-Disposition", "attachment;filename=unknown.xls");
        PrintWriter rsp = response.getWriter();

// Call method to read xml and load data into excel file
        HSSFWorkbook wb = genExcel(exported);
// Write tempo xls file
        String realPath = request.getRealPath("/");
        FileOutputStream fileOut = new FileOutputStream(realPath + "temp.xls");
        wb.write(fileOut);
        fileOut.close();

// Building xml to return url to file
        String serverName = request.getHeader("host");
        String sXML = "<data>";
        sXML = sXML + "<variable name=\"URLDummy\">";
        sXML = sXML + "<row>";
        sXML = sXML + "<column>http://" + serverName + "/ExportToExcelv3/temp.xls</column>";
        sXML = sXML + "</row>";
        sXML = sXML + "</variable>";
        sXML = sXML + "</data>";
        rsp.write(sXML);

%>

但是当这个JSP运行时,它会在行中产生错误  wb.write(FILEOUT);. 任何帮助将不胜感激。

1 个答案:

答案 0 :(得分:0)

我想你在这里有NPE:

nodeListColumn.item(numcol)

其中numcol可以来自0 to (number of rows * number of columns) - 1,而nodeListColumn.getLength()可能只是j < nodeListColumn.getLength() / nodeList.getLength();

你为什么要分开?

{{1}}