Bug 50877 - Jasper fails to parse the marged web.xml if it contains non-ASCII character and the platform encoding is not UTF-8
Summary: Jasper fails to parse the marged web.xml if it contains non-ASCII character a...
Status: RESOLVED DUPLICATE of bug 50720
Alias: None
Product: Tomcat 7
Classification: Unclassified
Component: Jasper (show other bugs)
Version: 7.0.8
Hardware: PC Windows XP
: P2 normal (vote)
Target Milestone: ---
Assignee: Tomcat Developers Mailing List
URL:
Keywords:
Depends on:
Blocks:
 
Reported: 2011-03-05 11:09 UTC by Kenichi Masuko
Modified: 2011-03-06 01:18 UTC (History)
0 users



Attachments
patch to tomcat-7.0.8 source (149 bytes, patch)
2011-03-05 11:27 UTC, Kenichi Masuko
Details | Diff

Note You need to log in before you can comment on or make changes to this bug.
Description Kenichi Masuko 2011-03-05 11:09:20 UTC
The following exception is thrown on Japanese Windows


org.apache.jasper.JasperException: org.apache.jasper.JasperException: ファイルorg.apache.tomcat.util.scan.MergedWebXmlのXML解析エラー
        at org.apache.jasper.compiler.JspConfig.processWebDotXml(JspConfig.java:218) ~[jasper.jar:7.0.8]
        at org.apache.jasper.compiler.JspConfig.init(JspConfig.java:231) ~[jasper.jar:7.0.8]
        at org.apache.jasper.compiler.JspConfig.findJspProperty(JspConfig.java:290) ~[jasper.jar:7.0.8]
        at org.apache.jasper.compiler.Compiler.generateJava(Compiler.java:113) ~[jasper.jar:7.0.8]
        at org.apache.jasper.compiler.Compiler.compile(Compiler.java:365) ~[jasper.jar:7.0.8]
        at org.apache.jasper.compiler.Compiler.compile(Compiler.java:345) ~[jasper.jar:7.0.8]
        at org.apache.jasper.compiler.Compiler.compile(Compiler.java:332) ~[jasper.jar:7.0.8]
        at org.apache.jasper.JspCompilationContext.compile(JspCompilationContext.java:594) ~[jasper.jar:7.0.8]
        at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:342) ~[jasper.jar:7.0.8]
        at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:391) ~[jasper.jar:7.0.8]
        at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:334) ~[jasper.jar:7.0.8]
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) ~[servlet-api.jar:na]
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:306) [catalina.jar:7.0.8]
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) [catalina.jar:7.0.8]
        at jp.co.jri.joe.lip.servlet.RequestCharacterEncodingFilter.doFilter(RequestCharacterEncodingFilter.java:64) ~[RequestCharacterEncodingFilter.class:na]
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:244) [catalina.jar:7.0.8]
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) [catalina.jar:7.0.8]
        at com.google.inject.persist.PersistFilter.doFilter(PersistFilter.java:89) ~[guice-persist-3.0-rc2.jar:na]
        at jp.co.jri.joe.lip.servlet.GuicePersistFilter.doFilter(GuicePersistFilter.java:33) ~[GuicePersistFilter.class:na]
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:244) [catalina.jar:7.0.8]
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) [catalina.jar:7.0.8]
        at jp.co.jri.joe.lip.servlet.ExceptionLogFilter.doFilter(ExceptionLogFilter.java:43) ~[ExceptionLogFilter.class:na]
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:244) [catalina.jar:7.0.8]
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) [catalina.jar:7.0.8]
        at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:240) [catalina.jar:7.0.8]
        at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:161) [catalina.jar:7.0.8]
        at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:589) [catalina.jar:7.0.8]
        at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:164) [catalina.jar:7.0.8]
        at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) [catalina.jar:7.0.8]
        at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:541) [catalina.jar:7.0.8]
        at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) [catalina.jar:7.0.8]
        at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:383) [catalina.jar:7.0.8]
        at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:243) [tomcat-coyote.jar:7.0.8]
        at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:188) [tomcat-coyote.jar:7.0.8]
        at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:166) [tomcat-coyote.jar:7.0.8]
        at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:288) [tomcat-coyote.jar:7.0.8]
        at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) [na:1.6.0_24]
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) [na:1.6.0_24]
        at java.lang.Thread.run(Thread.java:662) [na:1.6.0_24]
Caused by: org.apache.jasper.JasperException: ファイルorg.apache.tomcat.util.scan.MergedWebXmlのXML解析エラー
        at org.apache.jasper.xmlparser.ParserUtils.parseXMLDocument(ParserUtils.java:111) ~[jasper.jar:7.0.8]
        at org.apache.jasper.compiler.JspConfig.processWebDotXml(JspConfig.java:83) ~[jasper.jar:7.0.8]
        ... 38 common frames omitted
Caused by: com.sun.org.apache.xerces.internal.impl.io.MalformedByteSequenceException: Invalid byte 1 of 1-byte UTF-8 sequence.
        at com.sun.org.apache.xerces.internal.impl.io.UTF8Reader.invalidByte(UTF8Reader.java:684) ~[na:1.6.0_24]
        at com.sun.org.apache.xerces.internal.impl.io.UTF8Reader.read(UTF8Reader.java:554) ~[na:1.6.0_24]
        at com.sun.org.apache.xerces.internal.impl.XMLEntityScanner.load(XMLEntityScanner.java:1742) ~[na:1.6.0_24]
        at com.sun.org.apache.xerces.internal.impl.XMLEntityScanner.skipChar(XMLEntityScanner.java:1416) ~[na:1.6.0_24]
        at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl$FragmentContentDriver.next(XMLDocumentFragmentScannerImpl.java:2792) ~[na:1.6.0_24]
        at com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl.next(XMLDocumentScannerImpl.java:648) ~[na:1.6.0_24]
        at com.sun.org.apache.xerces.internal.impl.XMLNSDocumentScannerImpl.next(XMLNSDocumentScannerImpl.java:140) ~[na:1.6.0_24]
        at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanDocument(XMLDocumentFragmentScannerImpl.java:511) ~[na:1.6.0_24]
        at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:808) ~[na:1.6.0_24]
        at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:737) ~[na:1.6.0_24]
        at com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(XMLParser.java:119) ~[na:1.6.0_24]
        at com.sun.org.apache.xerces.internal.parsers.DOMParser.parse(DOMParser.java:235) ~[na:1.6.0_24]
        at com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:284) ~[na:1.6.0_24]
        at org.apache.jasper.xmlparser.ParserUtils.parseXMLDocument(ParserUtils.java:96) ~[jasper.jar:7.0.8]
        ... 39 common frames omitted
Comment 1 Kenichi Masuko 2011-03-05 11:27:57 UTC
Created attachment 26731 [details]
patch to tomcat-7.0.8 source

Parse the merged web.xml content using UTF-8 encoding.
(It is always UTF-8 since the encoding is hardcoded in org.apache.catalina.deploy.WebXml.toXml.)
Comment 2 Mark Thomas 2011-03-06 01:18:52 UTC

*** This bug has been marked as a duplicate of bug 50720 ***