RESTFUL是一种网络应用程序的设计风格和开发方式.
在HTTP协议,一个URL地址,表示一个资源,根据不同的方法(HTTP协议中方法:GET,POST,PUT,DELETE等等),表示对这资源的不同的动作(不同的操作)。
http://127.0.0.1:8080/test/img/1.jpg
HTTP协议:
使用GET请求获取资源
使用POST请求提交资源
使用PUT请求修改资源
使用DELETE请求删除资源
场景:用户操作:
新增用户 : addUser.do -----> user.do post
查询用户 : queryUser.do -----> user.do get
修改用户 : updateUser.do ----> user.do put
删除用户 :deleteUser.do ----> user.do delete
以上使用了4个URL地址,操作同一个资源。违背一个资源一个地址。
RESTful的原则,一个资源一个地址。使用不同动作,区分对其不同操作。
在springmvc中使用restful
1.将DispatcherServlet的拦截地址,改为/
<!--配置springmvc-->
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
2.配置静态资源文件处理方式
-1.使用tomcat服务器自带的default Servlet处理静态文件
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.js</url-pattern>
<url-pattern>*.css</url-pattern>
<url-pattern>*.jpg</url-pattern>
</servlet-mapping>
-2.使用springmvc提供默认Servlet配置
<mvc:default-servlet-handler/>
不足:不支持WEB-INF目录下的文件
-3.使用资源文件配置
<mvc:resources location="/resource/" mapping="/resource/**"></mvc:resources>
不足: 会执行拦截器
3.配置处理PUT请求过滤器
<!-- 配置restful put 请求的参数问题 -->
<filter>
<filter-name>httpPutFormContentFilter</filter-name>
<filter-class>org.springframework.web.filter.HttpPutFormContentFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>httpPutFormContentFilter</filter-name>
<servlet-name>springmvc</servlet-name>
</filter-mapping>
4.处理器代码
package com.zw.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import com.zw.pojo.User;
@Controller
public class TestController {
// @RequestMapping(value = "user",method = RequestMethod.GET)
// @ResponseBody
// public Object get(Integer id) {
// System.out.println("get请求");
// return new User("韩梅梅", "18");
// }
@RequestMapping(value = "user/{id}/{name}.action",method = RequestMethod.GET)
@ResponseBody
public Object getRest(@PathVariable("id")Integer id123,@PathVariable("name")String name) {
System.out.println(id123);
System.out.println(name);
System.out.println("get请求");
return new User("韩梅梅", "18");
}
@RequestMapping(value = "user",method = RequestMethod.POST)
@ResponseBody
public Object post(User user) {
System.out.println("POST请求");
System.out.println(user);
return new User("韩梅梅", "18");
}
@RequestMapping(value = "user",method = RequestMethod.PUT)
@ResponseBody
public Object put(User user) {
System.out.println("PUT请求");
System.out.println(user);
return new User("韩梅梅", "18");
}
@RequestMapping(value = "user/{id}",method = RequestMethod.DELETE)
@ResponseBody
public Object delete(@PathVariable("id")Integer id) {
System.out.println("DELETE请求");
return new User("韩梅梅", "18");
}
}
5.前端代码
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<link rel="stylesheet" href="resource/layui/css/layui.css" />
</head>
<body>
<button class="layui-btn" id="get">get请求</button>
<button class="layui-btn" id="post">post请求</button>
<button class="layui-btn" id="put">put请求</button>
<button class="layui-btn" id="delete">delete请求</button>
<script type="text/javascript" src="resource/layui/layui.js"></script>
<script type="text/javascript">
layui.use(['jquery','layer'],function(){
var $ = layui.jquery;
var layer = layui.layer;
//get请求
/* $("#get").click(function(){
$.get("user",{"id":1},function(rs){
console.log(rs);
})
}); */
$("#get").click(function(){
$.get("user/111111/java.html",function(rs){// DispatcherServlet == controler
//但是 由于 htm 后缀,静态文件后缀,所以直接让默认Servlet处理
console.log(rs);
})
});
//post请求
$("#post").click(function(){
$.post("user",{"name":"韩梅梅","password":"123"},function(rs){
console.log(rs);
})
});
//DELETE
$("#delete").click(function(){
$.ajax({
url:"user/1",
type:"delete",
success:function(rs){
console.log(rs);
}
});
});
//PUT
$("#put").click(function(){
$.ajax({
url:"user",
type:"put",
data:{"id":1,"name":"李磊","password":"123"},
success:function(rs){
console.log(rs);
}
});
});
})
</script>
</body>
</html>
注意 :
在restful中,PUT 本质上是POST请求,而DELETE请求本质上是GET请求。