使用 @WebServlet 注释启动 Tomcat Servlet 时出现问题 [重复]

Problem with Tomcat Servlet startup using @WebServlet annotations [duplicate]

提问人:xplox 提问时间:11/14/2023 更新时间:11/14/2023 访问量:37

问:

早上好。

我的 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 但目前情况并非如此。🤔

怎么了?请帮忙。 提前致谢。 基督教

Java Servlet 启动 tomcat9

评论

0赞 prasad_ 11/14/2023
通常,日志文件显示 Web 应用程序 WAR 部署在 Tomcat 上。您如何在 Tomcat 上部署 Web 应用程序 WAR 文件?
0赞 xplox 11/14/2023
@prasad_我在服务器启动时使用自动部署部署了 Web 应用程序 WAR 文件。但我想我已经找到了问题所在。
0赞 prasad_ 11/14/2023
此外,需要位于文件夹下。- lib/my.jarWEB-INF

答:

0赞 xplox 11/14/2023 #1

我一直在寻找的问题🙈:

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 上进行部署。😣