Spring-Boot-3-Controller层

1. Controller层

1.1. RestController

  • RestController是REST风格API的控制器
@RestController
@RequestMapping("/story")
public class StoryController {  
    @Autowired 
    private StoryService storyService;
}
  1. @Controller对应表现层的Bean。这里用RestController,默认类中的方法都会以json的格式返回给前端。
  2. 使用@Controller注解标识StoryController之后,就表示要把StoryController交给Spring容器管理,在Spring容器中会存在一个名字为"storyController"的bean。
  3. 如果@Controller不指定名称,则默认的bean名字为这个类的类名首字母小写,如果指定名称【@Controller(value=“StoryController”)】或者【@Controller(“StoryController”)】,则使用value作为bean的名字。

1.2. RequestMapping

@RestController
@RequestMapping("/story")
public class StoryController {
    @Autowired
    private StoryService storyService;
}
  1. @RequestMapping注解用于映射url到控制器类或一个特定的处理程序方法。可用于类或方法上。用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。
  2. @RequestMapping注解常用属性有:
    • value指定请求的地址
    • method指定请求类型, GET、POST、PUT、DELETE等
    • consumes指定请求的接收内容类型,如application/json, text/html
    • produces指定返回内容类型。
    • params指定request中必须包含某些参数值,才让该方法处理请求。
    • headers指定request中必须包含某些指定的header值,才让该方法处理请求。

1.3. RequestParam

@RestController
@RequestMapping("/story")
public class StoryController {
    @Autowired
    private StoryService storyService;
    /*** 交换两个story*/
    @PostMapping("/exchange")
    public ResultVO<Story> exchangeById(@RequestParam int src_id,@RequestParam int tar_id){}
}
  1. @RequestParam从request里面取参数值。
    使用http://IP:port/story/exchange?src_id=num1&tar_id=num2访问,将num1和num2传递赋值给src_id和tar_id
  2. Eg.@PostMapping("/url") 等同于@RequestMapping(value = “/url”,method = RequestMethod.POST)

1.4. PathVariable

/**根据task获取对应的所有story*/
@GetMapping("/list/{taskId}")
public ResultVO<List<Story>> getByTask(@PathVariable int taskId){}
  1. @PathVariable映射url片段到java方法的参数。
  2. Eg.使用http://IP:port/story/list/num访问,num将作为参数传递给taskId
  3. Eg.@GetMapping("/url") 等同于
    @RequestMapping(value = “/url”,method = RequestMethod.GET)
  4. @PathVariable 支持三种参数
    • name 指定绑定参数的名称,要跟URL上面的一样
    • required 指定这个参数是不是必须的
    • value 跟name一样的作用,是name属性的一个别名
    • @RequestParam支持四种参数,加上了defaultValue,表示如果本次请求没有携带这个参数,或者参数为空,那么就会启用默认值

1.5. RequestBody

/**新增story*/
@PostMapping("/create")
public ResultVO<Story> createStory(@RequestBody StoryVO storyInput){}
  1. @RequestBody映射请求体到java方法的参数,一般不用于get请求。
  2. 前端访问需要传递JSON字符串,字符串定义了StoryVO的属性值。
  3. ResponseBody注解的作用是将controller的方法返回的对象通过适当的转换器转换为指定的格式,紫萼如到response对象输出指定格式的数据。
  4. 前端使用ajax访问方式如下示例
var data = {
    "taskId": $("#taskId").val(),
    "name": $("#name").val(),
    "storyPoint": $("#storyPoint").val(),
    "priority": $("#priority").val(),
    "description": 
$("#description").val(),
    "posId": $("#posId").val(),
    "acceptance":
$("#acceptance").val(),
    "releaseId": $("#iteration").val(),
}
$.ajax({
    type: "POST",
    url: "/story/create",
    dataType:"json",
    contentType : ‘application/json’,
    data:JSON.stringify(data),
    success: function (data) {}
})

1.6. GetMapping

@GetMapping("/storyMapping")
public ModelAndView getMapping(@RequestParam int proId){
    ModelAndView modelAndView = new ModelAndView("storymap");
    modelAndView.addObject("proId",proId);
    return modelAndView;
}
  1. controller除了下发操作到数据库,还用于跳转界面,返回值为ModelAndView类型。
  2. ModelAndView的构造参数storymap是指要跳转的目标页面storymap.html的路径。
  3. ModelAndView可以携带参数,这个方法传递了proId给目标页面,在storymap.html文件中接收方式如下:
<script th:inline="javascript">
var proId = [[${proId}]]
</script>

2. @RestController和@Controller的区别

官方文档:@RestController is a stereotype annotation that combines @ResponseBody and @Controller.

  1. @RestController注解相当于@ResponseBody + @Controller合在一起的作用。

2.1. @Controller

  1. 这个注解在:org.springframework.stereotype包下,其中被@RequestMapping标记的方法被分发处理器扫描识别,将不同的请求分发得到对应接口。
  2. 查找方式主要是通过包扫描
  3. 在这种模式下,需要使用@ResponseBody注解

3. 参考

  1. spring注解:@RestController、@Controller、@ResponseBody
  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
 课程目标:你将对研发框架的代码封装和开发规范制定的底实现逻辑有所掌握,并形成自己的开发封装套路,告别CRUD课程简介:   1. 课程背景: 能帮你解决什么问题?企业中通常由架构师搭建好开发框架,里面包含了很多封装好的基础结构,日志规范以及响应的异常统一处理,还有相应的参数校验等。很多初中高级开发工程师没有机会接触这部分代码的逻辑,而这部分代码逻辑又是非线性的,单纯看代码逻辑是看不出来执行顺序的,需要大量调试总结。不像mvc代码结构,你知道从Controller看到Service再到Dao,而这样底的基础性代码则像积木,不熟悉的前提下需要一块块的插入拔出,不断总结,而沿着本课程的顺序梳理与实战你将会豁然开朗。市面上的大多文章结构较散,并且处理不够全面,比如返回结构通常是 具体的正例与反例日志统一处理 统一异常处理及特殊的情况处理 参数优雅校验 1基础的校验 2. 自定义校验 3.分组校验最重要的是给大家捋顺了一个清晰的实现结构以上在我们后面章节Spring Boot HelloWorld的至少10个可扩展点里有更多的相关介绍,在核心章节里有更细致的讲解实现。理解框架升级底逻辑: 全网首套基于Spring Boot 3.x+Java 17开发系列 SpringBoot3的升级背景和路线逻辑掌握代码重构及编码效率提升技巧学习基于最为前沿的Spring Boot 3.x 和 Java 17 开发代码依赖于Spring Boot 3.x Java 17环境开发穿插相应新版本的变化讲解可编写完成一个生产级开发规范框架的制定 包含不限于 统一响应结构统一异常处理基于ThreadLocal处理请求RequestId基于日志框架的MDC 统一记录日志统一状态码处理Filter中的异常及状态码处理,以及日志的完整性处理自定义优雅参数校验学习源码剖析方式方法等等 3. 课程规划1.  课程章节规划 2. 讲课方式代码实战为主+图文演示为辅例如说明后端校验的重要性 以一张图清晰明了的展示说明解答了为何前端有了前端校验还要后端校验的问题 3. 特别说明本课程所有代码使用版本会随着Spring Boot 3.x的开发进度而更新,直到Spring Boot 3.x的正式版本发布,可放心食用本课程的重点会侧重放在研发框架的基础规范编码上,并非专注于SpringBoot3.x和Java17的新特性上讲解。主要是两点原因,1课程的方向侧重点, 2. SpringBoot3.x 官方尚处于MileStone/Snapshot版并未Release,所以大家可关注本人编程燃风后续的产品课程。本课程代码同样适用于Spring Boot 1.x 2.x 只需微调API和相关库版本的即可(注意1.x已经归档不维护) 常见问题:问:是否讲解Java17和SpringBoot3新特性答:本课程的重点会侧重放在研发框架的基础规范编码上,并非专注于SpringBoot3.x和Java17的新特性上讲解。主要是两点原因,1课程的方向侧重点是框架基础规范编码实战 2. SpringBoot3.x 官方尚处于MileStone/Snapshot版并未Release,所以大家可关注本人编程燃风后续的讲解课程。问:代码仅限于SpringBoot3吗? SpringBoot2和SpringBoot1是否适用?答:本课程代码同样适用于Spring Boot 1.x 2.x 只需微调API和相关库版本的即可(注意1.x已经归档不维护)。另外本课程重点讲解代码封装和底实现逻辑和具体API版本关联不大,只是基于最新的SpringBoot3和Java17实现而已,请放心使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值