Springboot mvc开发之Rest风格及RESTful简化开发案例

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介: Springboot mvc开发之Rest风格及RESTful简化开发案例

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'}";
    }
}

小结

目录
相关文章
|
2天前
|
API 网络架构 开发者
探索后端开发:RESTful API设计的艺术
【9月更文挑战第18天】在数字化时代的浪潮中,后端开发如同搭建一座座坚固的桥梁,连接用户与数据的无限可能。本文将深入浅出地探讨RESTful API设计的精髓,从理论基础到实践应用,带领读者领略API设计的艺术。我们将以代码示例为灯塔,照亮理解之路,但
|
15天前
|
XML JSON 缓存
探索后端开发中的RESTful API设计原则
【9月更文挑战第5天】在数字化时代的浪潮中,后端开发扮演着支撑整个互联网世界运行的基石角色。而作为连接前端与后端桥梁的RESTful API,其设计质量直接影响到应用的性能和用户体验。本文将深入探讨RESTful API的设计原则,通过浅显易懂的语言和实际代码示例,引导读者理解如何构建高效、易于维护的API。无论你是初学者还是有经验的开发者,这篇文章都将为你提供新的视角和思考。
|
15天前
|
缓存 Java 应用服务中间件
随着微服务架构的兴起,Spring Boot凭借其快速开发和易部署的特点,成为构建RESTful API的首选框架
【9月更文挑战第6天】随着微服务架构的兴起,Spring Boot凭借其快速开发和易部署的特点,成为构建RESTful API的首选框架。Nginx作为高性能的HTTP反向代理服务器,常用于前端负载均衡,提升应用的可用性和响应速度。本文详细介绍如何通过合理配置实现Spring Boot与Nginx的高效协同工作,包括负载均衡策略、静态资源缓存、数据压缩传输及Spring Boot内部优化(如线程池配置、缓存策略等)。通过这些方法,开发者可以显著提升系统的整体性能,打造高性能、高可用的Web应用。
45 2
|
3天前
|
存储 JavaScript NoSQL
深入浅出后端开发:构建你的第一个RESTful API
【9月更文挑战第17天】在数字时代的浪潮中,后端开发是支撑起整个互联网的骨架。本文将引导读者了解后端开发的基本概念,并通过一个实际的代码示例,展示如何从零开始构建一个简单的RESTful API。我们将一起探索API设计的哲学、选择合适的后端语言和框架,以及实现数据存储和接口测试的过程。无论你是编程新手,还是希望扩展你的技术栈,这篇文章都将为你提供一次全面而深入的后端开发之旅。
17 0
|
21天前
|
监控 测试技术 API
|
21天前
|
API 数据库 开发者
深入浅出后端开发:从零开始构建RESTful API
【8月更文挑战第31天】在数字时代的浪潮中,后端开发如同搭建一座连接用户与数据的桥梁。本文将引导你步入这个充满逻辑与创造的世界,通过一个简单的实例,学习如何从无到有,构建一个功能完备的RESTful API。无论你是编程新手还是希望扩展技能的开发者,这篇文章都将为你提供一个清晰的学习路径和实用的知识。让我们开始这段探索之旅,解锁后端开发的奥秘吧!
|
21天前
|
缓存 JavaScript API
构建高效的RESTful API:后端开发的最佳实践
【8月更文挑战第31天】在数字化时代,RESTful API成为连接不同软件组件的桥梁。本文将揭示如何打造一个既高效又易于维护的RESTful API,涵盖设计原则、代码实现及性能优化技巧。你将学习到如何运用最佳实践来提升API的响应速度和可扩展性,同时确保安全性和可靠性。
|
3天前
|
前端开发 JavaScript Java
基于Java+Springboot+Vue开发的音乐推荐管理系统
基于Java+Springboot+Vue开发的音乐推荐管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的音乐推荐管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
41 8
基于Java+Springboot+Vue开发的音乐推荐管理系统
|
3天前
|
前端开发 JavaScript Java
基于Java+Springboot+Vue开发的母婴商城管理系统
基于Java+Springboot+Vue开发的母婴商城管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的网上母婴商城管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
22 7
基于Java+Springboot+Vue开发的母婴商城管理系统
|
4天前
|
前端开发 JavaScript Java
基于Java+Springboot+Vue开发的在线摄影预约管理系统
基于Java+Springboot+Vue开发的在线摄影预约管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的在线摄影管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
20 8
基于Java+Springboot+Vue开发的在线摄影预约管理系统