【发布时间】:2016-03-21 06:13:09
【问题描述】:
我正在使用 POSTMAN 应用程序向我的 StoryBoardResource 发送一个 GET 请求,该类负责生成 JSON 格式数据。关联的方法只消耗Application/JSON 数据:@Produces(MediaType.APPLICATION_JSON)。
我在 POSTMAN 上收到 500 内部服务器错误,尽管我的 IDE 控制台上没有任何显示,因为我也在记录一些语句以进行调试。
如果有一些 jar 文件问题,它一定会为no MesageBodyWriter found 抛出错误……对吗?我已更新 pom.xml 以包含 JSON 依赖项,并且 jar 也在那里。
这是我的StoryBoardResource 请求被委托的类:
import javax.ws.rs.Consumes;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.QueryParam;
import javax.ws.rs.core.MediaType;
import org.harsh.webapp.storyBoard.model.StoryBoardModel;
import org.harsh.webapp.storyBoard.service.StoryBoardService;
@Path("/authenticateUser")
public class StoryBoardResource {
private StoryBoardService sts = new StoryBoardService();
@GET
@Produces(MediaType.APPLICATION_JSON)
public StoryBoardModel authUser(@QueryParam("username") String username, @QueryParam("password") String password){
return sts.authUser(username, password);
}
}
在我的服务类StoryBoardService 上调用authUser 方法:
public StoryBoardModel authUser(String username, String password){
System.out.println("In here");
if(username.equals(map.get(username).getUsername()) && password.equals(map.get(username).getPassword())){
System.out.println("true");
return map.get(username);
}
return map.get(username);
}
这可能是因为一些 jar 或 Jersey 版本冲突?
这是我的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.harsh.webapp</groupId>
<artifactId>storyBoard</artifactId>
<packaging>war</packaging>
<version>0.0.1-SNAPSHOT</version>
<name>storyBoard</name>
<build>
<finalName>storyBoard</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>
<dependency>
<groupId>org.glassfish.jersey.media</groupId>
<artifactId>jersey-media-moxy</artifactId>
</dependency>
</dependencies>
<properties>
<jersey.version>2.16</jersey.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
</project>
这是 Maven 依赖项
的快照很抱歉发了这么长的帖子,但我想我应该清楚地解释一下。 请帮忙找出我在这里做错了什么?
还有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.harsh.webapp.storyBoard</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>
【问题讨论】:
-
500 表示服务器出现故障。服务器的堆栈跟踪在哪里?错误日志呢?
-
检查 POSTMAN 中的响应选项卡。如果在调用控制器方法之前出现错误,它肯定会出现在 POSTMAN 响应中。..
-
我的 IDE 控制台上没有显示任何内容。所以不能说错误是什么?而且我不知道日志将存储在哪里。我正在使用 Eclipse
-
@TheCoder : POSTMAN 的响应选项卡显示带有消息的 html:
Internal Server Error和描述为:The server encountered an internal error that prevented it from fulfilling this request -
@Harshavardhan:你做了 web.xml 映射吗?