Ich versuche Apache POI zu implementieren, um die Daten in einer Excel-Datei in einige Eingaben auf meiner Webseite anzuzeigen. Ich erhalte diese Ausnahme:Ausnahme bei der Verwendung von Apache POI auf einer 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)
und das ist der Code, den ich auf meine .jsp Datei:
<%@ 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>
Hat jemand weiß, wo ist das Problem?
Ja, ich benutze Tomcat 7.x, lassen Sie mich versuchen, das Semikolon zu entfernen ... –
Das löst das Problem, aber ich bekomme andere Fehler: Ein Fehler trat bei Zeile: [17] in der generierten Java-Datei: [C: \ Apache-Tomcat-7.0.70 \ Apache-Tomcat-7.0.70 \ Arbeit \ Catalina \ Localhost \ HelloWorldJSP \ Org \ Apache \ Jsp \ HelloWorld_jsp.java] Nur ein Typ kann importiert werden. org.apache.poi.hssf.usermodel.HSSFCell löst zu einem Paket Und weitere Dinge wie .... –
Bitte erstellen Sie eine weitere Frage für das nächste Problem, da es nicht mit diesem Problem verbunden ist. Wenn das vorhandene Problem gelöst wurde, können Sie die Antwort akzeptieren. –