このエラーが発生しています:HTTP Status 405 - Request method 'POST' not supported
私がやろうとしているのは、別のドロップダウンボックスで選択された他の値に基づいて入力されるドロップダウンボックスを持つフォームを作成することです。たとえば、customerName
ボックスで名前を選択すると、.jspページのonChange
関数が実行され、customerCountry
ボックスの対応する値でページが再度送信されます。
ただし、このHTTPステータス405エラーが発生しています。インターネットで解決策を検索しましたが、助けになるものが見つかりませんでした。コードの関連部分は次のとおりです。
jspページの一部
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<style>
.error { color: red; }
</style>
<script>
function repopulate(){
document.deliveryForm.submit();
}
function setFalse(){
document.getElementById("hasId").value ="false";
document.deliveryForm.submit();
// document.submitForm.submit(); (This was causing the error)
}
</script>
</head>
<body>
<h1>Create New Delivery</h1>
<c:url var="saveUrl" value="/test/delivery/add" />
<form:form modelAttribute="deliveryDtoAttribute" method="POST" action="${saveUrl}" name="deliveryForm">
<table>
<tr>
<td><form:hidden id="hasId" path="hasCustomerName" value="true"/></td>
</tr>
<tr>
<td>Customer Name</td>
<td><form:select path="customerName" onChange="repopulate()">
<form:option value="" label="--- Select ---" />
<form:options items="${customerNameList}" />
</form:select>
</td>
<td><form:errors path="customerName" cssClass="error" /></td>
</tr>
<tr>
<td>Customer Country</td>
<td><form:select path="customerCountry">
<form:option value="" label="--- Select ---" />
<form:options items="${customerCountryList}" />
</form:select>
</td>
<td><form:errors path="customerCountry" cssClass="error" /></td>
</tr>
</form:form>
<form:form name="submitForm">
<input type="button" value="Save" onClick="setFalse()"/>
</form:form>
</body>
</html>
コントローラーの一部:
@RequestMapping(value = "/add", method = RequestMethod.GET)
public String getDelivery(ModelMap model) {
DeliveryDto deliveryDto = new DeliveryDto();
model.addAttribute("deliveryDtoAttribute", deliveryDto);
model.addAttribute("customerNameList",
customerService.listAllCustomerNames());
model.addAttribute("customerCountryList", customerService
.listAllCustomerCountries(deliveryDto.getCustomerName()));
return "new-delivery";
}
// I want to enter this method if hasId=true which means that a value in the CustomerName
// drop down list was selected. This should set the CountryList to the corresponding values
// from the database. I want this post method to be triggered by the onChange in the jsp page
@RequestMapping(value = "/add", method = RequestMethod.POST, params="hasCustomerName=true")
public String postDelivery(
@ModelAttribute("deliveryDtoAttribute") DeliveryDto deliveryDto,
BindingResult result, ModelMap model) {
model.addAttribute("deliveryDtoAttribute", deliveryDto);
model.addAttribute("customerNameList",
customerService.listAllCustomerNames());
model.addAttribute("customerCountryList", customerService
.listAllCustomerCountries(deliveryDto.getCustomerName()));
return "new-delivery";
}
// This next post method should only be entered if the save button is hit in the jsp page
@RequestMapping(value = "/add", method = RequestMethod.POST, params="hasCustomerName=false")
public String postDelivery2(
@ModelAttribute("deliveryDtoAttribute") @Valid DeliveryDto deliveryDto,
BindingResult result, ModelMap model) {
if (result.hasErrors()) {
model.addAttribute("deliveryDtoAttribute", deliveryDto);
model.addAttribute("customerNameList",
customerService.listAllCustomerNames());
model.addAttribute("customerCountryList", customerService
.listAllCustomerCountries(deliveryDto.getCustomerName()));
return "new-delivery";
} else {
Delivery delivery = new Delivery();
//Setters to set delivery values
return "redirect:/mis/home";
}
}
このエラーが発生するのはなぜですか?どんな助けも大歓迎です!ありがとう
編集:hasId
をhasCustomerName
に変更しました。それでもHTTP Status 405 - Request method 'POST' not supported
エラーが表示されます。
EDIT2:エラーの原因となったsetFalse
関数の行をコメント化
// D
HTTPエラーの原因となっている問題を見つけました。
[保存]ボタンによってトリガーされるsetFalse()
関数では、コードがボタンを含むフォームを送信しようとしました。
_ function setFalse(){
document.getElementById("hasId").value ="false";
document.deliveryForm.submit();
document.submitForm.submit();
_
document.submitForm.submit();
を削除すると動作します:
_ function setFalse(){
document.getElementById("hasId").value ="false";
document.deliveryForm.submit()
_
@RogerLindsjö正しいパラメーターを渡していないエラーを見つけてくれてありがとう!
これが役立つかどうかはわかりませんが、同じ問題がありました。
CSRF保護でspringSecurityFilterChainを使用しています。 POSTリクエストでフォームを送信するときにトークンを送信する必要があります。次の入力をフォームに追加してみてください。
<input type="hidden" name="${_csrf.parameterName}" value="${_csrf.token}"/>
@ ResponseBodyまたは@ResponseStatusを返しているかどうかを確認します
同様の問題がありました。私のコントローラーは次のように見えました:
@RequestMapping(value="/user", method = RequestMethod.POST)
public String updateUser(@RequestBody User user){
return userService.updateUser(user).getId();
}
POSTリクエストで呼び出すと、常に次のエラーが発生しました。
HTTPステータス405-要求メソッド「POST」はサポートされていません
しばらくして、メソッドが実際に呼び出されたことがわかりましたが、@ ResponseBodyと@ResponseStatusがないため、Spring MVCはエラーを発生させます。
これを修正するには、単に@ResponseBodyを追加します
@RequestMapping(value="/user", method = RequestMethod.POST)
public @ResponseBody String updateUser(@RequestBody User user){
return userService.updateUser(user).getId();
}
またはメソッドへの@ResponseStatus。
@RequestMapping(value="/user", method = RequestMethod.POST)
@ResponseStatus(value=HttpStatus.OK)
public String updateUser(@RequestBody User user){
return userService.updateUser(user).getId();
}
行を変更する必要があるかもしれません
@RequestMapping(value = "/add", method = RequestMethod.GET)
に
@RequestMapping(value = "/add", method = {RequestMethod.GET,RequestMethod.POST})
問題は、コントローラーがパラメーターhasId = falseまたはhasId = trueを期待しているが、それを渡していないことです。非表示フィールドのIDはhasIdですが、hasCustomerNameとして渡されるため、一致するマッピングはありません。
非表示フィールドのパスをhasIdに変更するか、マッピングパラメーターをhasCustomerName = trueまたはhasCustomerName = falseに変更してください。