我刚刚开始使用JavaEE(我对JavaSE相当熟练),并且很难将我的大脑包装在制作即使是最简单的应用程序所需的所有新事物上。现在,我正在尝试使用JAX-RS注释在IntelliJ中使用Glassfish 4生成一个简单的"Hello World"html页面。我已经搜索了这些注释的正确使用,似乎我做的是正确的,但无论我在localhost中导航到哪里,我总是得到404。我开始认为我遗漏了代码中的重要组件,而且我对JavaEE的了解不够,无法知道我遗漏了什么(也许它可能是web xml文件中的某些内容,我不太了解)。下面是我写的代码,减去导入:
@LocalBean
@Stateless
@Path("/hello")
@Produces("text/html")
public class Hello {
@GET
@Path("/world")
public String printHelloWorld() {
return "<html lang="en"><body><h1>Hello, World!</h1></body></html>";
}
}
服务器本身已启动并运行,应用程序似乎已正确部署。在启动时设置的默认URL是"http://localhost:8080/HelloWorld_war_exploded/",所以我的理解是我应该去http://localhost:8080/HelloWorld_war_exploded/hello/world显示消息
编辑:这是我的XML文件,我根本没有改变:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/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">
<servlet>
<servlet-name>Faces Servlet</servlet-name>
<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>*.xhtml</url-pattern>
</servlet-mapping>
</web-app>
在看到Lutz的评论后,我调查了基础URL问题,目前正在查看以下链接:http://www-01.ibm.com/support/knowledgecenter/SSAW57_8.5.5/com.ibm.websphere.nd.doc/ae/twbs_jaxrs_configwebxml.html?cp=SSAW57_8.5.5%2F1-3-0-28-2-0-1
我会相应更新
你需要在你的web.xml中配置Jersey (Glassfish中的JAX-RS实现)。您目前只有JSF配置
<servlet>
<servlet-name>jersey-serlvet</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>jersey.config.server.provider.packages</param-name>
<param-value>the.package.where.your.resources.are</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>jersey-serlvet</servlet-name>
<url-pattern>/api/*</url-pattern>
</servlet-mapping>
<url-mapping>
是你的Jersey应用程序的基础。所以你会使用
http://localhost:8080/HelloWorld_war_exploded/api/hello/world
如果您想使用标准JAX-RS配置,您可以执行
<servlet>
<servlet-name>javax.ws.rs.core.Application</servlet-name>
</servlet>
<servlet-mapping>
<servlet-name>javax.ws.rs.core.Application</servlet-name>
<url-pattern>/api/*</url-pattern>
</servlet-mapping>
这将扫描整个类路径以查找资源,因此您不需要像前面的配置那样指定包。
或者你可以使用Java代码
@javax.ws.rs.ApplicationPath("/api")
public class RestApplication extends javax.ws.rs.core.Application {
}
将该类保留为空还将扫描整个类路径以查找资源。或者您可以显式地添加类
@javax.ws.rs.ApplicationPath("/api")
public class RestApplication extends javax.ws.rs.core.Application {
@Override
public Set<Class<?>> getClasess() {
Set<Class<?>> classes = new HashSet<>();
classes.add(Hello.class);
return classes;
}
}