2016-07-20 5 views
0

Я пытаюсь реализовать POI Apache, чтобы отображать данные в файле Excel на некоторые входы на моей веб-странице. Я получаю это исключение:Исключение при использовании Apache POI на JSP

exception 
org.apache.jasper.JasperException: Unable to compile class for JSP 
org.apache.jasper.JspCompilationContext.compile(JspCompilationContext.java:677) 
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:364) 
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:395) 
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:339) 
javax.servlet.http.HttpServlet.service(HttpServlet.java:731) 
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) 

root cause 
java.lang.IllegalArgumentException: Page directive: invalid value for import 
org.apache.jasper.compiler.Node$PageDirective.validateImport(Node.java:628) 
org.apache.jasper.compiler.Node$PageDirective.addImport(Node.java:611) 
org.apache.jasper.compiler.Parser.parsePageDirective(Parser.java:352) 
org.apache.jasper.compiler.Parser.parseDirective(Parser.java:473) 
org.apache.jasper.compiler.Parser.parseFileDirectives(Parser.java:1773) 
org.apache.jasper.compiler.Parser.parse(Parser.java:135) 
org.apache.jasper.compiler.ParserController.doParse(ParserController.java:242) 
org.apache.jasper.compiler.ParserController.parseDirectives(ParserController.java:119) 
org.apache.jasper.compiler.Compiler.generateJava(Compiler.java:194) 
org.apache.jasper.compiler.Compiler.compile(Compiler.java:374) 
org.apache.jasper.compiler.Compiler.compile(Compiler.java:354) 
org.apache.jasper.compiler.Compiler.compile(Compiler.java:341) 
org.apache.jasper.JspCompilationContext.compile(JspCompilationContext.java:662) 
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:364) 
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:395) 
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:339) 
javax.servlet.http.HttpServlet.service(HttpServlet.java:731) 
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) 

И этот код у меня есть на моем .jsp файле:

<%@ page language="java" contentType="text/html; charset=ISO-8859-1" 
pageEncoding="ISO-8859-1"%> 

<%@ page import="java.io.FileInputStream, 
java.io.FileNotFoundException, 
java.io.IOException, 
org.apache.poi.hssf.usermodel.HSSFCell, 
org.apache.poi.hssf.usermodel.HSSFRow, 
org.apache.poi.hssf.usermodel.HSSFSheet, 
org.apache.poi.hssf.usermodel.HSSFWorkbook;"%> 

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> 
<html> 
<head></head> 
<body> 

<% 
    HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream("excel.xls")); 
    HSSFSheet sheet = workbook.getSheetAt(0); 
    HSSFRow row = sheet.getRow(1); 
    double Something,Something1,Something2,Something3,Something4; 

     Something= row.getCell(0).getNumericCellValue(); 
     Something1= row.getCell(1).getNumericCellValue(); 
     Something2= row.getCell(2).getNumericCellValue(); 
     Something3= row.getCell(3).getNumericCellValue(); 
     Something4= row.getCell(4).getNumericCellValue(); 

%> 

<div> 
    <table> 
     <tr> 
      <td>Something: </td> 
      <td><input type="text" value="<% Something %>"></td> 
     </tr> 
     <tr> 
      <td>Something1: </td> 
      <td><input type="text" value="<% Something1 %>"></td> 
     </tr> 
     <tr> 
      <td>Something2: </td> 
      <td><input type="text" value="<% Something2 %>"></td> 
     </tr> 
     <tr> 
      <td>Something3: </td> 
      <td> <input type="text" value="<% Something3 %>"></td> 
     </tr> 
     <tr> 
      <td>Something4: </td> 
      <td><input type="text" value="<% Something4 %>"></td> 
     </tr> 
    </table> 
</div> 
</body> 
</html> 

ли кто-то знает, где проблема?

ответ

1

Не знаете, какой сервер вы используете. Но если это Tomcat 7.0.57 или новее (см. Также this link), то вам нужно удалить точку с запятой (;) в конце директив импорта. Попробуйте удалить это, и он должен работать.

+0

Да, я использую Tomcat 7.x, позвольте мне попробовать удалить точку с запятой ... –

+0

Это решает эту проблему, но я получаю другую ошибку: Произошла ошибка в строке: [17] в сгенерированном java-файл: [C: \ apache-tomcat-7.0.70 \ apache-tomcat-7.0.70 \ work \ Catalina \ localhost \ HelloWorldJSP \ org \ apache \ jsp \ helloWorld_jsp.java] Можно импортировать только тип. org.apache.poi.hssf.usermodel.HSSFCell разрешает пакет И еще такие вещи .... –

+0

Не забудьте создать другой вопрос для следующей проблемы, поскольку он не связан с этой проблемой. Если это разрешит существующую проблему, вы можете принять ответ. –

Смежные вопросы