Spring - 405(不支持请求方法'POST')

时间:2014-04-25 05:52:47

标签: javascript spring angularjs spring-mvc post

我有简单的代码,通过AngularJS将表单数据传递给spring控制器。在chrome调试器中,我可以看到正确的值随请求传递,但是我收到错误说405 (Request method 'POST' not supported)并且我的控制器中的调试指针没有命中。所以我明白这是因为我的POST请求没有映射到我的控制器,但我已经做好了一切。

表格: -

<form name="empForm" ng-controller="insertEmpCtrl" ng-submit="insertEmp()">
<table>
    <tr><td>First name: <input type="text" class="form-control" name="fname" ng-model="formData.fname"/></td></tr>
    <tr><td>Last name: <input type="text" class="form-control" name="lname" ng-model="formData.lname"/></td></tr>
    <tr><td>Contact no: <input type="text" class="form-control" name="contact" ng-model="formData.contactno"/></td></tr>
    <tr>
        <td><input type="submit" value="Save" /> <input type="reset" value="Edit"></td>
        <td></td>
    </tr>
</table>

AngularJS控制器: -

empApp.controller('insertEmpCtrl',function($scope,$http){

        $scope.insertEmp = function(){


            $http.post("http://localhost:8080/IdeaOne#/addemp", $scope.formData, {
                withCredentials: true,
                headers: {'Content-Type': 'application/json'},
                transformRequest: angular.identity
            }).success(function(){console.log("done")}).error(function(){console.log("error")});

        };
    });

Spring控制器: -

public class HelloController {

@RequestMapping(method = RequestMethod.GET)
public String home(ModelMap model){

    return "hello";
}

//method redirects to hello.jsp
@RequestMapping(value="/addemp",method = RequestMethod.POST)
public String addEmployee(@RequestBody  Employee employee) {


    EmployeeManager.empDB.add(employee);

    return "hello";
}


//method returns a link list as a json doc to the front end
@RequestMapping(value="/viewall",method = RequestMethod.GET)
public @ResponseBody
LinkedList<Employee> viewAll(ModelMap model){


    return EmployeeManager.viewEmployees();

}

}

有人可以帮我弄清楚我哪里出错了吗?

1 个答案:

答案 0 :(得分:0)

在弹簧控制器中

@RequestMapping(value="/addemp",method = RequestMethod.POST)

将路径设置为/addemp。但是js代码发布到/IdeaOne#/addemp。 (我不熟悉angularjs,我不知道网址中的##;&#39;符号意思)。

你必须确保两条路径相同。