【发布时间】:2018-02-07 12:48:09
【问题描述】:
我一直在尝试使用 jersey、tomcat 和 eclipse 处理 Rest 应用程序,但我收到 404 错误(请求的资源不可用。)我确实遇到了所有类似的错误,但我无法解决这个问题。
这是我的 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 version="2.5" 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">
<servlet>
<servlet-name>Jersey Web Application</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>jersey.config.server.provider.packages</param-name>
<param-value>org.kushal.rest.testRest</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Jersey Web Application</servlet-name>
<url-pattern>/webapi/*</url-pattern>
</servlet-mapping>
</web-app>
我交叉检查了 servlet 名称,它是匹配的。 我尝试使用 jdk 1.7 和 tomcat 7 以及 jdk 1.8 和 tomcat 8 以及不同版本的球衣,我尝试的最新版本是 2.25。
这是我的 pom.xml:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.kushal.rest</groupId>
<artifactId>testRest</artifactId>
<packaging>war</packaging>
<version>0.0.1-SNAPSHOT</version>
<name>testRest</name>
<build>
<finalName>testRest</finalName>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.5.1</version>
<inherited>true</inherited>
<configuration>
<source>1.7</source>
<target>1.7</target>
</configuration>
</plugin>
</plugins>
</build>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.glassfish.jersey</groupId>
<artifactId>jersey-bom</artifactId>
<version>${jersey.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<dependency>
<groupId>org.glassfish.jersey.containers</groupId>
<artifactId>jersey-container-servlet-core</artifactId>
<!-- use the following artifactId if you don't need servlet 2.x compatibility -->
<!-- artifactId>jersey-container-servlet</artifactId -->
</dependency>
<!-- uncomment this to get JSON support
<dependency>
<groupId>org.glassfish.jersey.media</groupId>
<artifactId>jersey-media-moxy</artifactId>
</dependency>
-->
</dependencies>
<properties>
<jersey.version>2.25</jersey.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
</project>
这是我的 resource.java 文件
package org.kushal.rest.testRest;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
/**
* Root resource (exposed at "myresource" path)
*/
@Path("/myresource")
public class MyResource {
/**
* Method handling HTTP GET requests. The returned object will be sent
* to the client as "text/plain" media type.
*
* @return String that will be returned as a text/plain response.
*/
@GET
@Produces(MediaType.TEXT_PLAIN)
public String getIt() {
return "Got it!";
}
}
http://localhost:8080/testRest/myresource http://localhost:8080/testRest 请让我知道我做错了什么,因为我在过去 3 天被卡住了。
here are the logs:
Aug 29, 2017 5:11:03 PM org.apache.tomcat.util.digester.SetPropertiesRule begin
WARNING: [SetPropertiesRule]{Server/Service/Engine/Host/Context} Setting property 'source' to 'org.eclipse.jst.jee.server:messenger' did not find a matching property.
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: Server version: Apache Tomcat/8.0.39
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: Server built: Nov 9 2016 08:48:39 UTC
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: Server number: 8.0.39.0
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: OS Name: Windows 10
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: OS Version: 10.0
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: Architecture: amd64
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: Java Home: C:\Program Files\Java\jre1.8.0_91
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: JVM Version: 1.8.0_91-b15
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: JVM Vendor: Oracle Corporation
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: CATALINA_BASE: C:\Users\kushaldileep\New_Rest\.metadata\.plugins\org.eclipse.wst.server.core\tmp0
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: CATALINA_HOME: C:\Courses\273\apache-tomcat-8.0.39
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: Command line argument: -Dcatalina.base=C:\Users\kushaldileep\New_Rest\.metadata\.plugins\org.eclipse.wst.server.core\tmp0
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: Command line argument: -Dcatalina.home=C:\Courses\273\apache-tomcat-8.0.39
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: Command line argument: -Dwtp.deploy=C:\Users\kushaldileep\New_Rest\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\wtpwebapps
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: Command line argument: -Djava.endorsed.dirs=C:\Courses\273\apache-tomcat-8.0.39\endorsed
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.VersionLoggerListener log
INFO: Command line argument: -Dfile.encoding=Cp1252
Aug 29, 2017 5:11:03 PM org.apache.catalina.core.AprLifecycleListener lifecycleEvent
INFO: The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: C:\Program Files\Java\jre1.8.0_91\bin;C:\WINDOWS\Sun\Java\bin;C:\WINDOWS\system32;C:\WINDOWS;C:/Program Files/Java/jre1.8.0_91/bin/server;C:/Program Files/Java/jre1.8.0_91/bin;C:/Program Files/Java/jre1.8.0_91/lib/amd64;C:\ProgramData\Oracle\Java\javapath;C:\Program Files (x86)\CodeBlocks\MinGW\bin;C:\Program Files (x86)\Brackets\command;C:\Program Files\Java\jdk1.8.0_65\bin;C:\Program Files (x86)\GtkSharp\2.12\bin;C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\System32\Wbem;C:\WINDOWS\System32\WindowsPowerShell\v1.0\;C:\Program Files\Git\cmd;C:\Program Files (x86)\Skype\Phone\;C:\Program Files\nodejs\;C:\Program Files\MySQL\MySQL Utilities 1.6\;C:\Users\kushaldileep\AppData\Local\Programs\Python\Python36-32\Scripts\;C:\Users\kushaldileep\AppData\Local\Programs\Python\Python36-32\;C:\Users\kushaldileep\Anaconda2;C:\Users\kushaldileep\Anaconda2\Scripts;C:\Users\kushaldileep\Anaconda2\Library\bin;C:\Users\kushaldileep\AppData\Roaming\npm;C:\Users\kushaldileep\AppData\Local\Microsoft\WindowsApps;;C:\Courses\273\Enide-2015-7-windows-x64-20150706\eclipse;;.
Aug 29, 2017 5:11:03 PM org.apache.coyote.AbstractProtocol init
INFO: Initializing ProtocolHandler ["http-nio-8080"]
Aug 29, 2017 5:11:03 PM org.apache.tomcat.util.net.NioSelectorPool getSharedSelector
INFO: Using a shared selector for servlet write/read
Aug 29, 2017 5:11:03 PM org.apache.coyote.AbstractProtocol init
INFO: Initializing ProtocolHandler ["ajp-nio-8009"]
Aug 29, 2017 5:11:03 PM org.apache.tomcat.util.net.NioSelectorPool getSharedSelector
INFO: Using a shared selector for servlet write/read
Aug 29, 2017 5:11:03 PM org.apache.catalina.startup.Catalina load
INFO: Initialization processed in 1636 ms
Aug 29, 2017 5:11:04 PM org.apache.catalina.core.StandardService startInternal
INFO: Starting service Catalina
Aug 29, 2017 5:11:04 PM org.apache.catalina.core.StandardEngine startInternal
INFO: Starting Servlet Engine: Apache Tomcat/8.0.39
Aug 29, 2017 5:11:04 PM org.apache.catalina.util.SessionIdGeneratorBase createSecureRandom
INFO: Creation of SecureRandom instance for session ID generation using [SHA1PRNG] took [101] milliseconds.
Aug 29, 2017 5:11:04 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["http-nio-8080"]
Aug 29, 2017 5:11:04 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["ajp-nio-8009"]
Aug 29, 2017 5:11:04 PM org.apache.catalina.startup.Catalina start
INFO: Server startup in 901 ms
【问题讨论】:
-
testRest/webapi/myresource。看起来 web.xml url 模式。这是网址的一部分。 -
你有日志吗?例如,对于 tomcat,检查 catalina.out 和 localhost_access 日志以及部署到它的应用程序会很有用。
-
@peeskillet 我试过这个localhost:8080/messenger/webapi/myresource 仍然显示相同。
-
@SergeiSirik:我刚刚在新工作区中创建了一个新的 Maven 项目以再次检查我已在问题中附加了日志
-
尝试访问localhost:8080/testRest/webapi/myresource URL
标签: java eclipse rest tomcat jersey-2.0