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

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

ただいまの
回答率

90.40%

  • Java

    16452questions

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

  • Spring

    901questions

    Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

  • Spring Boot

    781questions

    Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

springbootでの検索画面について

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 1,350

heavyuseman

score 34

いつもお世話になっております。 
springbootで会員検索画面を作成しました。 
First画面(会員検索画面)を開き、検索する名前とパスワードを入力し 
検索ボタンを押下しましたが検索がうまくできず、下記のエラーが出ました

2017-05-24 20:41:46.879  INFO 1425 --- [nio-8080-exec-5] o.h.h.i.QueryTranslatorFactoryInitiator  : HHH000397: Using ASTQueryTranslatorFactory
listは[]
2017-05-24 20:41:49.075 ERROR 1425 --- [nio-8080-exec-8] o.a.c.c.C.[.[.[/].[dispatcherServlet]    : Servlet.service() for servlet dispatcherServlet threw exception

ログの結果である
listは[]

    //firstPost画面呼び出し
    @RequestMapping(value="/First",method=RequestMethod.POST)
    public ModelAndView FirstPost(@ModelAttribute("formModel") String newaccount,ModelAndView mav){
        List<Newaccount> list = dataAccessRepository.findByName(newaccount);
        System.out.println("listは"+list);
        mav.addObject("datalist",list);
    return mav;
}


の結果であり、listの結果が空でした。
原因が不明ですのでご教授よろしくお願いいたします。

package com.tuyano.springboot.app;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.http.MediaType;
import org.springframework.stereotype.Controller;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.servlet.ModelAndView;
import com.fasterxml.jackson.databind.SerializationFeature;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.tuyano.springboot.app.Emp;
import com.tuyano.springboot.app.EmpRepository;
import com.tuyano.springboot.dateaccess.DataAccessRepository;
import com.tuyano.springboot.dateaccess.Newaccount;




@Controller
@EnableAutoConfiguration
public class Test {

    @Autowired //リポジトリを紐づけます
    EmpRepository repository;
    @Autowired //リポジトリを紐づけます
    DataAccessRepository dataAccessRepository;
    @RequestMapping(value="/")
    @ResponseBody
    public String home(){
    //json値格納変数
    String jsonvalue;
     //全件取得します
    Iterable<Emp> list = repository.findAll();

        // 取得した内容を出力します
        for(Emp emp: list){
        //Jacksonでオブジェクトを JSON に変換
        ObjectMapper objectMapper = new ObjectMapper();
        try {
            jsonvalue = objectMapper.writeValueAsString(emp);
        System.out.println("jsonの値"+jsonvalue);
        return jsonvalue;
        }catch (JsonProcessingException e) {
            e.printStackTrace();
        }
        }
        return null;

    }
    //firstGet画面呼び出し
    @RequestMapping(value="/First",method=RequestMethod.GET)
    public String FirstGet(){

        return null;
    }
    //firstPost画面呼び出し
    @RequestMapping(value="/First",method=RequestMethod.POST)
    public ModelAndView FirstPost(@ModelAttribute("formModel") String newaccount,ModelAndView mav){
        List<Newaccount> list = dataAccessRepository.findByName(newaccount);
        System.out.println("listは"+list);
        mav.addObject("datalist",list);
    return mav;
}
    //NewAccountGet画面呼び出し
    @RequestMapping(value="/NewAccount",method=RequestMethod.GET)
    public String NewAccountGet(){

        return null;
    }
    //NewAccountPost画面呼び出し
    @RequestMapping(value="/NewAccount",method=RequestMethod.POST)
    @Transactional(readOnly=false)
    public ModelAndView NewAccountPost(@ModelAttribute("formModel") Newaccount newaccount,ModelAndView mav){
        System.out.println("newaccountは"+newaccount);
        dataAccessRepository.saveAndFlush(newaccount);
        return new ModelAndView("redirect:/NewAccount");
    }
    //MemberGet画面呼び出し
        @RequestMapping(value="/Member",method=RequestMethod.GET)
        public String MemberGet(){

            return null;
        }
   //MemberPost画面呼び出し
        @RequestMapping(value="/Member",method=RequestMethod.POST)
        public ModelAndView MemberPost(@ModelAttribute("formModel") Newaccount newaccount,ModelAndView mav){
            System.out.println("newaccountは"+newaccount);
            dataAccessRepository.saveAndFlush(newaccount);
            return new ModelAndView("redirect:/NewAccount");
        }

}
package com.tuyano.springboot.dateaccess;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;


@Entity// このクラスはEntityとして登録しますよ、とspringに教えてます
public class Newaccount {

    @Id// プライマリーキーのものに設定してください
    @GeneratedValue// 主に数字に対して、順番に一意に設定しますよ、の意味
    private Integer ID;

    @Column// ただの変数じゃなくて、DBのカラムだよ、の意味
    private String name;
    @Column// 
    private int password;
    @Column// 
    private String address;
    // setter & getter ---------------------
    public Integer getID() {
        return ID;
    }
    public String getName(){
        return name;
    }
    public int getPassword(){
        return password;
    }
    public String getAddress(){
        return address;
    }

    public void setEmpID(Integer ID) {
        this.ID = ID;
    }

    public void setName(String name) {
        this.name = name;
    }

    public void setPassword(int password) {
        this.password = password;
    }

    public void setAddress(String address) {
        this.address = address;
    }



    // constructor --------------------------
    public Newaccount(){
        super();
    }

    public Newaccount(Integer ID, String name,int password,String address){
        super();
        this.ID =ID;
        this.name = name;
        this.password = password;
        this.address = address;
    }

}
package com.tuyano.springboot.dateaccess;

import java.util.List;

import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;



@Repository
public interface DataAccessRepository extends JpaRepository<Newaccount, Integer>{
    public List<Newaccount> findByName(String s);
}
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<title>top page</title>
<meta http-equiv="Content-Type"
content="text/html" charset="UTF-8"/>

<!-- css -->

<style>
    html { height: 100% }
    body { height: 100%; margin: 0; padding: 0 }
    #map { height: 100% }
</style>




</head>
<body>

   <h1 th:text="${title}">find Page</h1>
   <table>
  <form method="post" action="/First" th:object="${formModel}">
 <tr><td>名前</td>
 <td><input type="text" id="name"  name="name" size="20" th:value="${name}"/></td></tr>
 <tr><td>パスワード</td>
 <td><input type="text" id="password" name="password" size="20" th:value="${password}"/></td></tr>
 <tr><td>住所</td>
 <td><input type="text" id="address" name="address" size="20" th:value="${address}"/></td></tr>
 <tr><td></td><td><input type="submit" /></td></tr>
 </form> 
 </table>
 <hr/>
                    <form action="urlForUpload" enctype="multipart/form-data" method="post">
                        <div class="form-group">
                            <label>■ファイル種類:</label>
                            <select id="select_file_type" name="select_file_type" required="">
                                <option value="login-user">ログインユーザー</option>
                                <!-- アップロードするファイルを定義していく -->
                            </select>
                        </div>
                        <div class="form-group">
                            <label>■ファイルパス:</label>
                            <input type="file" id="upload_file" name="upload_file" required="" />
                        </div>
                        <div class="form-group">
                            <input id="data_upload_button" type="submit" value="アップロード" />
                        </div>
                    </form>
                    <table>
<tr><th>名前</th><th>住所</th></tr>
<tr th:each="obj :${datalist}">
<td th:text="${obj.name}"></td>

</tr>
</table>

</body>
</html>
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

<form method="post" action="/First" th:object="${formModel}">

で送信した内容を、

@RequestMapping(value="/First",method=RequestMethod.POST)
public ModelAndView FirstPost(@ModelAttribute("formModel") String newaccount,ModelAndView mav){
        List<Newaccount> list = dataAccessRepository.findByName(newaccount);
        System.out.println("listは"+list);
        mav.addObject("datalist",list);
return mav;

@ModelAttribute("formModel") String newaccount で受け取っていますが、以下の理由で取得できていません

  1. formがSpringMVCのformで送信していないのに、formModelを指定して取得しようとしている
  2. 送信パラメータはいくつかある(name,password,address)が、これに対応した同じ名前の変数で受け取っていない。

他のメソッドを見た限りではnewaccountは Newaccountクラスで受け取っていますので、もし "formModel"の名前で画面側と受け渡しをしたいのであれば、SpringMVCのformタグを用いてModelAttibuteの名前を定義し、受け取るメソッド側も修正します。

<form:form method="post" action="/First" th:object="${formModel}" modelAttribute="formModel">
@RequestMapping(value="/First",method=RequestMethod.POST)
public ModelAndView FirstPost(@ModelAttribute("formModel") Newaccount newaccount,ModelAndView mav){
        ......
    return mav;
}

参考までに:
株式会社CONFRAGE ITソリューション事業部:SpringMVCで@ModelAttributeアノテーションを使用する
Qiita:Springで画面の入力値を受け取る

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/05/27 00:03

    ご回答ありがとうございます。
    2.送信パラメータはいくつかある(name,password,address)が、これに対応した同じ名前の変数で受け取っていない。
    上記に対応するためにFirstpostメソッドを
    //firstPost画面呼び出し
    @RequestMapping(value="/First",method=RequestMethod.POST)
    public ModelAndView FirstPost(@RequestParam("name") String param,ModelAndView mav){
    List<Newaccount> list = dataAccessRepository.findByName(param);
    System.out.println("listは"+list);
    mav.addObject("datalist",list);
    return mav;
    }
    のように修正し、名前から検索することができるようになりました。

    キャンセル

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

  • ただいまの回答率 90.40%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • Java

    16452questions

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

  • Spring

    901questions

    Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

  • Spring Boot

    781questions

    Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。