前提・実現したいこと
はじめまして。3か月前に未経験でIT企業に入社し、研修を受けているものです。
講師の方にもわからないといわれてしまったので皆さんのお力をお借りしたく投稿させていただきました。
今、SpringとOracleDBを接続して、formで入力された範囲の価格検索を行うプログラムを書こうとしています。
今は自分の書いたものがどこまでなら動くのか試しているところなので、実際にDBのデータをとるところまで動かしているわけではないのですが、この段階ですでにおかしいので質問させていただきました。
まずつくりとしては、入力フォームに値を一つずつ入力し、sidebar.html内でname="priceMin"/"priceMax"として受け取り、それをGET送信でコントローラーに送っています。
コントローラーでは受け取った値を同じ名前で使っていて、PriceFormで定義した入力チェックをクリアしたかどうかでif文で分岐するようになっています。どのようなルートを通っているかを確認するためにところどころにコンソール上に文字が表示されるようにしているのですが、なぜかメソッド全体が二回繰り返されています。何が原因なのでしょうか?
発生している問題・エラーメッセージ
1:実行するとコンソール上で2回同じ文が表示される(二回同じメソッドが繰り返し実行されている?) 2:表示されているエラー文↓ WARN 16572 --- [io-55000-exec-4] o.springframework.validation.DataBinder : Skipping URI variable 'priceMin' because request contains bind value with same name. (※priceMaxに関しても同じエラーが出ています。) 3:今はコメントアウトしてあるのですが、コントローラーのif文のelseの中のrepositoryからクエリを呼び出す一文のコメントアウトを外すと画面遷移がうまくいかなくなります。
該当のソースコード
Java
1//sidebar.html 2 3<div class="form" 4 th:if="${session.user == null or session.user.authority == 2}"> 5 <h2 class="title">価格別検索</h2> 6 <form method="get" th:action="@{/shared_shop/item/list/price/{priceMin}/{priceMax} 7 (priceMin=${'priceMin'},priceMax=${'priceMax'})}"> 8 9 <input type="text" name="priceMin" />円~<input type="text" name="priceMax" />円 10 <input type="submit" value="検索" /> 11 </form> 12 </div> 13 14 15//ItemShowCostomoerController 16 17 @RequestMapping(path = "/shared_shop/item/list/price/{priceMin}/{priceMax}",method = RequestMethod.GET) 18 public String showPrice(@Valid @ModelAttribute PriceForm form , BindingResult result,Model model, 19 String priceMin, String priceMax) { 20 21 System.out.println("Min:"+priceMin); 22 System.out.println("Max:"+priceMax); 23 24 25 26 27 if (result.hasErrors()) { 28 model.addAttribute("errMessage","正しい価格を入力してください"); 29 30 System.out.println("入力チェック×"); 31 32 33 }else { 34 35 36 37//model.addAttribute("items",itemRepository.findByPriceQuery(priceMin,priceMax)); 38 System.out.println("入力チェッククリア"); 39 40 41 42 } 43 return "item/list/item_list"; 44 45 } 46 47 48//PriceForm 49 @NotBlank 50 @Pattern(regexp = "^[0-9]{1,7}$") 51 private String priceMin; 52 53 54 @NotBlank 55 @Pattern(regexp = "^[0-9]{1,7}$") 56 private String priceMax; 57//この下にgetterとsetterがあります。 58 59//ItemRepository 60@Repository 61public interface ItemRepository extends JpaRepository<Item, Integer> { 62 63 64 // 商品情報を新着順で検索 65 public Page<Item> findByDeleteFlagOrderByInsertDateDesc(int deleteFlag, Pageable pageable); 66 67 //入力された値をもとに範囲検索をするクエリ文(追加機能) 68 @Query("SELECT i FROM Item i WHERE :priceMax>=i.price AND i.price>=:priceMin") 69 public List<Item>findByPriceQuery(String priceMin, String priceMax); 70 71} 72 73
試したこと
HTMLとControllerで使っている変巣名が同じなのがいけないのかと思い、html内での変数名をpriceMin、name=を"priceMinN"、コントローラーで受け取った後の名前を@pathVariableでpriceMinPなどに変えてみたのですが、System.out.printで一回目の繰り返しで「priceMin」、二回目の繰り返しで「{priceMin}」と表示されました。
また、@pathVariableがいけないのかと思い、うえで試したことを@pathVariableなしで暗示的にできないかなーと試してみたところ。「Null」と表示されました。このときはskipされたという旨のエラーは出ませんでした。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。