2016-06-11 107 views
2

私はJavaアプリケーションを実行するために埋め込みのtomcat(v_ 8.0.33)を使用しています。コンソールで次のエラーを投げている:埋め込みのTomcatサーバを使用しているときに警告が発行されます

INFO: Starting Servlet Engine: Apache Tomcat/8.0.33 
Jun 11, 2016 2:53:02 PM org.apache.tomcat.util.digester.Digester endElement 
WARNING: No rules found matching 'web-app/servlet/servlet-name'. 
Jun 11, 2016 2:53:02 PM org.apache.tomcat.util.digester.Digester endElement 
WARNING: No rules found matching 'web-app/servlet/servlet-class'. 
Jun 11, 2016 2:53:02 PM org.apache.tomcat.util.digester.Digester endElement 
WARNING: No rules found matching 'web-app/servlet/init-param/param-name'. 
Jun 11, 2016 2:53:02 PM org.apache.tomcat.util.digester.Digester endElement 
WARNING: No rules found matching 'web-app/servlet/init-param/param-value'. 
Jun 11, 2016 2:53:02 PM org.apache.tomcat.util.digester.Digester endElement 
WARNING: No rules found matching 'web-app/servlet/init-param'. 
Jun 11, 2016 2:53:02 PM org.apache.tomcat.util.digester.Digester endElement 
WARNING: No rules found matching 'web-app/servlet/init-param/param-name'. 
Jun 11, 2016 2:53:02 PM org.apache.tomcat.util.digester.Digester endElement 
WARNING: No rules found matching 'web-app/servlet/init-param/param-value'. 
Jun 11, 2016 2:53:02 PM org.apache.tomcat.util.digester.Digester endElement 
WARNING: No rules found matching 'web-app/servlet/init-param'. 
Jun 11, 2016 2:53:02 PM org.apache.tomcat.util.digester.Digester endElement 
WARNING: No rules found matching 'web-app/servlet/load-on-startup'. 
g.apache.tomcat.util.digester.Digester endElement 
WARNING: No rules found matching 'web-app/servlet-mapping'. 
Jun 11, 2016 2:53:02 PM org.apache.tomcat.util.digester.Digester endElement 
WARNING: No rules found matching 'web-app'. 
Jun 11, 2016 2:53:02 PM org.apache.catalina.startup.ContextConfig getDefaultWebXmlFragment 
INFO: No global web.xml found 
Jun 11, 2016 2:53:04 PM org.apache.jasper.servlet.TldScanner scanJars 
INFO: 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. 
Jun 11, 2016 2:53:06 PM org.apache.coyote.AbstractProtocol start 
INFO: Starting ProtocolHandler ["http-nio-8080"] 

私はそのマッピングがweb.xmlのファイルを修正するためだと思うけど何とかではない、それはタグ解析することができ、その理由を把握することができdont't。このTomcatのバージョンに起因するのですか(何かが廃止され、私は使用しているかもしれません)?以下

は私のweb.xmlです:

<?xml version="1.0" encoding="UTF-8"?> 
<!-- This web.xml file is not required when using Servlet 3.0 container, 
    see implementation details http://jersey.java.net/nonav/documentation/latest/jax-rs.html --> 
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5"> 

    <servlet> 
    <servlet-name>REST Servlet</servlet-name> 
    <servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class> 
    <init-param> 
     <param-name>javax.ws.rs.Application</param-name> 
     <param-value>ResourceLoader</param-value> 
    </init-param> 
    <init-param> 
     <param-name>jersey.config.server.provider.packages</param-name> 
     <param-value>sran.api.ifscLookup.resources</param-value> 
    </init-param> 
    <load-on-startup>1</load-on-startup> 
    </servlet> 
    <servlet-mapping> 
    <servlet-name>REST Servlet</servlet-name> 
    <url-pattern>/Api/*</url-pattern> 

    </servlet-mapping> 

</web-app> 

答えて

1

誰かがまた、この時点で打った場合、将来的にいつでも、回避策は、XMLの解析ロジックに問題があるので、web.xmlデプロイメント記述子を使用しないようにされるかもしれませwebapp-runnerでは

代わり使用 - Tomcatのインスタンスを含むあなたのメインクラスで>を:

Tomcat.addServlet(context, "yourServletName", resourceConfig()); 
context.addServletMapping("/yourApi/*", "yourServletName"); 



private ServletContainer resourceConfig() { 
     return new ServletContainer(new ResourceConfig(
       new ResourceLoader().getClasses())); 
    } 

ResourceLoader.java

import java.util.HashSet; 
import java.util.Set; 

import javax.ws.rs.core.Application; 



public class ResourceLoader extends Application{ 

    @Override 
    public Set<Class<?>> getClasses() { 
     final Set<Class<?>> classes = new HashSet<Class<?>>(); 

     // register root resource 
     classes.add(classWhereYouDefinedUrlEndpoint.class); 
     return classes; 
    } 

これはあなたの時間を節約するかもしれません:)

関連する問題