我刚开始使用JavaEE(我对JavaSE相当熟练),并且在将所有最简单的应用程序所需的新事物包缠起来时遇到了麻烦。现在,我正在尝试使用JAX-RS注释使用Glassfish 4在IntelliJ中生成一个简单的“ 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
我将进行相应的更新。
<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;
}
}