RESTful架构
REST(Resource Representational State Transfer)即“资源表现层状态转化”,省略了Resource (资源)。允许客户端发出以统一资源标识符访问和操作网络资源的请求,而与预先定义好的无状态操作集一致化。
资源
指网络上的一个具体信息,可以是文本、图片、视频等,每种资源对应一个特定的URI,要想操作该资源访问它的URI就可以,因此URI就成了每一个资源的地址或独一无二的识别符。
表现层(Representation)
“资源"具体呈现出来的形式,叫做它的"表现层”(Representation),如,文本可以用txt格式表现,也可以用HTML格式、XML格式、JSON格式表现,甚至可以采用二进制格式;图片可以用JPG格式表现,也可以用PNG格式表现。URI只代表资源的实体,不代表它的形式。严格地说,有些网址最后的".html"后缀名是不必要的,因为这个后缀名表示格式,属于"表现层"范畴,而URI应该只代表"资源"的位置。它的具体表现形式,应该在HTTP请求的头信息中用Accept和Content-Type字段指定,这两个字段才是对"表现层"的描述
状态转化(State Transfer)
一次客户端和服务器的一个互动过程,会涉及到数据和状态的变化。互联网通信协议HTTP协议,是一个无状态协议,所有的状态都保存在服务器端。因此,客户端想要操作服务器,必须通过某种手段,让服务器端发生"状态转化"(State Transfer),这种转化是建立在表现层之上的,所以就是"表现层状态转化"。由于客户端用到的技术手段只能是HTTP协议,使用四个操作方式的动词:GET、POST、PUT、DELETE分别对应四种基本操作。GET用来获取资源,POST用来新建资源(也可以用于更新资源),PUT用来更新资源,DELETE用来删除资源
简单小结
每一个URI代表一种资源;客户端和服务器之间,传递这种资源的某种表现层;客户端通过四个HTTP动词,对服务器端资源进行操作,实现"表现层状态转化"。符合REST规范的软件架构就是restful编程风格。
在Restful风格中,用户请求的url使用同一个url而用请求方式:get,post,delete,put等方式对请求的处理方法进行区分,这样可以在前后台分离式的开发中使得前端开发人员不会对请求的资源地址产生混淆和大量的检查方法名的麻烦,形成一个统一的接口
SpringMVC对RESTful架构的支持
Spring MVC通过注解的方式将对资源的请求映射为一个URL,通过JSON等格式表示和传输资源;使用SpringMVC可以完成
- 需要从URL中获取一些参数
- 使得同一个接口的不同请求方法可以完成对应的操作
【示例】:设计一个对课程资源进行操作的RESTful接口
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
package com.kkb.controller;
import com.kkb.pojo.Course;
import com.kkb.service.CourseService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
@RestController
public class RESTCourseController {
@Autowired
CourseService service;
//获取全部课程
@RequestMapping (value = "/course" ,method = RequestMethod.GET)
public List<Course> getCourseList(){
System.out.println( "getCourseList" );
return service.selectCourses();
}
//根据id获取某个课程
@RequestMapping (value = "/course/{id}" ,method = RequestMethod.GET)
public Course getCourse( @PathVariable Integer id){
System.out.println( "getCourse" );
System.out.println( "参数:" +id);
return service.selectByID(id);
}
//添加新的课程
@RequestMapping (value = "/course" ,method = RequestMethod.POST)
public String addCourse( @RequestBody Course course){
System.out.println( "addCourse" );
System.out.println( "参数:" +course);
service.insertCourse(course);
return "{\"msg\":\"success\"}" ;
}
//根据id删除课程
@RequestMapping (value = "/course/{id}" ,method = RequestMethod.DELETE)
public String deleteCourse( @PathVariable Integer id){
System.out.println( "deleteCourse" );
System.out.println( "参数:" +id);
service.deleteCourse(id);
return "{\"msg\":\"success\"}" ;
}
//根据id更新课程
@RequestMapping (value = "/course" ,method = RequestMethod.PUT)
public String updateCourse( @RequestBody Course course){
System.out.println( "updateCourse" );
System.out.println( "参数:" +course);
service.updateCourse(course);
return "{\"msg\":\"success\"}" ;
}
}
|
代码中使用@RestController做注解,相当于@Controller+@ResponseBody两个注解的结合,返回json数据不需要在方法前面加@ResponseBody注解了,但使用@RestController这个注解,就不能返回jsp,html页面,视图解析器无法解析jsp,html页面。
在前后端完全分离单页面项目中,路由跳转一般在前端进行,此时一般异步获取数据时使用(ajax或axios)获取,此时一般使用@RestController注解简单方便。
在RequestMapping,URL均使用http://。。。/course,但method不同分别实现增、删、改、查。
注意: 在web应用中,表单的提交只能使用post和get,put和delete是无法提交,在在web.xml中配置拦截器即可
示例代码来源于:http://www.zzvips.com/article/140182.html
利用ajax实现前后端完全分离
当前web开发流行的单页面系统使用前端路由,利用Ajax或AXOIS完成前端与后端的交互通讯,数据的传递格式一般使用json完成,具有rest编程风格的SpringMVC成为当前Java web开发主流技术。
以上就是java开发SSM框架具有rest风格的SpringMVC的详细内容,更多关于SpringMVC具有rest风格的SSM框架的资料请关注服务器之家其它相关文章!
原文链接:https://blog.csdn.net/guoyp2126/article/details/118156181