初心者です。eclipseでH2データベースを使い、簡単な掲示板のようなものを作りたいのですが、実行すると例外が投げられます。No suitable driver found for~とコンソールに出ているのですが、データベースとうまく接続できていないのでしょうか?
データベースからSELECT文で取り出す処理だけを書いたクラスを作り、javaアプリケーションで実行した場合は、コンソールに正常に表示されるのですが、サーバーで実行するとうまくいきません。拡張for文のところでorg.apache.jasper.JasperException: An exception occurred processingと出ます。
コードに問題があるのか、JDBCドライバがうまく設置できていないのか、コードに問題がある場合どこがいけないのか教えていただきたいです。よろしくお願いします。
サーブレット
package
1 2import java.io.IOException; 3import java.util.List; 4 5import javax.servlet.RequestDispatcher; 6import javax.servlet.ServletException; 7import javax.servlet.annotation.WebServlet; 8import javax.servlet.http.HttpServlet; 9import javax.servlet.http.HttpServletRequest; 10import javax.servlet.http.HttpServletResponse; 11 12import ko.setu; 13import model.Beans; 14 15/** 16 * Servlet implementation class test1 17 */ 18@WebServlet("/test1") 19public class test1 extends HttpServlet { 20 private static final long serialVersionUID = 1L; 21 22 /** 23 * @see HttpServlet#HttpServlet() 24 */ 25 public test1() { 26 super(); 27 // TODO Auto-generated constructor stub 28 } 29 30 /** 31 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response) 32 */ 33 protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 34 // TODO Auto-generated method stub 35 response.getWriter().append("Served at: ").append(request.getContextPath()); 36 37 38 setu setu2=new setu(); 39 40 41 List<Beans> beansList=setu2.get(); 42 request.setAttribute("beansList",beansList); 43 44 45 RequestDispatcher dispatcher=request.getRequestDispatcher("/WEB-INF/lib/NewFilex.jsp"); 46 dispatcher.forward(request,response); 47 48 } 49 50 /** 51 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) 52 */ 53 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 54 // TODO Auto-generated method stub 55 doGet(request, response); 56 57 String a=request.getParameter("text"); 58 String b=request.getParameter("texn"); 59 String c=request.getParameter("texm"); 60 61 Beans beans=new Beans(a,b,c); 62 setu setu2=new setu(); 63 setu2.post(beans); 64 65 List<Beans> beansList=setu2.get(); 66 67 request.setAttribute("beansList",beansList); 68 69 RequestDispatcher dispatcher=request.getRequestDispatcher("/WEB-INF/lib/NewFilex.jsp"); 70 dispatcher.forward(request,response); 71 72 73 } 74 75} 76
スコープに保存するクラス
package
1 2import java.io.Serializable; 3 4public class Beans implements Serializable{ 5 6 private int id; 7 public String name; 8 public String doro; 9 public String text; 10 11 public Beans() {} 12 public Beans(int id,String name,String doro,String text) { 13 14 this.id=id; 15 this.name=name; 16 this.doro=doro; 17 this.text=text; 18 19 20 21 } 22 23 24public Beans(String name,String doro,String text) { 25 26 this.name=name; 27 this.doro=doro; 28 this.text=text; 29 30 31 32 } 33 34 35public int getId() {return id;} 36public String getName() {return name;} 37public String getDoro() {return doro;} 38public String getText() {return text;} 39 40 41 42 43 44 45} 46
データベースとの接続をするクラス```ここに言語を入力
コード
```package ko; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.ArrayList; import java.util.List; import model.Beans; public class setu { public void post(Beans beans) { try(Connection conn=DriverManager.getConnection("jdbc:h2:tcp://localhost/~/mydb","sa","")){ String sql="INSERT INTO TD(NAME,DORO,TEXT) VALUES(?,?,?)"; PreparedStatement stmt=conn.prepareStatement(sql); stmt.setString(1,beans.getName()); stmt.setString(2,beans.getDoro()); stmt.setString(3,beans.getText()); int i=stmt.executeUpdate(); }catch (SQLException e) { e.printStackTrace(); System.out.println("kamo"); } } public List<Beans> get() { List<Beans> beansList=new ArrayList<>(); try(Connection conn=DriverManager.getConnection("jdbc:h2:tcp://localhost/~/mydb","sa","")){ String spl="SELECT ID,NAME,DORO,TEXT FROM TD"; PreparedStatement stnt=conn.prepareStatement(spl); ResultSet rs=stnt.executeQuery(); while (rs.next()) { int id=rs.getInt("ID"); String name=rs.getString("NAME"); String doro=rs.getString("DORO"); String text=rs.getString("TEXT"); Beans beans=new Beans(id,name,doro,text); beansList.add(beans); } }catch (SQLException e) { e.printStackTrace(); return null; } return beansList; } }
表示するjspファイル
pageEncoding="UTF-8"%> <%@ page import="model.Beans,ko.setu,java.util.List" %> <% List<Beans> beansList=(List<Beans>)request.getAttribute("beansList");%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <form action="/ka/test1" method="Post"> <input type="text" name="text"> <input type="text" name="texn"> <input type="text" name="texm"> <input type="submit" value="e"> </form> <%for(Beans beans:beansList){%> <p><%= beans.getName()%>:<%= beans.getDoro()%>:<%= beans.getText()%>:<%= beans.getId() %></p> <% }%> </body> </html>
回答1件
あなたの回答
tips
プレビュー