提问人:xplox 提问时间:11/14/2023 更新时间:11/14/2023 访问量:37
使用 @WebServlet 注释启动 Tomcat Servlet 时出现问题 [重复]
Problem with Tomcat Servlet startup using @WebServlet annotations [duplicate]
问:
早上好。
我的 servlet 启动有问题。你能帮帮我吗? 我正在使用
- 雄猫 9.0.82
- Coretto 11.0.17.8.1
- 视窗 10 19045.3570
我有一个编译的 WAR 存档,目录结构如下。
WAR
- index.htm
- img
- some_images.gif
- WEB-INF
- web.xml
- lib/my.jar
- servlet.HelpServlet.class`
web.xml 如下所示:
<?xml version="1.0" encoding="UTF-8"?\>
<!-- Metadata-complete Attribute: If your web.xml contains the attribute
metadata-complete="true" in the tag, this will instruct the server
to ignore annotations and use only the web.xml for deployment configuration. -->
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1" metadata-complete="false"\>
<mime-mapping>
<extension>wsdl</extension>
<mime-type>text/xml</mime-type>
</mime-mapping>
<mime-mapping>
<extension>xsd</extension>
<mime-type>text/xml</mime-type>
</mime-mapping>
Servlet 具有以下定义:
@WebServlet(
name = "HelpServlet",
urlPatterns = "/help/\*")
public class HelpServlet extends javax.servlet.http.HttpServlet
{
private static final long serialVersionUID = -2877995723829943551L;
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException
{
System.out.println("HELP PLEASE");
}
}
我的 tomcat 具有以下配置(从 vanilla 更改):
conf/server.xml 端口从 8080 更改为 6080
<Host name="localhost" appBase="../webapp/app" unpackWARs="true"\>
conf/Catalina/localhost/app.xml
<?xml version="1.0" encoding="ISO-8859-15"?>
<Context docBase="D:/app-deploy/webapp/app.war" reloadable="false" />
是否有任何配置我忘记配置Servlet在服务器启动时启动?战争档案将部署在预期的目录中。索引.htm可以在浏览器中找到并查看,但是找不到localhost:8080/app/help下的HELP-Servlet 404!
这是完整的日志文件:
[09:34:41] <Guest28> 14-Nov-2023 09:29:50.270 INFORMATION [main] org.apache.coyote.AbstractProtocol.init Initialisiere ProtocolHandler["http-nio-6080"]
[09:34:41] <Guest28> 14-Nov-2023 09:29:50.319 INFORMATION [main] org.apache.catalina.startup.Catalina.load Server initialization in [1059] milliseconds
[09:34:41] <Guest28> 14-Nov-2023 09:29:50.446 INFORMATION [main] org.apache.catalina.core.StandardService.startInternal Starting service [Catalina]
[09:34:41] <Guest28> 14-Nov-2023 09:29:50.447 INFORMATION [main] org.apache.catalina.core.StandardEngine.startInternal Starting Servlet engine: [Apache Tomcat/9.0.82]
[09:34:41] <Guest28> 14-Nov-2023 09:29:50.468 INFORMATION [main] org.apache.catalina.startup.HostConfig.deployDescriptor Deploying deployment descriptor [D:\java-ide\workspace\webframe-deploy\apache-tomcat-9.0.82\conf\Catalina\localhost\webframe.xml]
[09:34:41] <Guest28> 14-Nov-2023 09:30:30.455 INFORMATION [main] org.apache.jasper.servlet.TldScanner.scanJars At least one JAR was scanned for TLDs yet contained no TLDs. Enable debug logging for this logger for a complete list of JARs that were scanned but no TLDs were found in them. Skipping unneeded JARs during scanning can improve startup time and JSP compilation time.
[09:34:41] <Guest28> 14-Nov-2023 09:33:54.540 WARNUNG [main] org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom Creation of SecureRandom instance for session ID generation using [SHA1PRNG] took [260] milliseconds.
[09:34:41] <Guest28> 14-Nov-2023 09:33:54.635 INFORMATION [main] org.apache.catalina.startup.HostConfig.deployDescriptor Deployment of deployment descriptor [D:\java-ide\workspace\webframe-deploy\apache-tomcat-9.0.82\conf\Catalina\localhost\webframe.xml] has finished in [244.166] ms
[09:34:41] <Guest28> 14-Nov-2023 09:33:54.638 INFORMATION [main] org.apache.coyote.AbstractProtocol.start Starting ProtocolHandler ["http-nio-6080"]
[09:34:41] <Guest28> 14-Nov-2023 09:33:54.920 INFORMATION [main] org.apache.catalina.startup.Catalina.start Server startup in [244596] milliseconds
预期的是 Tomcat 在 [GET] http://localhost:6080/app/help 下启动定义的 servlet 但目前情况并非如此。🤔
怎么了?请帮忙。 提前致谢。 基督教
答:
我一直在寻找的问题🙈:
14-Nov-2023 10:56:08.673 SCHWERWIEGEND [main] org.apache.catalina.core.StandardContext.loadOnStartup Web 应用程序中的 Servlet [HelpServlet] [/app] 抛出 load() 异常 java.lang.UnsupportedClassVersionError:servlet/HelpServlet 已由较新版本的 Java 运行时(类文件版本 60.0)编译,此版本的 Java 运行时仅识别最高 55.0 的类文件版本(无法加载类 [servlets.HelpServlet]) 在 org.apache.catalina.loader.WebappClassLoaderBase.findClassInternal(WebappClassLoaderBase.java:2484)
通知! 不要使用 buildIn JRE 16 在 Eclipse 中使用 ANT 进行编译,并使用 JRE 11 在 Tomcat 上进行部署。😣
评论
- lib/my.jar
WEB-INF