REST开发
这个内容对以后开发中很重要吧
这个知识点有点欠缺
我们这边是一个知识加油站
是隶属于springboot mvc的一个小的细节
互联网上
风格简洁
Rest
是表现形式状态转换
访问网络资源的状态格式
传统风格是通过访问路径的方式实现在网页中的操作
也很少有这个课程
Rest风格描述形式简洁许多
我要访问user这个资源 id是1
我要访问user这个资源
所有的数据通过post提交的话
我们在外面是看不到数据的
我们通过调用行为进行区分
访问资源时有不同的行为动作
按照REST风格访问资源时使用行为动作区分对资源进行的何种操作
我们在postman中请求的方式有很多
我们通过一个路径和一个访问方式我们就可以确定一个资源的访问形式
REST只是一个风格
RESTFUL RESTful
只是一个建议 可以打破的
一种可以改变的思想
话没说的太满...
这个风格使用频率很高 从今往后 基本上都用这种风格进行开发
入门案例
我们先前的程序
package com.bigdata1421.demo.controller; import com.bigdata1421.demo.demos.web.User; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; @Controller public class UserController { /* * @ResponseBody注解是Spring框架中的一个注解, * 它用于标记在控制器方法上, * 表示该方法返回的对象将直接作为HTTP响应体返回给客户端, * 而不会经过视图解析器进行解析。 * 通常用于RESTful风格的接口开发。 * */ @RequestMapping("/save") @ResponseBody public String save(@RequestBody User user){ System.out.println("user save ... " + user); return "{'module':'user save'}"; } @RequestMapping("/delete") @ResponseBody public String delete(Integer id){ System.out.println("user delete ... " + id); return "{'module':'user delete'}"; } /* * @RequestBody注解是Spring框架中的一个注解, * 它用于标记在控制器方法的参数上, * 表示该参数的值将从请求体中获取。 * 通常在处理POST请求或PUT请求时, * 客户端会将请求数据以请求体的形式发送给服务器。 * 而使用@RequestBody注解可以将请求体中的数据绑定到控制器方法的参数上, * 方便进行进一步的处理或者验证。 * */ @RequestMapping("/update") @ResponseBody public String update(@RequestBody User user){ System.out.println("user update ... " + user); return "{'module':'user update'}"; } @RequestMapping("/getById") @ResponseBody public String update(Integer id){ System.out.println("user getById ... " + id); return "{'module':'user getById'}"; } }
视图解析器(View Resolver)是Spring框架中的一个组件,它主要用于将控制器方法返回的逻辑视图名解析为具体的视图对象。
在Spring MVC中,控制器方法通常返回一个字符串作为逻辑视图名,而不是直接返回一个视图对象。这个逻辑视图名表示了一个视图的标识符,通过视图解析器将其解析成一个具体的视图对象,最终呈现给用户。
视图解析器根据配置的规则和约定来查找和解析视图对象。它可以根据视图名称从不同的位置(如文件系统、类路径、数据库等)查找视图文件,并将其转换为对应的视图对象。一旦找到了相应的视图对象,就可以使用它来渲染并生成最终的响应。
@ResponseBody注解是Spring框架中的一个注解,它用于标记在控制器方法上,表示该方法返回的对象将直接作为HTTP响应体返回给客户端,而不会经过视图解析器进行解析。通常用于RESTful风格的接口开发。
使用@ResponseBody注解时,Spring会根据返回值的类型自动选择对应的HttpMessageConverter进行序列化处理。常见的HttpMessageConverter包括:MappingJackson2HttpMessageConverter(用于处理JSON格式)、StringHttpMessageConverter(用于处理字符串)、ByteArrayHttpMessageConverter(用于处理字节数组)等。
@RequestBody注解是Spring框架中的一个注解,它用于标记在控制器方法的参数上,表示该参数的值将从请求体中获取。
通常在处理POST请求或PUT请求时,客户端会将请求数据以请求体的形式发送给服务器。而使用@RequestBody注解可以将请求体中的数据绑定到控制器方法的参数上,方便进行进一步的处理或者验证。
我们通过postman向网站发起请求
之后获取了反馈
接下来我们改成Rest风格的
如果使用get请求提交是会报错的 提示不支持这种请求方式
控制台有反馈
全部改写
我们如果要传参可以通过路径变量的注解实现
{id}表示形参 @PathVariable 代表从路径里面取值
这两个是一对
在postman里发起DELETE请求就能获取响应结果
控制台也能反馈
前端应该发送的是json格式的数据
@responseBody注解将json转为了Javabean对象
package com.bigdata1421.demo.controller; import com.bigdata1421.demo.demos.web.User; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.*; @Controller public class UserController { @RequestMapping(value = "/users",method = RequestMethod.POST) @ResponseBody public String save(){ System.out.println("user save ... "); return "{'module':'user save'}"; } @RequestMapping(value = "/users/{id}",method = RequestMethod.DELETE) @ResponseBody public String delete(@PathVariable Integer id){ System.out.println("user delete ... " + id); return "{'module':'user delete'}"; } @RequestMapping(value = "/users" ,method = RequestMethod.PUT) @ResponseBody public String update(@PathVariable User user){ System.out.println("user update ... " + user); return "{'module':'user update'}"; } @RequestMapping(value = "/users{id}",method = RequestMethod.GET) @ResponseBody public String update(@PathVariable Integer id){ System.out.println("user getById ... " + id); return "{'module':'user getById'}"; } }
小结
根据请求行为去指定书写
请求的参数如果有路径变量
路径上有参数的占位 在形参上用注解的方式对应上
学到这里
后期大量的时间里
我们都会将数据封装成pojo然后通过字符串的方式
传递过去
RESTful简化开发
入门案例过于繁琐 可以简化
重复大量写的东西可以简化书写
设置统一请求路径
把ResponseBody注解提上去
整合注解
指定请求类型的注解
标准请求动作映射(4种)
这样就能简写
快速以RESTful风格开发
package com.bigdata1421.demo.controller; import com.bigdata1421.demo.demos.web.User; import org.springframework.web.bind.annotation.*; @RestController @RequestMapping("/users") public class UserController { @PostMapping public String save(){ System.out.println("user save ... "); return "{'module':'user save'}"; } @DeleteMapping("/{id}") public String delete(@PathVariable Integer id){ System.out.println("user delete ... " + id); return "{'module':'user delete'}"; } @PutMapping public String update(@PathVariable User user){ System.out.println("user update ... " + user); return "{'module':'user update'}"; } @GetMapping ("/{id}") public String update(@PathVariable Integer id){ System.out.println("user getById ... " + id); return "{'module':'user getById'}"; } }
小结