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

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

新規登録して質問してみよう
ただいま回答率
85.48%
JSP

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

Java

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

servlet

Servletとは、Webページの動的な生成やデータ処理などをサーバ上で実行するために、Javaで作成されたプログラムです。 ショッピングサイトやオンラインバンキングといった、動的なウェブサイトの構築に用いられています。

Q&A

1回答

518閲覧

サーブレット質問。よろしくお願いいたします。

sinzuku123321

総合スコア3

JSP

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

Java

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

servlet

Servletとは、Webページの動的な生成やデータ処理などをサーバ上で実行するために、Javaで作成されたプログラムです。 ショッピングサイトやオンラインバンキングといった、動的なウェブサイトの構築に用いられています。

0グッド

0クリップ

投稿2022/06/17 05:50

Java・Servlet・JSPについて質問があります。

サーブレットを実装していますが、エラーが表示されます。

Java

1コード 2DAO 3 4public ArrayList<MenuSearchBean> kensaku(String SHOP_NAME){ 5 ArrayList<MenuSearchBean> list = new ArrayList<MenuSearchBean>(); 6 String name="%" + SHOP_NAME+"%"; 7 8 String sql="select SHOP_ID ,SHOP_NAME,SHOP_TIPS,PRICE_RANGE,TAKEOUT,ANTI_COVID,CATEGORY_NAME from shop inner join category on shop.CATEGORY_ID = category.CATEGORY_ID where SHOP_NAME like ? "; 9 10 try { 11 12 connect(); 13 14 PreparedStatement ps = getConnection().prepareStatement(sql); 15 16 17 ResultSet rs = ps.executeQuery(); 18 ps.setString(1,name); 19 20 21 while (rs.next()) { 22 MenuSearchBean bean = new MenuSearchBean(); 23 bean.setShopName(rs.getString("SHOP_NAME")); 24 bean.setId(rs.getInt("SHOP_ID")); 25 bean.setTips(rs.getString("SHOP_TIPS")); 26 bean.setCat(rs.getString("CATEGORY_NAME")); 27 bean.setPrice(rs.getString("PRICE_RANGE")); 28 bean.setTakeOut(rs.getString("TAKEOUT")); 29 bean.setCovid(rs.getString("ANTI_COVID")); 30 list.add(bean); 31 } 32 33 } catch (Exception e) { 34 e.printStackTrace(); 35 } finally { 36 disconnect(); 37 } 38 return list; 39 40 }

Java

1 2 3public class MenuListServlet extends HttpServlet { 4 5 public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 6 doPost(request, response); 7 } 8 9 public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 10 HttpSession session=request.getSession(); 11 12 request.setCharacterEncoding("UTF-8"); 13 response.setContentType("text/html;charset= UTF-8"); 14 15 MenuSearchDAO dao=new MenuSearchDAO(); 16 //String name=request.getParameter("name"); 17 dao.kensaku(request.getParameter("name")); 18 19 20 RequestDispatcher rd = request.getRequestDispatcher("/web/menu.jsp?no=1"); 21 rd.forward(request, response); 22 } 23}

Java

1menu.jsp 2 3<%if(no==1){ %> 4 <%ArrayList<MenuSearchBean> list2=(ArrayList<MenuSearchBean>)request.getAttribute("list"); %> 5<table border="1"> 6<p></p> 7<%for(int i=0;i<list2.size();i++){ %> 8<tr><td colspan="2"><a href=""><%=list2.get(i).getShopName() %> </a></td><tr> 9<tr><td ><%=list2.get(i).getTips() %></td><td><%=list2.get(i).getCat() %></td></tr> 10<tr><td>価格帯</td><td><%=list2.get(i).getPrice() %></td></tr> 11 12<tr><td> 感染対策</td> 13<td><%=list2.get(i).getCovid() %></td></tr> 14 15<tr><td>テイクアウト</td> 16<td><%=list2.get(i).getTakeOut() %></td></tr> 17 18 19<%}} %>
タイプ 例外報告 メッセージ [web/menu.jsp] の処理中に行番号 [66] で例外が発生しました。 説明 サーバーは予期しない条件に遭遇しました。それはリクエストの実行を妨げます。 例外 org.apache.jasper.JasperException: [web/menu.jsp] の処理中に行番号 [66] で例外が発生しました。 63: <%ArrayList<MenuSearchBean> list=(ArrayList<MenuSearchBean>)request.getAttribute("list"); %> 64: <table border="1"> 65: <p></p> 66: <%for(int i=0;i<list.size();i++){ %> 67: <tr><td colspan="2"><a href=""><%=list.get(i).getShopName() %> </a></td><tr> 68: <tr><td ><%=list.get(i).getTips() %></td><td><%=list.get(i).getCat() %></td></tr> 69: <tr><td>価格帯</td><td><%=list.get(i).getPrice() %></td></tr> Stacktrace: org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:610) org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:499) org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:379) org.apache.jasper.servlet.JspServlet.service(JspServlet.java:327) javax.servlet.http.HttpServlet.service(HttpServlet.java:764) org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) Search.MenuListServlet.doPost(MenuListServlet.java:37) javax.servlet.http.HttpServlet.service(HttpServlet.java:681) javax.servlet.http.HttpServlet.service(HttpServlet.java:764) org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)

以上のようなエラーメッセージが表示されます。

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

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

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

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

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

m.ts10806

2022/06/17 06:17

回答してしまいましたが、タイトルに中身がありません。 要件を記載してください。 質問タグで表現できることはタイトルに書く必要はないです。
guest

回答1

0

MenuSearchDAO.kensaku()は呼び出されただけで返却値を受け取っていなく

dao.kensaku(request.getParameter("name"));

また[list]というキーがjspに対して渡されていません。
ゆえに、request.getAttribute()で存在しないキーに対するアクセスしようとして出ているエラーなのでは。

投稿2022/06/17 06:15

編集2022/06/17 06:16
m.ts10806

総合スコア80850

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問