24

我收到此错误:HTTP Status 405 - Request method 'POST' not supported

我要做的是制作一个带有下拉框的表单,该下拉框根据在另一个下拉框中选择的其他值填充。例如,当我在customerName框中选择一个名称时,onChange应该运行 .jsp 页面中的函数,然后再次加载提交的页面,并在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";
        }

    }

我怎么会收到这个错误?任何帮助将非常感激!谢谢

编辑:更改hasIdhasCustomerName. 我仍然得到HTTP Status 405 - Request method 'POST' not supported错误。

EDIT2:注释掉setFalse函数中导致错误的行

// D

4

7 回答 7

22

我不确定这是否有帮助,但我遇到了同样的问题。

您正在使用带有 CSRF 保护的 springSecurityFilterChain。这意味着当您通过 POST 请求发送表单时,您必须发送令牌。尝试将下一个输入添加到您的表单中:

<input type="hidden" name="${_csrf.parameterName}" value="${_csrf.token}"/>
于 2015-08-11T15:07:24.053 回答
17

检查您是否返回 @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();
}
于 2015-02-24T20:53:37.937 回答
5

您可能需要更改线路

@RequestMapping(value = "/add", method = RequestMethod.GET)

@RequestMapping(value = "/add", method = {RequestMethod.GET,RequestMethod.POST})
于 2012-06-21T22:21:34.653 回答
4

问题是您的控制器需要一个参数hasId=falsehasId=true,但您没有传递它。您的隐藏字段具有 id hasId但作为hasCustomerName传递,因此没有映射匹配。

将隐藏字段的路径更改为hasId或将映射参数更改为期望hasCustomerName=truehasCustomerName=false

于 2012-06-21T21:02:23.380 回答
3

我发现了导致 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()

@Roger Lindsjö 感谢您发现我没有传递正确参数的错误!

于 2012-06-22T09:43:31.130 回答
0

由于其他原因(test-response 未在 csrf 令牌中添加 url 模式)我遇到了类似的问题,我通过在以下属性中允许我的 URL 模式来解决它config/local.properties

csrf.allowed.url.patterns = /[^/]+(/[^?])+(sop-response)$,/[^/]+(/[^?])+(merchant_callback)$,/[^/]+(/[^?])+(hop-response)$

修改为

csrf.allowed.url.patterns = /[^/]+(/[^?])+(sop-response)$,/[^/]+(/[^?])+(merchant_callback)$,/[^/]+(/[^?])+(hop-response)$,/[^/]+(/[^?])+(test-response)$

于 2020-03-20T15:25:00.560 回答
0

在我的情况下,网址以 / 结尾

paymentUrl(old)= /get-details/

我刚刚删除了尾随 /

paymentUrl(new)= /get-details

它奏效了

于 2022-02-07T19:57:51.050 回答