データベースの値を取得し表示させたいのですが、エラーが出てしまいます。
商品の一覧を作っています。
データベースにある値をとりあえず表示させようとしたら以下のエラーメッセージが発生しました。
発生している問題・エラーメッセージ
タイプ 例外報告 メッセージ [jacket.jsp] の処理中に行番号 [37] で例外が発生しました。 説明 サーバーは予期しない条件に遭遇しました。それはリクエストの実行を妨げます。 例外 org.apache.jasper.JasperException: [jacket.jsp] の処理中に行番号 [37] で例外が発生しました。 34: <tr> 35: <th>名前</th> 36: </tr> 37: <%for(int i = 0; i < pb.size(); i++){ %> 38: <%ProductBeans a = (ProductBeans)pb.get(i);%> 39: <tr> 40: <td><%out.println(a.getProductId());%></td> Stacktrace: org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:626) org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:515) org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:385) org.apache.jasper.servlet.JspServlet.service(JspServlet.java:329) javax.servlet.http.HttpServlet.service(HttpServlet.java:733) org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) filter.Filter.doFilter(Filter.java:38) 根本原因 java.lang.NullPointerException org.apache.jsp.jacket_jsp._jspService(jacket_jsp.java:161) org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:71) javax.servlet.http.HttpServlet.service(HttpServlet.java:733) org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:477) org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:385) org.apache.jasper.servlet.JspServlet.service(JspServlet.java:329) javax.servlet.http.HttpServlet.service(HttpServlet.java:733) org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) filter.Filter.doFilter(Filter.java:38) 注意 原因のすべてのスタックトレースは、サーバのログに記録されています
該当のソースコード
jsp
1<%@ page language="java" contentType="text/html; charset=UTF-8" 2 pageEncoding="UTF-8"%> 3<%@page import="model.ProductBeans"%> 4<%@page import="java.util.List"%> 5<%@page import="dao.ProductDAO"%> 6<%@ page import="java.util.ArrayList" %> 7 8<% 9List<ProductBeans> pb = (List<ProductBeans>) request.getAttribute("proList"); 10%> 11 12<!doctype html> 13<html lang="ja"> 14<head> 15<meta charset="UTF-8"> 16<meta name="viewport" content="width=device-width, initial-scale=1"> 17<title>Duckstream:jacket</title> 18<meta name="keywords" content=""> 19<meta name="description" content=""> 20<link rel="icon" type="image/png" href="img/favicon.png"> 21<link rel="stylesheet" media="all" href="css/ress.min.css" /> 22<link rel="stylesheet" media="all" href="css/style.css" /> 23<link rel="stylesheet" media="all" href="css/ichiran.css" /> 24<script src="js/jquery-2.1.4.min.js"></script> 25<script src="js/style.js"></script> 26 27<!-- Favicon --> 28<link rel="icon" type="image/png" href="img/favicon.png"> 29</head> 30<body> 31 32 <div class="catch"> 33 <table> 34 <tr> 35 <th>名前</th> 36 </tr> 37 <%for(int i = 0; i < pb.size(); i++){ %> 38 <%ProductBeans a = (ProductBeans)pb.get(i);%> 39 <tr> 40 <td><%out.println(a.getProductId());%></td> 41 <td><%out.println(a.getProductName());%></td> 42 <td><%out.println(a.getProductPrice());%></td> 43 <td><%out.println(a.getProductDetail());%></td> 44 </tr> 45 <% } %> 46 </table> 47 <p></p> 48 </div> 49 <div id="column" class="column04"> 50 <ul> 51 52 </ul> 53 </div> 54 <div class="copyright"> 55 <a target="_blank">Copyright © Duckstream All Rights Reserved.</a> 56 </div> 57</body> 58 59</html>
java
1package dao; 2 3import java.sql.Connection; 4import java.sql.DriverManager; 5import java.sql.PreparedStatement; 6import java.sql.ResultSet; 7import java.sql.SQLException; 8import java.util.ArrayList; 9import java.util.List; 10 11import model.ProductBeans; 12 13public class ProductDAO { 14 // データベース接続に使用する情報 15 final String jdbcId = "root"; 16 final String jdbcPass = ""; 17 final String jdbcUrl = "jdbc:mysql://127.0.0.1:3306/duck"; 18 19 // 商品を探す 20 public List<ProductBeans> findAll() { 21 List<ProductBeans> proList = new ArrayList<>(); 22 23 24 25 // データベースへ接続 26 try { 27 Class.forName("com.mysql.jdbc.Driver"); 28 Connection con = DriverManager.getConnection(jdbcUrl, jdbcId, jdbcPass); 29 String sql = "SELECT * FROM product"; 30 PreparedStatement ps= con.prepareStatement(sql); 31 32 ResultSet rs = ps.executeQuery(); 33 34 35 if (rs.next()) { 36 // 見つかった商品情報を戻り値にセット 37 int productId = rs.getInt("product_id"); 38 String productName = rs.getString("product_name"); 39 int productPrice = rs.getInt("product_price"); 40 String productDetail = rs.getString("product_detail"); 41 ProductBeans productbeans = new ProductBeans(productId, productName, productPrice, productDetail); 42 proList.add(productbeans); 43 } else { 44 // 商品がなければnullを返す 45 return null; 46 } 47 } catch (SQLException e) { 48 e.printStackTrace(); 49 return null; 50 } catch (ClassNotFoundException e) { 51 System.out.println("ドライバを読み込めませんでした "+ e); 52 } 53 return proList; 54 } 55}
Beans
1package model; 2 3import java.io.Serializable; 4 5public class ProductBeans implements Serializable { 6 private static final long serialVersionUID = 1L; 7 8 private int productId; 9 private String productName; 10 private int productPrice; 11 private String productDetail; 12 13 14 public ProductBeans(int productId, String productName, int productPrice, String productDetail) { 15 this.productId = productId; 16 this.productName = productName; 17 this.productPrice = productPrice; 18 this.productDetail = productDetail; 19 } 20 public int getProductId() { 21 return productId; 22 } 23 public void setProductId(int productId) { 24 this.productId = productId; 25 } 26 public String getProductName() { 27 return productName; 28 } 29 public void setProductName(String productName) { 30 this.productName = productName; 31 } 32 public int getProductPrice() { 33 return productPrice; 34 } 35 public void setProductPrice(int productPrice) { 36 this.productPrice = productPrice; 37 } 38 public String getProductDetail() { 39 return productDetail; 40 } 41 public void setProductDetail(String productDetail) { 42 this.productDetail = productDetail; 43 } 44} 45
補足情報(FW/ツールのバージョンなど)
eclipse, phpmyadmin
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。