1.dispatcherServlet的配置
<!-- The front controller of this Spring Web application, responsible for handling all application requests --> <servlet> <servlet-name>springDispatcherServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring-mvc-ftl.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <!-- Map all requests to the DispatcherServlet for handling --> <servlet-mapping> <servlet-name>springDispatcherServlet</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping>注:<url-pattern>/</url-pattern>不能指定后缀名
2. 使servlet可以操作PUT和DELETE
<!-- 支持http的PUT和DELTE操作 --> <filter> <filter-name>httpMethodFilter</filter-name> <filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class> </filter> <filter-mapping> <filter-name>httpMethodFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
3.controller示例
@Controller
@RequestMapping("/user/")
public class UserController
{
@RequestMapping(value="index", method=RequestMethod.GET, produces={"application/json;charset=UTF-8"})
public ModelAndView index()
{
ModelAndView modelAndView = new ModelAndView();
modelAndView.setViewName("home");
return modelAndView;
}
@RequestMapping(value="user/{id}", method=RequestMethod.GET, produces={"application/json;charset=UTF-8"})
@ResponseBody
public User getUser(@PathVariable("id") String userId)
{
System.err.println("查询用户信息:" + userId);
return new UserBuilder().setUserId(userId).setUserName("测试").toUser();
}
@RequestMapping(value="user", method=RequestMethod.POST, produces={"application/json;charset=UTF-8"})
@ResponseBody
public User addUser(String userId, String userName, int userAge)
{
System.err.println("新增用户信息:" + userId);
return new UserBuilder().setUserId(userId).setUserName(userName).setUserAge(userAge).toUser();
}
@RequestMapping(value="user", method=RequestMethod.PUT, produces={"application/json;charset=UTF-8"})
@ResponseBody
public User editUser(String userId, String userName, int userAge)
{
System.err.println("修改用户信息:" + userId);
return new UserBuilder().setUserId(userId).setUserName(userName).setUserAge(userAge).toUser();
}
@RequestMapping(value="user/{id}", method=RequestMethod.DELETE, produces={"application/json;charset=UTF-8"})
@ResponseBody
public User deleteUser(@PathVariable("id") String userId)
{
System.err.println("删除用户信息:" + userId);
return new UserBuilder().setUserId(userId).toUser();
}
}4.js示例
<script type="text/javascript">
function fnQuery(){
$.ajax({
type: ‘GET‘,
url: ‘${request.contextPath}/user/user/111‘,
async: true,
data: {},
dataType: "json",
success: function(data){
alert(JSON.stringify(data));
},
error:function(msg){
alert(JSON.stringify(msg));
}
});
}
function fnAdd(){
$.ajax({
type: ‘POST‘,
url: ‘${request.contextPath}/user/user‘,
async: true,
data: {
‘userId‘:‘123‘,
‘userName‘:‘测试测试测试测试‘,
‘userAge‘:88,
},
dataType: "json",
success: function(data){
alert(JSON.stringify(data));
},
error:function(msg){
alert(JSON.stringify(msg));
}
});
}
function fnEdit(){
$.ajax({
type: ‘POST‘,
url: ‘${request.contextPath}/user/user‘,
async: true,
data: {
_method:‘PUT‘,
‘userId‘:‘55555‘,
‘userName‘:‘修改试测试测试‘,
‘userAge‘:48,
},
dataType: "json",
success: function(data){
alert(JSON.stringify(data));
},
error:function(msg){
alert(JSON.stringify(msg));
}
});
}
function fnDelete(){
$.ajax({
type: ‘POST‘,
url: ‘${request.contextPath}/user/user/111‘,
async: true,
data: {
_method:‘DELETE‘,
},
dataType: "json",
success: function(data){
alert(JSON.stringify(data));
},
error:function(msg){
alert(JSON.stringify(msg));
}
});
}
</script>注:PUT与DELETE的特殊处理,需要在参数中增加_method.
参考地址:http://www.cnblogs.com/qixiaoyizhan/p/5864233.html
本文出自 “旅行者” 博客,请务必保留此出处http://881206524.blog.51cto.com/10315134/1922055
原文:http://881206524.blog.51cto.com/10315134/1922055