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

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 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'}";
    }
}

小结

目录
相关文章
|
4月前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
78 4
|
4月前
|
Java API 数据库
如何使用Spring Boot构建RESTful API,以在线图书管理系统为例
【10月更文挑战第9天】本文介绍了如何使用Spring Boot构建RESTful API,以在线图书管理系统为例,从项目搭建、实体类定义、数据访问层创建、业务逻辑处理到RESTful API的实现,详细展示了每个步骤。通过Spring Boot的简洁配置和强大功能,开发者可以高效地开发出功能完备、易于维护的Web应用。
111 3
|
2月前
|
监控 前端开发 API
一款基于 .NET MVC 框架开发、功能全面的MES系统
一款基于 .NET MVC 框架开发、功能全面的MES系统
|
3月前
|
JSON API 数据格式
探索后端开发:从零构建简易RESTful API
在数字时代的浪潮中,后端开发如同搭建一座桥梁,连接着用户界面与数据世界。本文将引导读者步入后端开发的殿堂,通过构建一个简易的RESTful API,揭示其背后的逻辑与魅力。我们将从基础概念出发,逐步深入到实际操作,不仅分享代码示例,更探讨如何思考和解决问题,让每一位读者都能在后端开发的道路上迈出坚实的一步。
|
3月前
|
缓存 前端开发 API
深入浅出:后端开发中的RESTful API设计原则
【10月更文挑战第43天】在数字化浪潮中,后端开发如同搭建梦想的脚手架,而RESTful API则是连接梦想与现实的桥梁。本文将带你领略API设计的哲学之美,探索如何通过简洁明了的设计,提升开发效率与用户体验。从资源定位到接口约束,从状态转换到性能优化,我们将一步步构建高效、易用、可维护的后端服务。无论你是初涉后端的新手,还是寻求进阶的开发者,这篇文章都将为你的开发之路提供指引。让我们一起走进RESTful API的世界,解锁后端开发的新篇章。
|
3月前
|
JSON API 开发者
构建高效API:后端开发中的RESTful最佳实践####
在数字化时代,API作为不同系统间通信的桥梁,其重要性日益凸显。本文将深入探讨RESTful API的设计原则与最佳实践,通过实际案例分析,揭示如何构建高效、可维护且易于使用的API接口,助力后端开发者提升项目质量与用户体验。 ####
|
3月前
|
JSON 缓存 API
探索后端开发中的RESTful API设计原则
【10月更文挑战第41天】在后端开发的广阔天地中,API的设计如同绘制一幅精细的地图,指引着数据的流向和前端的交互。本文将带你走进RESTful API的世界,一起探索如何用简洁高效的设计原则来构建一个清晰、可维护且易于理解的API结构。我们将从RESTful API的基础概念出发,通过实际案例分析,揭示如何在实践中应用这些设计原则,并讨论如何在复杂的业务逻辑中保持API的简洁性和一致性。
|
3月前
|
XML JSON API
【PHP开发专栏】PHP RESTful API设计与开发
随着互联网技术的发展,前后端分离成为Web开发的主流模式。本文介绍RESTful API的基本概念、设计原则及在PHP中的实现方法。RESTful API是一种轻量级、无状态的接口设计风格,通过HTTP方法(GET、POST、PUT、DELETE)操作资源,使用JSON或XML格式传输数据。在PHP中,通过定义路由、创建控制器、处理HTTP请求和响应等步骤实现RESTful API,并强调了安全性的重要性。
58 2
|
3月前
|
前端开发 关系型数据库 API
深入浅出后端开发——从零到一构建RESTful API
本文旨在为初学者提供一个关于后端开发的全面指南,特别是如何从零开始构建一个RESTful API。我们将探讨后端开发的基本概念、所需技术栈、以及通过实际案例展示如何设计和实现一个简单的RESTful API。无论你是完全的新手还是有一定编程基础的开发者,这篇文章都将为你提供实用的知识和技巧,帮助你在后端开发的道路上迈出坚实的一步。
|
3月前
|
安全 测试技术 API
构建高效RESTful API:后端开发的艺术与实践####
在现代软件开发的浩瀚星空中,RESTful API如同一座桥梁,连接着前端世界的绚丽多彩与后端逻辑的深邃复杂。本文旨在探讨如何精心打造一款既高效又易于维护的RESTful API,通过深入浅出的方式,剖析其设计原则、实现技巧及最佳实践,为后端开发者提供一份实用的指南。我们不深入晦涩的理论,只聚焦于那些能够即刻提升API品质与开发效率的关键点,让你的API在众多服务中脱颖而出。 ####
45 0