失败 - 无法启动位于上下文路径/Hello的应用程序

17

我正在尝试在Tomcat 6.0中部署新的Web应用程序,但每当我点击启动按钮时,我都会不断地收到FAIL - 应用程序在上下文路径 /Hello 无法启动的消息。其他已部署的应用程序在我点击启动按钮时都可以正常运行。但为什么这个应用程序不行呢?

web-xml:

 <web-app xmlns="http://java.sun.com/xml/ns/j2ee"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
         version="2.4">

<servlet>
<servlet-name>j_security_check</servlet-name>
<servlet-class>EmailHander</servlet-class>
</servlet>

<login-config>
<auth-method>FORM</auth-method>
<form-login-config>
<form-login-page>/login.jsp</form-login-page>
<form-error-page>/fail_login.html</form-error-page>
</form-login-config>
</login-config>
<web-app>

这是我在catalina日志文件中得到的异常:

Jan 23, 2010 6:49:31 PM org.apache.catalina.startup.ContextConfig applicationWebConfig
SEVERE: Parse error in application web.xml file at jndi:/localhost/Hello/WEB-INF/web.xml
org.xml.sax.SAXParseException: XML document structures must start and end within the same entity.
    at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.parse(AbstractSAXParser.java:1231)
    at com.sun.org.apache.xerces.internal.jaxp.SAXParserImpl$JAXPSAXParser.parse(SAXParserImpl.java:522)
    at org.apache.tomcat.util.digester.Digester.parse(Digester.java:1644)
    at org.apache.catalina.startup.ContextConfig.applicationWebConfig(ContextConfig.java:365)
    at org.apache.catalina.startup.ContextConfig.start(ContextConfig.java:1066)
    at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:261)
    at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:4339)
    at org.apache.catalina.manager.ManagerServlet.start(ManagerServlet.java:1249)
    at org.apache.catalina.manager.HTMLManagerServlet.start(HTMLManagerServlet.java:612)
    at org.apache.catalina.manager.HTMLManagerServlet.doGet(HTMLManagerServlet.java:136)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:525)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:849)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:454)
    at java.lang.Thread.run(Thread.java:619)

web.xml文件出错的原因是什么?

7个回答

29

您的 web.xml 结尾应该是 </web-app> 而不是 <web-app>

顺带一提,这几乎就是异常告诉您的字面意思。


7
你需要使用</web-app>来关闭XML,而不是使用<web-app>

2
< p > EmailHandler 是你的servlet类的全名吗,例如它不在一个包中,像com.something.EmailHandler?在web.xml中必须使用完全限定名。< /p >

1
我可以帮助您翻译以下内容:

我曾经遇到同样的问题,是因为在web.xml中servlet的URL缺少了斜杠

替换

<servlet-mapping>
    <servlet-name>jsonservice</servlet-name>
    <url-pattern>jsonservice</url-pattern>
</servlet-mapping>

使用

<servlet-mapping>
    <servlet-name>jsonservice</servlet-name>
    <url-pattern>/jsonservice</url-pattern>
</servlet-mapping>

0
Tomcat使用的Java版本必须正确。8.5版本使用的是1.8的Java。

0

检查web.xml文件,可能是servletContextListener没有正常工作。 在我的情况下,我添加了servletContextListener并让它为空,但仍然出现相同的错误。我尝试从项目文件中删除它,但它仍然存在于web.xml文件中。最后,我从web.xml文件中删除了它并保存了文件。运行项目,它成功启动了。


0

第一原因可能是应用程序的web.xml文件的结束标记未能正确关闭。

web.xml可能以<web-app>结尾,但必须以</web-app>结尾

第二原因在我的情况下起作用的可能是您的tomcat的lib文件夹必须包含数据库支持jar文件。

针对Oracle的ojdbc或针对SqlServer的sqljdbc


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接