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

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

小结

目录
相关文章
|
9天前
|
XML Java 数据格式
SpringBoot入门(8) - 开发中还有哪些常用注解
SpringBoot入门(8) - 开发中还有哪些常用注解
27 0
|
11天前
|
XML JSON API
【PHP开发专栏】PHP RESTful API设计与开发
随着互联网技术的发展,前后端分离成为Web开发的主流模式。本文介绍RESTful API的基本概念、设计原则及在PHP中的实现方法。RESTful API是一种轻量级、无状态的接口设计风格,通过HTTP方法(GET、POST、PUT、DELETE)操作资源,使用JSON或XML格式传输数据。在PHP中,通过定义路由、创建控制器、处理HTTP请求和响应等步骤实现RESTful API,并强调了安全性的重要性。
18 2
|
1月前
|
JSON Java 网络架构
elasticsearch学习四:使用springboot整合 rest 进行搭建elasticsearch服务
这篇文章介绍了如何使用Spring Boot整合REST方式来搭建和操作Elasticsearch服务。
122 4
elasticsearch学习四:使用springboot整合 rest 进行搭建elasticsearch服务
|
18天前
|
前端开发 关系型数据库 API
深入浅出后端开发——从零到一构建RESTful API
本文旨在为初学者提供一个关于后端开发的全面指南,特别是如何从零开始构建一个RESTful API。我们将探讨后端开发的基本概念、所需技术栈、以及通过实际案例展示如何设计和实现一个简单的RESTful API。无论你是完全的新手还是有一定编程基础的开发者,这篇文章都将为你提供实用的知识和技巧,帮助你在后端开发的道路上迈出坚实的一步。
|
23天前
|
存储 XML API
探索后端开发中的RESTful API设计哲学
【10月更文挑战第21天】在数字化时代,后端开发是构建强大、可靠和可扩展应用程序的基石。本文将深入探讨RESTful API的设计原则,并展示如何通过这些原则来提升API的质量和性能。我们将从基础概念出发,逐步深入到实际案例分析,揭示高效API设计的秘诀。无论你是初学者还是有经验的开发者,这篇文章都将为你提供宝贵的见解和实用的技巧,帮助你在后端开发的道路上更进一步。
|
1月前
|
Web App开发 JavaScript Java
elasticsearch学习五:springboot整合 rest 操作elasticsearch的 实际案例操作,编写搜索的前后端,爬取京东数据到elasticsearch中。
这篇文章是关于如何使用Spring Boot整合Elasticsearch,并通过REST客户端操作Elasticsearch,实现一个简单的搜索前后端,以及如何爬取京东数据到Elasticsearch的案例教程。
174 0
elasticsearch学习五:springboot整合 rest 操作elasticsearch的 实际案例操作,编写搜索的前后端,爬取京东数据到elasticsearch中。
|
1月前
|
NoSQL Java Redis
shiro学习四:使用springboot整合shiro,正常的企业级后端开发shiro认证鉴权流程。使用redis做token的过滤。md5做密码的加密。
这篇文章介绍了如何使用Spring Boot整合Apache Shiro框架进行后端开发,包括认证和授权流程,并使用Redis存储Token以及MD5加密用户密码。
30 0
shiro学习四:使用springboot整合shiro,正常的企业级后端开发shiro认证鉴权流程。使用redis做token的过滤。md5做密码的加密。
|
19天前
|
JavaScript 前端开发 Java
SpringBoot_web开发-webjars&静态资源映射规则
https://www.91chuli.com/ 举例:jquery前端框架
16 0
|
1月前
|
前端开发 Java 数据库连接
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
本文是一份全面的表白墙/留言墙项目教程,使用SpringBoot + MyBatis技术栈和MySQL数据库开发,涵盖了项目前后端开发、数据库配置、代码实现和运行的详细步骤。
43 0
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
|
1月前
|
开发框架 Java API
「SpringBrick快速入门指南」:一款基于Spring Boot的高级插件化开发框架
「SpringBrick快速入门指南」:一款基于Spring Boot的高级插件化开发框架
53 0