teratail header banner
teratail header banner
質問するログイン新規登録

質問編集履歴

1

ああああああああああああああああああ

2022/05/17 11:10

投稿

wassan_nikoniko
wassan_nikoniko

スコア9

title CHANGED
@@ -1,1 +1,1 @@
1
- jspで受け取った値を、次のjspにEL式で出力したい。
1
+ ああああああああああああああああああ
body CHANGED
@@ -1,329 +1,1 @@
1
- ### 前提・実現したいこと
2
- ProductInfo.jspで受け取った値を、ProductList.jspにEL式で出力をしたい
3
- ### 発生している問題・エラーメッセージ
4
-
5
- ```
6
- タイプ 例外報告
7
-
8
- メッセージ [WEB-INF/jsp/ProductList.jsp] の処理中に行番号 [30] で例外が発生しました。
9
-
10
- 説明 サーバーは予期しない条件に遭遇しました。それはリクエストの実行を妨げます。
11
-
12
- 例外
13
-
14
- org.apache.jasper.JasperException: [WEB-INF/jsp/ProductList.jsp] の処理中に行番号 [30] で例外が発生しました。
15
-
16
- 27: </tr>
17
- 28: <!-- 二行目 -->
18
- 29: <tr>
19
- 30: <td> ${Product.Productid}</td>
20
- 31: <td><img class="watch" src="image/Aandyou_SW_E07_一覧用.png"></td>
21
- 32: <td><%=product.getProductmaker()%></td>
22
- 33: <td><%=product.getProductname()%></td>
23
-
24
-
25
-
26
- 根本原因
27
-
28
- javax.el.PropertyNotFoundException: プロパティ[Productid]がタイプ[dto.Product]で見つかりません
29
- 以下文字数制限のため省略
30
- ```
31
-
32
-
33
- ### 該当のソースコード
34
-
35
- ```servlet
36
- package sample;
37
-
38
- import java.io.IOException;
39
- import java.sql.SQLException;
40
-
41
- import javax.servlet.RequestDispatcher;
42
- import javax.servlet.ServletException;
43
- import javax.servlet.annotation.WebServlet;
44
- import javax.servlet.http.HttpServlet;
45
- import javax.servlet.http.HttpServletRequest;
46
- import javax.servlet.http.HttpServletResponse;
47
-
48
- import dao.ProductDao;
49
- import dto.Product;
50
-
51
- /**
52
- * Servlet implementation class ProductInfoServlet
53
- */
54
- @WebServlet("/ProductInfoServlet")
55
- public class ProductInfoServlet extends HttpServlet {
56
- private static final long serialVersionUID = 1L;
57
-
58
- /**
59
- * @see HttpServlet#HttpServlet()
60
- */
61
- public ProductInfoServlet() {
62
- super();
63
- // TODO Auto-generated constructor stub
64
- }
65
-
66
- /**
67
- * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
68
- */
69
- protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
70
- RequestDispatcher rd=request.getRequestDispatcher("WEB-INF/jsp/ProductInfo.jsp");
71
- rd.forward(request, response);
72
-
73
- }
74
-
75
- /**
76
- * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
77
- */
78
- protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
79
- //値をgetする
80
- int Productid=Integer.parseInt(request.getParameter("Productid"));
81
- String Productgenrecode=request.getParameter("ProductGenreCode");
82
- String Productname=request.getParameter("Productname");
83
- String Productmaker=request.getParameter("Productmaker");
84
- int Productprice=Integer.parseInt(request.getParameter("Productprice"));
85
- int Productstock=Integer.parseInt(request.getParameter("Productstock"));
86
- int Productsales=Integer.parseInt(request.getParameter("Productsales"));
87
- String Productremarks=request.getParameter("remarks");
88
-
89
- //コンソール上に出力
90
- System.out.println(Productid);
91
- System.out.println(Productgenrecode);
92
- System.out.println(Productmaker);
93
- System.out.println(Productname);
94
- System.out.println(Productprice);
95
- System.out.println(Productstock);
96
- System.out.println(Productsales);
97
- System.out.println(Productremarks);
98
-
99
-
100
-
101
- Product p =new Product();
102
- p.setProductid(Productid);
103
- p.setProductgenre(Productgenrecode);
1
+ ああああああああああああああああああああああああああああああああああああ
104
- p.setProductname(Productname);
105
- p.setProductmaker(Productmaker);
106
- p.setProductprice(Productprice);
107
- p.setProductstock(Productstock);
108
- p.setProductsales(Productsales);
109
-
110
- //insertメソッドを実行する。
111
- ProductDao productdao =new ProductDao();
112
- try {
113
- productdao.insertsqlinfo(p);
114
- } catch(SQLException e) {
115
- e.printStackTrace();
116
- }
117
-
118
- //リクエストスコープに値を入れ込む。
119
- request.setAttribute("product",p);
120
-
121
- //フォワード処理
122
- RequestDispatcher rd=request.getRequestDispatcher("WEB-INF/jsp/ProductList.jsp");
123
- rd.forward(request, response);
124
- }
125
-
126
- }
127
-
128
- ```
129
-
130
- ```dto
131
-
132
- package dto;
133
-
134
- public class Product implements java.io.Serializable{
135
- //javabeans
136
- //フィールド定義
137
- private int Productid;
138
- private String Productmaker;
139
- private String Productname;
140
- private String Productgenre;
141
- private int Productstock;
142
- private int Productsales;
143
- private int Productprice;
144
- private String Productremarks;
145
-
146
- //getter setterの定義
147
- public int getProductid() {
148
- return Productid;
149
- }
150
- public void setProductid(int productid) {
151
- Productid = productid;
152
- }
153
- public String getProductmaker() {
154
- return Productmaker;
155
- }
156
- public void setProductmaker(String productmaker) {
157
- Productmaker = productmaker;
158
- }
159
- public String getProductname() {
160
- return Productname;
161
- }
162
- public void setProductname(String productname) {
163
- Productname = productname;
164
- }
165
- public String getProductgenre() {
166
- return Productgenre;
167
- }
168
- public void setProductgenre(String productgenre) {
169
- Productgenre = productgenre;
170
- }
171
- public int getProductstock() {
172
- return Productstock;
173
- }
174
- public void setProductstock(int productstock) {
175
- Productstock = productstock;
176
- }
177
- public int getProductsales() {
178
- return Productsales;
179
- }
180
- public void setProductsales(int productsales) {
181
- Productsales = productsales;
182
- }
183
- public int getProductprice() {
184
- return Productprice;
185
- }
186
- public void setProductprice(int productprice) {
187
- Productprice = productprice;
188
- }
189
- public String getProductremarks() {
190
- return Productremarks;
191
- }
192
- public void setProductremarks(String productremarks) {
193
- Productremarks = productremarks;
194
- }
195
-
196
-
197
-
198
-
199
- }
200
-
201
- ```
202
- ```jsp
203
- <%@ page language="java" contentType="text/html; charset=UTF-8"
204
- pageEncoding="UTF-8"%>
205
- <!DOCTYPE html>
206
- <html lang="ja" dir="ltr">
207
- <head>
208
- <meta charset="utf-8">
209
- <link rel="stylesheet" type="text/css" href="<%=request.getContextPath() %>/css/style.css">
210
- <title>商品情報管理システム</title>
211
- </head>
212
- <body>
213
- <h1>在庫管理システム</h1>
214
- <input class="input1" type="image" name="検索" value="検索" src="image/検索1.png">
215
- <input type="image" name="検索" value="検索" src="image/検索1.png"><br>
216
- <table border="1">
217
- <!-- 1行目 -->
218
- <tr>
219
- <th>商品ID</th>
220
- <th>画像</th>
221
- <th>メーカー名</th>
222
- <th>商品名</th>
223
- <th>ジャンル</th>
224
- <th>在庫数</th>
225
- <th>販売個数</th>
226
- <th>価格</th>
227
- </tr>
228
- <!-- 二行目 -->
229
- <tr>
230
- <td> ${product.Productid}</td>
231
- <td><img class="watch" src="image/Aandyou_SW_E07_一覧用.png"></td>
232
- <td>${product.Productmaker}</td>
233
- <td>${product.Productname}</td>
234
- <td>${product.Productgenre}</td>
235
- <td>${product.Productstock}</td>
236
- <td>${product.Productsales}</td>
237
- <td>${product.Productprice}</td>
238
- </tr>
239
- </table>
240
- </body>
241
- </html>
242
-
243
- ```
244
- ```jsp
245
- <%@ page language="java" contentType="text/html; charset=UTF-8"
246
- pageEncoding="UTF-8"%>
247
- <%@ page import="enums.ProductGenre"%>
248
- <%@ page import="enums.ProductMaker"%>
249
- <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
250
- <!DOCTYPE html>
251
- <html>
252
- <head>
253
- <link rel="stylesheet" type="text/css"
254
- href="<%=request.getContextPath() %>/css/ProductInfo.css">
255
- <meta charset="UTF-8">
256
- <title>商品情報登録</title>
257
- </head>
258
- <body>
259
- <form action="/pda.k.oonuki/ProductInfoServlet" method="POST">
260
- <div class="row">
261
- <p>商品ID</p>
262
- <p>ジャンル</p>
263
- </div>
264
-
265
- <input type="text" name="Productid">
266
- <!--<select name="Productgenre">
267
- <option value="時計">時計</option>
268
- <option value="電子機器">電子機器</option>
269
- <option value="携帯">携帯</option>
270
- </select> -->
271
-
272
- <select name="ProductGenreCode">
273
- <c:forEach var="genre" items="${ProductGenre.values()}">
274
- <option value="${genre.genrecode }">${genre.genrename}</option>
275
- </c:forEach>
276
- </select>
277
-
278
-
279
- <div class="row">
280
- <p>商品名</p>
281
- <p>メーカー名</p>
282
- </div>
283
-
284
- <input type="text" name="Productname">
285
-
286
- <!-- <select name="Productmaker">
287
- <option value="パナソニック">パナソニック</option>
288
- <option value="ソニー">ソニー</option>
289
- <option value="シャープ">シャープ</option>
290
- </select> -->
291
- <select name="productMaker">
292
- <c:forEach var="maker" items="${ProductMaker.values() }">
293
- <option value="${maker.makername}">
294
- ${maker.makername}</option>
295
- </c:forEach>
296
- </select>
297
-
298
- <div class="row">
299
- <p>金額</p>
300
- <p>在庫数</p>
301
- </div>
302
-
303
- <input type="text" name="Productprice"> <input type="text"
304
- name="Productstock">
305
-
306
- <div class="row">
307
- <p>販売個数</p>
308
- </div>
309
-
310
- <input type="text" name="Productsales">
311
-
312
- <div class="row">
313
- <p>備考</p>
314
- </div>
315
-
316
- <textarea name="remarks" rows="5"></textarea>
317
- <br>
318
- <button type="submit" name="submit">登録</button>
319
- </form>
320
- </body>
321
- </html>
322
- ```
323
-
324
- ### 試したこと
325
- EL式の記述方法について調べ、${リクエストスコープのデータ名.受け取ったインスタンスのプロパティ}
326
- という方法で記述をしているのですが、間違っていましたでしょうか?
327
-
328
- また、こちら初学者のため、EL式などの記述の方法等詳しいサイトなど調べたつもりですが何かおすすめのサイトなどございましたら
329
- 教えていただけると幸いです。