我遇到了一个奇怪的问题。我使用 Jersey 2.2 来做我宁静的网络服务(使用 jersey-media-moxy)。如果我将输出生成为 application/xml,它运行良好。但是,如果将我的输出生成为 application/json,我会得到“内部服务器错误 500”。
我在 ivy.xml 中的依赖设置是:
<dependency org="org.glassfish.jersey.core" name="jersey-server" rev="2.2"/>
<dependency org="org.glassfish.jersey.containers" name="jersey-container-servlet-core" rev="2.2"/>
<dependency org="org.glassfish.jersey.media" name="jersey-media-moxy" rev="2.2"/>
我的服务等级是:
@Path("/projects/{companykey: [0-9]*}")
@Produces({MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON})
public class ProjectResource {
private static Logger logger = Logger.getLogger(ProjectResource.class);
private final Application app = Application.getInstance();
@GET
public List<ProjectBase> getProjectBases(
@PathParam("companykey") String companyKeyStr) {
...
}
@GET
@Path("/{projectkey: [0-9]*}")
public ProjectBase getProjectBase(
@PathParam("companykey") String companyKeyStr,
@PathParam("projectkey") String projectKeyStr) {
int companyKey = Integer.valueOf(companyKeyStr);
int projObjKey = Integer.valueOf(projectKeyStr);
logger.debug(MessageFormat.format("get project {1} of company {0}",
companyKey, projObjKey));
ProjectBase project = null;
try {
project = app.getProjectIF().getProjectBase(companyKey, projObjKey);
if (project == null) throw new WebApplicationException(404);
return project;
} catch (ServerException se) {
logger.warn("get project fails ! " + se);
throw new WebApplicationException(500);
}
}
...
}
//class end
如果我要求 xml 输出(访问http://biz.loc.net:8080/tm/rest/projects/100/104),我得到:
<projectBase>
<_checkTopicAccess>false</_checkTopicAccess>
<_checkTaskAccess>false</_checkTaskAccess>
....
如果我要求 json 输出,我会得到:
HTTP 状态 500 - 内部服务器错误
类型状态报告
消息内部服务器错误
描述 服务器遇到了一个内部错误(Internal Server Error),导致它无法完成这个请求。
我在我的应用程序的日志文件或 Tomcat 的日志文件中没有找到任何错误消息,所以我不知道发生了什么。
有谁知道这个问题的任何可能原因?非常感谢 ...