質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
DAO(Data Access Object)

DAO(Data Access Object)とは、データベースなどに保存するための操作を実装したオブジェクトのことです。データの永続化機構に抽象化されたインタフェースを提供し、データベースの詳細を隠蔽。ビジネスロジックとデータ操作も分離できます。

JSP

JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

1回答

714閲覧

データベースの値を表示させたい。

kakibayashi

総合スコア0

DAO(Data Access Object)

DAO(Data Access Object)とは、データベースなどに保存するための操作を実装したオブジェクトのことです。データの永続化機構に抽象化されたインタフェースを提供し、データベースの詳細を隠蔽。ビジネスロジックとデータ操作も分離できます。

JSP

JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

1クリップ

投稿2022/02/01 01:52

編集2022/02/01 02:00

データベースの値を取得し表示させたいのですが、エラーが出てしまいます。

商品の一覧を作っています。
データベースにある値をとりあえず表示させようとしたら以下のエラーメッセージが発生しました。

発生している問題・エラーメッセージ

タイプ 例外報告 メッセージ [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

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

根本原因
java.lang.NullPointerException

ProductDAO#findAll()は、nullを返すケースがある。
nullを返した時に、NullPointerExceptionが発生しているのでしょう。

java

1 } else { 2 // 商品がなければnullを返す 3 return null; 4 } 5 } catch (SQLException e) { 6 e.printStackTrace(); 7 return null;

まずは、JSPなんか噛ませずに、ProductDAOクラスのテストを書いてみてはどうでしょうか。テストはあなたの思惑通りに動いていますか?

投稿2022/02/01 02:06

shiketa

総合スコア3971

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問