2012-07-06 144 views
0

我使用NetBeans IDE 7.0.1和Apache Tomcat 7.0.14.0。我使用IDE构建了一个Struts2应用程序,并且能够很好地构建,无一例外。但是,IDE的服务器日志在所有Struts2应用程序的每个部署时间内都会出现相同的异常。应用程序运行良好,没有其他例外。Struts2应用程序部署时的常见异常

这里是个例外:

Jul 6, 2012 9:40:31 AM org.apache.catalina.core.StandardWrapperValve invoke 
    SEVERE: Servlet.service() for servlet [jsp] in context with path [/OnlineBooking] threw exception [Unable to compile class for JSP] with root cause 
    java.io.UTFDataFormatException: Invalid byte 1 of 1-byte UTF-8 sequence. 
at org.apache.jasper.xmlparser.UTF8Reader.invalidByte(UTF8Reader.java:623) 
    at org.apache.jasper.xmlparser.UTF8Reader.read(UTF8Reader.java:488) 
    at org.apache.jasper.xmlparser.XMLEncodingDetector.load(XMLEncodingDetector.java:1017) 
    at org.apache.jasper.xmlparser.XMLEncodingDetector.skipString(XMLEncodingDetector.java:968) 
    at org.apache.jasper.xmlparser.XMLEncodingDetector.scanXMLDecl(XMLEncodingDetector.java:1224) 
    at org.apache.jasper.xmlparser.XMLEncodingDetector.getEncoding(XMLEncodingDetector.java:124) 
    at org.apache.jasper.xmlparser.XMLEncodingDetector.getEncoding(XMLEncodingDetector.java:112) 
    at org.apache.jasper.compiler.ParserController.determineSyntaxAndEncoding(ParserController.java:334) 
    at org.apache.jasper.compiler.ParserController.doParse(ParserController.java:190) 
    at org.apache.jasper.compiler.ParserController.parseDirectives(ParserController.java:119) 
    at org.apache.jasper.compiler.Compiler.generateJava(Compiler.java:192) 
    at org.apache.jasper.compiler.Compiler.compile(Compiler.java:372) 
    at org.apache.jasper.compiler.Compiler.compile(Compiler.java:352) 
    at org.apache.jasper.compiler.Compiler.compile(Compiler.java:339) 
    at org.apache.jasper.JspCompilationContext.compile(JspCompilationContext.java:594) 
    at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:344) 
    at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:390) 
    at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:333) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
    at org.apache.struts2.dispatcher.FilterDispatcher.doFilter(FilterDispatcher.java:428) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
    at org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:393) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:240) 
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:164) 
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:462) 
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:164) 
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) 
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:563) 
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:399) 
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:317) 
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:204) 
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:182) 
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:311) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) 
    at java.lang.Thread.run(Thread.java:662) 

我怎样才能避免这种情况?问题在哪里存在?

+0

看起来你在你的库中有一个XML解析器,它与其他人有冲突。尝试使用较新的版本进行更改或删除它。似乎与一些碧玉罐子的问题。 – batbaatar 2012-07-09 04:51:53

+0

@batbaatar,谢谢。我使用struts2,2.2.3版本。它可能有新的或最好的支持XML解析库。我最好使用另一个最新的struts2库2.2.4。但是2.2.3一定要支持好.. – 2012-07-09 06:07:58

回答

0
java.io.UTFDataFormatException xmlparser 

我猜问题是xml文件。

是否从其他文件复制?可能是编码不同,你应该自己输入。尝试添加以下到您的xml文件:

<?xml version="1.0" encoding="UTF-8"?> 

顺便说一句,我是一个中国学生,我不擅长英语,对不起。

+0

我试着添加那一行。但它仍然存在。感谢您的关注。中国人对所有语言都很擅长,不要撒谎。 :) – 2012-07-08 16:10:44

相关问题