【问题标题】:Java displaying JPA entitiesJava 显示 JPA 实体
【发布时间】:2017-08-01 12:00:39
【问题描述】:

我在显示一些使用 Java 的 JPA 实体时遇到问题。我对语言不是很熟悉,所以不确定我是否可以结合我现在所做的事情。我有这个Student 类,显然代表一个学生:

@Entity
@Table
public class Student implements Serializable {

    @Id
    @GeneratedValue
    private Integer id;

    @Email
    private String email;

    @Column(unique=true)
    private String studentNumber;

    private String firstName;

    private String lastName;

    public Student() {}

    public Student(String studentNumber, String firstName, String lastName, String email) {
        this.studentNumber = studentNumber;
        this.firstName = firstName;
        this.lastName = lastName;
        this.email = email;
    }

现在的想法是拥有一个 RESTFul 服务并能够显示所有学生,或者通过查找学生编号来显示学生。因此,我的持久性课程中有这个:

@Override
public Student findByStudentNumber(String studentNumber) {
    Object entity = em.createQuery("SELECT * FROM students st where st.studentNumber = :val")
            .setParameter("val", studentNumber).getSingleResult();
    return (Student) entity;
}

@Override
public List<Student> getAll() {
    List<Student> students = em.createQuery(criteriaQuery).getResultList();
    return students;
}

我的控制器:

@Path("/students")
public class StudentController {
    @Inject
    private StudentPersistence studentPersistence;

@GET
@Path("/get")
public List<Student> getAll() {
    List<Student> all = studentPersistence.getAll();
    return all;
}

@GET
@Path("{studentNr}")
public Student getStudent(@PathParam("studentNr") String id) {
    return studentPersistence.findByStudentNumber(id);
}

但是,我似乎无法让它们进入控制器,因为它不断抛出 500 内部服务器错误。我的问题:这是组合它的方式,还是有更好的方式来显示这些实体?

编辑:我的 500 错误的堆栈跟踪:

01-Aug-2017 14:04:24.769 SEVERE [http-nio-8081-exec-1] com.sun.jersey.spi.container.ContainerResponse.logException Mapped exception to response: 500 (Internal Server Error)
 javax.ws.rs.WebApplicationException: com.sun.jersey.api.MessageException: A message body writer for Java class models.Student, and Java type class models.Student, and MIME media type application/xml was not found
    at com.sun.jersey.spi.container.ContainerResponse.write(ContainerResponse.java:285)
    at com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1479)
    at com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1391)
    at com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1381)
    at com.sun.jersey.spi.container.servlet.WebComponent.service(WebComponent.java:416)
    at com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:538)
    at com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:716)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:729)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:230)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
    at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
    at filters.CorsFilter.doFilter(CorsFilter.java:33)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:474)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79)
    at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:624)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:349)
    at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:783)
    at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
    at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:798)
    at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1434)
    at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
    at java.lang.Thread.run(Thread.java:745)
Caused by: com.sun.jersey.api.MessageException: A message body writer for Java class models.Student, and Java type class models.Student, and MIME media type application/xml was not found
    ... 33 more

【问题讨论】:

  • 500 内部服务器错误意味着您的代码有问题。请添加完整的堆栈跟踪
  • @StanislavL 我明白了,现在就在那儿!
  • @dnsko,根据您的异常判断,您缺少的是负责将 Student java 对象转换为 XML 形式的代码。
  • 它无法将 Student 转换为 xml。展示你是如何配置逻辑的。
  • @StanislavL 这也不是想法,我假设我可以只获取控制器中的对象并将它们传递给模板或任何东西。甚至 JSON 格式也是必要的

标签: java hibernate jpa


【解决方案1】:

500 表示内部服务器错误,似乎引发了意外的异常,我明白为什么,您需要为生成的值指定策略,我相信您的目标是自动递增,因此您可以使用 AUTO

@Entity
@Table
public class Student implements Serializable {

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Integer id;

查看此link 了解有关您可以使用的策略的更多信息

【讨论】:

  • 我相信默认的是GenerationType.AUTO!因此,明确提及它不是强制性的。
【解决方案2】:

到目前为止,您还没有做任何可以显示用户数据的事情。您创建了一个模型类(学生)您实现了 CRUD 方法(它们应该使用 DAO 模式定义),您实现了控制器,但是在哪里应该显示数据的html/jsp? 建议你用spring来定义web服务,更简单更好;您还应该考虑调用 DAO 层的服务层,然后控制器调用服务。这样你就可以直接从控制器调用 CRUD 方法,这样你就可以将 web 层连接到 integration(db) 层:这是错误的。

实现一个jsp或一个html文件,你可以在其中显示一些东西。使用jsp标签或更新的东西(spring)来显示你想要的数据,然后看看Service层,DAO模式(但我想你已经知道了)和spring(你需要的模块是Ioc,依赖项和 mvc)。

更新: 我看到了你的堆栈跟踪。我不知道是不是同样的问题,看看这个: A message body writer for Java class not found

【讨论】:

    【解决方案3】:

    必须添加一些修改:

    1 - 你必须指定表名@Table(name = "table_name")

    2 - 您必须指定列名,例如:

       @Column(name="firstName")
       private String firstName;
    

    3 - 当您使用 HQL 时,您必须指定实体名称而不是表名称。在您的情况下,"SELECT * FROM students.... 将更改为 "SELECT * FROM Student

    【讨论】:

    • @Table 注释中指定名称不是强制性的。默认情况下,它采用下划线分隔的小写类名。 @Column 也是如此
    猜你喜欢
    • 1970-01-01
    • 2017-04-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-07-04
    • 1970-01-01
    • 2012-04-22
    相关资源
    最近更新 更多