我正在尝试进入Java Web开发,但似乎遇到了Tomcat和一个非常简单的servlet的奇怪问题.每当我尝试加载应用程序时,catalina日志就会出现这种情况:
Caused by: java.lang.IllegalArgumentException: Servlet mapping specifies an unknown servlet name MyServlet
at org.apache.catalina.core.StandardContext.addServletMapping(StandardContext.java:2393)
at org.apache.catalina.core.StandardContext.addServletMapping(StandardContext.java:2373)
... 40 more
Mar 4, 2009 10:37:58 AM org.apache.catalina.startup.ContextConfig applicationWebConfig
SEVERE: Parse error in application web.xml file at jndi:/localhost/mywebapp/WEB-INF/web.xml
java.lang.IllegalArgumentException: Servlet mapping specifies an unknown servlet name MyServlet
Run Code Online (Sandbox Code Playgroud)
做得体面.它似乎找不到我的servlet.但是,servlet似乎在正确的位置.我可以在WEB-INF/classes/MyServlet.class中清楚地看到它
作为参考,这是我目前使用的web.xml文件:
<?xml version="1.0" encoding="ISO-8859-1"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5">
<description>My first web app in Java.</description>
<display-name>My Web App</display-name>
<servlet>
<servlet-name>MyServlet</servlet-name>
<servlet-class>MyServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>MyServlet</servlet-name>
<url-pattern>/myservlet</url-pattern>
</servlet-mapping>
</web-app>
Run Code Online (Sandbox Code Playgroud)
正如你所看到的,我保持简单......但它不断抛出这个异常.一个简陋的Web应用程序在Java中是什么样的,我错过了哪些组件?
更新
为了绝对确定它不是某种神器,我启动了一个新的Tomcat副本并再次尝试.这样做后,这开始出现在日志文件中:
SEVERE: Error deploying web application archive mywebapp.war
java.lang.UnsupportedClassVersionError: Bad version number in .class file (unable to load class MyServlet)
Run Code Online (Sandbox Code Playgroud)
我将我的.class文件转储到MyServlet类,用-target 1.5重新构建它,重新打包.war,一切都很完美.
非常感谢你的帮助!排除故障的好教训从不伤害任何人.
小智 17
好吧,鉴于更新的信息,您的问题似乎是您用于类的编译器可能是运行Tomcat的JDK的新版本.
检查用于启动Tomcat的JDK版本,然后查看是否可以执行某些操作来协调它与您用于编译servlet的版本之间的版本差异.
这应该可以解决你的问题.