『http://localhost:8080/baseball_task/index』にアクセスすると現在のメッセージの登録件数である0が表示させたいのですが、以下のエラーが出ます。
エラー原因がjava.lang.NoClassDefFoundError: javax/persistence/Persistenceの為ファイル名のスペルチェックを行いましたが、誤りを見つけることが出来ませんでした。どちらに原因がある可能性が考えられるでしょうか?
ご回答よろしくお願い致します。
DBUtil.javaのコードは以下です。
package utils; import javax.persistence.EntityManager; import javax.persistence.EntityManagerFactory; import javax.persistence.Persistence; public class DBUtil { private static final String PERSISTENCE_UNIT_NAME = "baseball_task"; private static EntityManagerFactory emf; public static EntityManager createEntityManager() { return _getEntityManagerFactory().createEntityManager(); } private static EntityManagerFactory _getEntityManagerFactory() { if(emf == null) { emf = Persistence.createEntityManagerFactory(PERSISTENCE_UNIT_NAME); } return emf; } }
IndexServlet.javaは以下です。
package controllers; import java.io.IOException; import java.util.List; import javax.persistence.EntityManager; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import models.Message; import utils.DBUtil; /** * Servlet implementation class IndexServlet */ @WebServlet("/index") public class IndexServlet extends HttpServlet { private static final long serialVersionUID = 1L; /** * @see HttpServlet#HttpServlet() */ public IndexServlet() { super(); // TODO Auto-generated constructor stub } /** * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response) */ protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { EntityManager em = DBUtil.createEntityManager(); List<Message>messages = em.createNamedQuery("getAllMessages",Message.class) .getResultList(); response.getWriter().append(Integer.valueOf(messages.size()).toString()); em.close(); } }
他の設定は以下の通り行なっています。
JPAプロジェクトを立ち上げて、プロジェクト・ファセットの画面では初期状態で、以下で設定しています。プラットフォーム:Generic 2.1
JPA実装:ライブラリー構成を無効
接続:なし
永続化クラス管理:注釈付きクラスを persistence.xml に記述
persistence.xml の設定を以下でしています。
一般タブ
名前 : baseball_task
永続化プロバイダー : org.hibernate.jpa.HibernatePersistenceProvider
接続タブ
ドライバー:com.mysql.jdbc.Driver
URL : jdbc:mysql: //localhost/message_boarduseSSL=false&useUnicode=true&characterEncoding=utf8
ユーザ名 : 設定済
パスワード : 設定済
スキーマ生成タブ
Database action:作成
Scripts generation:デフォルト(なし)
プロパティータブ
名前 : hibernate.dialect
値 : org.hibernate.dialect.MySQL5Dialect
名前 : hibernate.show_sql
値 : true
名前 : hibernate.format_sql
値 : true
DTOのクラスである、Message.javaは以下です。
package models; import java.sql.Timestamp; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.NamedQueries; import javax.persistence.NamedQuery; import javax.persistence.Table; @Entity @NamedQueries({ @NamedQuery( name = "getAllMessages", query = "SELECT m FROM Message AS m ORDER BY m.id DESC" ) }) @Table(name = "messages") public class Message { @Id @Column(name = "id") @GeneratedValue(strategy = GenerationType.IDENTITY) private Integer id; @Column(name="title", length=255, nullable=false) private String titie; @Column(name="content", length=255 , nullable=false) private String content; @Column(name="created_at" , nullable=false) private Timestamp created_at; @Column(name="updated_at" , nullable=false) private Timestamp updated_at; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getTitie() { return titie; } public void setTitie(String titie) { this.titie = titie; } public String getContent() { return content; } public void setContent(String content) { this.content = content; } public Timestamp getCreated_at() { return created_at; } public void setCreated_at(Timestamp created_at) { this.created_at = created_at; } public Timestamp getUpdated_at() { return updated_at; } public void setUpdated_at(Timestamp updated_at) { this.updated_at = updated_at; } }
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/07/23 08:27
2019/07/23 08:28
2019/07/23 08:29
2019/07/23 08:34
2019/07/23 08:43 編集
2019/07/23 08:53
2019/07/25 06:40
2019/07/25 06:42
2019/07/25 07:11
2019/07/25 08:29
2019/07/25 09:10
2019/07/26 06:04
2019/07/26 06:05
2019/07/26 07:52
2019/07/26 07:53