JAX-RS-Jersey+;JSON-->;HTTP 500内部服务器错误
我的Web服务有一些问题-_- 我试图从Web服务接收我的电影列表,但总是出现这种令人讨厌的错误 这是我的型号:JAX-RS-Jersey+;JSON-->;HTTP 500内部服务器错误,json,jersey,jax-rs,internal-server-error,Json,Jersey,Jax Rs,Internal Server Error,我的Web服务有一些问题-_- 我试图从Web服务接收我的电影列表,但总是出现这种令人讨厌的错误 这是我的型号: package de.hawhof.dm.kino.model; import java.io.Serializable; import java.util.List; import java.util.Set; import javax.persistence.CascadeType; import javax.persistence.Entity; import javax.
package de.hawhof.dm.kino.model;
import java.io.Serializable;
import java.util.List;
import java.util.Set;
import javax.persistence.CascadeType;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Lob;
import javax.persistence.OneToMany;
import javax.xml.bind.annotation.XmlRootElement;
@Entity
@XmlRootElement(name="movie")
public class Movie implements Serializable {
/**
*
*/
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
int movieid;
String name;
String releaseDate;
@Lob
String critic;
String runtime;
@Lob
String synopsis;
String posterPath;
String thumbnail;
// user movie comment rating
@OneToMany(cascade = CascadeType.ALL, mappedBy = "movie")
List<User_Movie_CR> userMovieCR;
// cinema movie
@OneToMany(cascade = CascadeType.ALL, mappedBy = "movie")
List<Cinema_Movie> cinemaMovie;
// user film cinema table
@OneToMany(mappedBy = "movie")
Set<Cinema_Movie_User> cinema_movie_user;
public Movie() {
}
public Movie(String name, String releaseDate, String critic,
String runtime, String synopsis, String posterPath, String thumbnail) {
this.name = name;
this.releaseDate = releaseDate;
this.critic = critic;
this.runtime = runtime;
this.synopsis = synopsis;
this.posterPath = posterPath;
this.thumbnail = thumbnail;
}
// toString
public String toString() {
return "Movie [name=" + name + ", releaseDate=" + releaseDate
+ ", critic=" + critic + ", runtime=" + runtime + ", synopsis="
+ synopsis + ", posterPath=" + posterPath + "]";
}
// setter and getter
}
package de.hawhof.dm.kino.ws;
import java.util.ArrayList;
import java.util.List;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Request;
import javax.ws.rs.core.UriInfo;
import de.hawhof.dm.kino.facade.MovieFacade;
import de.hawhof.dm.kino.model.*;
@Path("/movies")
public class MoviesResource {
@Context
UriInfo uriInfo;
@Context
Request request;
MovieFacade movieFacade = new MovieFacade();
@GET
@Path("xml")
@Produces(MediaType.TEXT_XML)
public List<Movie> getMoviesBrowser() {
List<Movie> movies = new ArrayList<Movie>();
movies.addAll(movieFacade.listAll());
return movies;
}
@GET
@Path("XMLForApp")
@Produces({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON })
public List<Movie> getMovies() {
List<Movie> movies = new ArrayList<Movie>();
movies.addAll(movieFacade.listAll());
return movies;
}
@GET
@Path("onemovie")
public Movie getMovie() {
return new Movie("TEST!!!", "", "", "", "", "", "");
}
@GET
@Path("count")
@Produces(MediaType.TEXT_PLAIN)
public String getCount() {
int count = movieFacade.listAll().size();
return String.valueOf(count);
}
@Path("{movie}")
public MovieResource getMovie(@PathParam("movie") int movieid) {
return new MovieResource(uriInfo, request, movieid);
}
}
import javax.ws.rs.client.Client;
import javax.ws.rs.client.ClientBuilder;
import javax.ws.rs.core.MediaType;
public class MovieWSClient {
Client client;
String movieList;
public MovieWSClient() {
client = ClientBuilder.newClient().register(getClass());
movieList = client.target("http://localhost:8080/kino").path("/rest/movies/XMLForApp").request(MediaType.APPLICATION_JSON).get(String.class);
}
public String getMovieList() {
return movieList;
}
}
SEVERE: Servlet.service() for servlet [Hello Servlet] in context with path [/kino] threw exception [An exception occurred processing JSP page /pages/public/hello.jsp at line 20
Stacktrace:] with root cause
javax.ws.rs.InternalServerErrorException: HTTP 500 Internal Server Error
at org.glassfish.jersey.client.JerseyInvocation.convertToException(JerseyInvocation.java:904)
at org.glassfish.jersey.client.JerseyInvocation.translate(JerseyInvocation.java:749)
at org.glassfish.jersey.client.JerseyInvocation.access$500(JerseyInvocation.java:88)
at org.glassfish.jersey.client.JerseyInvocation$2.call(JerseyInvocation.java:650)
at org.glassfish.jersey.internal.Errors.process(Errors.java:315)
at org.glassfish.jersey.internal.Errors.process(Errors.java:297)
at org.glassfish.jersey.internal.Errors.process(Errors.java:228)
at org.glassfish.jersey.process.internal.RequestScope.runInScope(RequestScope.java:421)
at org.glassfish.jersey.client.JerseyInvocation.invoke(JerseyInvocation.java:646)
at org.glassfish.jersey.client.JerseyInvocation$Builder.method(JerseyInvocation.java:375)
at org.glassfish.jersey.client.JerseyInvocation$Builder.get(JerseyInvocation.java:275)
at de.hawhof.dm.kino.ws.MovieWSClient.<init>(MovieWSClient.java:16)
at org.apache.jsp.pages.public_.hello_jsp._jspService(hello_jsp.java:77)
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:419)
at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:391)
at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:334)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:684)
at org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:471)
at org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:402)
at org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:329)
at de.hawhof.dm.kino.servlet.HelloServlet.doGet(HelloServlet.java:21)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:240)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:164)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:462)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:164)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:562)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:395)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:250)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:188)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:166)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
at java.lang.Thread.run(Thread.java:722)
例外情况是:
package de.hawhof.dm.kino.model;
import java.io.Serializable;
import java.util.List;
import java.util.Set;
import javax.persistence.CascadeType;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Lob;
import javax.persistence.OneToMany;
import javax.xml.bind.annotation.XmlRootElement;
@Entity
@XmlRootElement(name="movie")
public class Movie implements Serializable {
/**
*
*/
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
int movieid;
String name;
String releaseDate;
@Lob
String critic;
String runtime;
@Lob
String synopsis;
String posterPath;
String thumbnail;
// user movie comment rating
@OneToMany(cascade = CascadeType.ALL, mappedBy = "movie")
List<User_Movie_CR> userMovieCR;
// cinema movie
@OneToMany(cascade = CascadeType.ALL, mappedBy = "movie")
List<Cinema_Movie> cinemaMovie;
// user film cinema table
@OneToMany(mappedBy = "movie")
Set<Cinema_Movie_User> cinema_movie_user;
public Movie() {
}
public Movie(String name, String releaseDate, String critic,
String runtime, String synopsis, String posterPath, String thumbnail) {
this.name = name;
this.releaseDate = releaseDate;
this.critic = critic;
this.runtime = runtime;
this.synopsis = synopsis;
this.posterPath = posterPath;
this.thumbnail = thumbnail;
}
// toString
public String toString() {
return "Movie [name=" + name + ", releaseDate=" + releaseDate
+ ", critic=" + critic + ", runtime=" + runtime + ", synopsis="
+ synopsis + ", posterPath=" + posterPath + "]";
}
// setter and getter
}
package de.hawhof.dm.kino.ws;
import java.util.ArrayList;
import java.util.List;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Request;
import javax.ws.rs.core.UriInfo;
import de.hawhof.dm.kino.facade.MovieFacade;
import de.hawhof.dm.kino.model.*;
@Path("/movies")
public class MoviesResource {
@Context
UriInfo uriInfo;
@Context
Request request;
MovieFacade movieFacade = new MovieFacade();
@GET
@Path("xml")
@Produces(MediaType.TEXT_XML)
public List<Movie> getMoviesBrowser() {
List<Movie> movies = new ArrayList<Movie>();
movies.addAll(movieFacade.listAll());
return movies;
}
@GET
@Path("XMLForApp")
@Produces({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON })
public List<Movie> getMovies() {
List<Movie> movies = new ArrayList<Movie>();
movies.addAll(movieFacade.listAll());
return movies;
}
@GET
@Path("onemovie")
public Movie getMovie() {
return new Movie("TEST!!!", "", "", "", "", "", "");
}
@GET
@Path("count")
@Produces(MediaType.TEXT_PLAIN)
public String getCount() {
int count = movieFacade.listAll().size();
return String.valueOf(count);
}
@Path("{movie}")
public MovieResource getMovie(@PathParam("movie") int movieid) {
return new MovieResource(uriInfo, request, movieid);
}
}
import javax.ws.rs.client.Client;
import javax.ws.rs.client.ClientBuilder;
import javax.ws.rs.core.MediaType;
public class MovieWSClient {
Client client;
String movieList;
public MovieWSClient() {
client = ClientBuilder.newClient().register(getClass());
movieList = client.target("http://localhost:8080/kino").path("/rest/movies/XMLForApp").request(MediaType.APPLICATION_JSON).get(String.class);
}
public String getMovieList() {
return movieList;
}
}
SEVERE: Servlet.service() for servlet [Hello Servlet] in context with path [/kino] threw exception [An exception occurred processing JSP page /pages/public/hello.jsp at line 20
Stacktrace:] with root cause
javax.ws.rs.InternalServerErrorException: HTTP 500 Internal Server Error
at org.glassfish.jersey.client.JerseyInvocation.convertToException(JerseyInvocation.java:904)
at org.glassfish.jersey.client.JerseyInvocation.translate(JerseyInvocation.java:749)
at org.glassfish.jersey.client.JerseyInvocation.access$500(JerseyInvocation.java:88)
at org.glassfish.jersey.client.JerseyInvocation$2.call(JerseyInvocation.java:650)
at org.glassfish.jersey.internal.Errors.process(Errors.java:315)
at org.glassfish.jersey.internal.Errors.process(Errors.java:297)
at org.glassfish.jersey.internal.Errors.process(Errors.java:228)
at org.glassfish.jersey.process.internal.RequestScope.runInScope(RequestScope.java:421)
at org.glassfish.jersey.client.JerseyInvocation.invoke(JerseyInvocation.java:646)
at org.glassfish.jersey.client.JerseyInvocation$Builder.method(JerseyInvocation.java:375)
at org.glassfish.jersey.client.JerseyInvocation$Builder.get(JerseyInvocation.java:275)
at de.hawhof.dm.kino.ws.MovieWSClient.<init>(MovieWSClient.java:16)
at org.apache.jsp.pages.public_.hello_jsp._jspService(hello_jsp.java:77)
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:419)
at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:391)
at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:334)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:684)
at org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:471)
at org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:402)
at org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:329)
at de.hawhof.dm.kino.servlet.HelloServlet.doGet(HelloServlet.java:21)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:240)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:164)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:462)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:164)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:562)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:395)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:250)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:188)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:166)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
at java.lang.Thread.run(Thread.java:722)
SEVERE:Servlet[Hello Servlet]的Servlet.service()在路径为[/kino]的上下文中引发异常[处理第20行的JSP page/pages/public/Hello.JSP时发生异常]
Stacktrace:]具有根本原因
javax.ws.rs.InternalServerErrorException:HTTP 500内部服务器错误
位于org.glassfish.jersey.client.JerseyInvocation.convertToException(JerseyInvocation.java:904)
位于org.glassfish.jersey.client.JerseyInvocation.translate(JerseyInvocation.java:749)
位于org.glassfish.jersey.client.JerseyInvocation.access$500(JerseyInvocation.java:88)
位于org.glassfish.jersey.client.JerseyInvocation$2.call(JerseyInvocation.java:650)
位于org.glassfish.jersey.internal.Errors.process(Errors.java:315)
位于org.glassfish.jersey.internal.Errors.process(Errors.java:297)
位于org.glassfish.jersey.internal.Errors.process(Errors.java:228)
位于org.glassfish.jersey.process.internal.RequestScope.runInScope(RequestScope.java:421)
位于org.glassfish.jersey.client.JerseyInvocation.invoke(JerseyInvocation.java:646)
位于org.glassfish.jersey.client.JerseyInvocation$Builder.method(JerseyInvocation.java:375)
位于org.glassfish.jersey.client.JerseyInvocation$Builder.get(JerseyInvocation.java:275)
在de.hawhof.dm.kino.ws.MovieWSClient.(MovieWSClient.java:16)
在org.apache.jsp.pages.public\u0.hello\ujsp.\ujspservice(hello\ujsp.java:77)
位于org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
位于javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
位于org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:419)
位于org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:391)
位于org.apache.jasper.servlet.JspServlet.service(JspServlet.java:334)
位于javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
位于org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304)
位于org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
位于org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:684)
位于org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:471)
位于org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:402)
位于org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:329)
位于de.hawhof.dm.kino.servlet.HelloServlet.doGet(HelloServlet.java:21)
位于javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
位于javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
位于org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304)
位于org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
位于org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:240)
位于org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:164)
位于org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:462)
位于org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:164)
位于org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
位于org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:562)
位于org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
位于org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:395)
位于org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:250)
位于org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:188)
位于org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:166)
位于org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302)
位于java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
位于java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
运行(Thread.java:722)
尝试将@RequestScoped
添加到REST服务。我也遇到了同样的问题,但与GAE(谷歌应用程序引擎)有关。这似乎与Jersey MessageBodyWriter无法序列化JSON有关
我通过在我的类路径中添加genson.jar
解决了这个问题。Genson是一个JSON序列化程序/反序列化程序库,您可以在其上下载
您还可以将其用作JSON提供程序(因为这是支持JSON与Jersey绑定的首选方式)
不要忘记将jar复制到WEB-INF/lib文件夹中