zoukankan      html  css  js  c++  java
  • Spring Boot入门系列(二十)快速打造Restful API 接口

    spring boot入门系列文章已经写到第二十篇,前面我们讲了spring boot的基础入门的内容,也介绍了spring boot 整合mybatis,整合redis、整合Thymeleaf 模板引擎 等各种框架,同时也介绍了使用jdbcTemplate 操作数据库,配置多数据源 等系列内容。应该说spring boot 常用的功能基本上都覆盖到了。接下来说一说spring boot 比较实用的项目级的功能。首先会介绍spring boot 如何快速打造Restful API接口。

    随着互联网化等逐渐深入,应用系统也变得越来越复杂,系统架构正在朝着微服务化,中台化的方向发展。这就需要各个系统、各个厂家之间的数据频繁交互。所以,使用 Restful 风格构建的应用接口适用于移动互联网厂商的业务场景,正在被越来越多的企业推荐使用。那么什么是 RESTful 呢?

    一、什么是 RESTful

    RESTful 是目前最流行的互联网软件架构。 REST(Representational State Transfer,表述性状态转移)一词是由 Roy Thomas Fielding 在他 2000 年博士论文中提出的,定义了他对互联网软件的架构原则,如果一个架构符合 REST 原则,则称它为 RESTful 架构。

    RESTful 把服务器端,所有的应用程序状态和功能定义为“资源”(Resource)。从 RESTful 的⻆度看,网络上的任何东西都是资源,它可以是一段文本、一张图片、一个服务等,每个资源都对应一个特定的 URI(统一资源定位符),并把它进行标示,访问这个 URI 就可以获得这个资源 。

    资源可以有多种表现形式,也就是资源的“表述”(Representation),比如一张图片可以使用 JPEG 格式也可以使用 PNG 格式。 URI 只是代表了资源的实体,并不能代表它的表现形式。互联网中,客户端和服务端之间的互动传递的就是资源的表述,我们上网的过程,就是调用资源的 URI,获取它不同表现形式的过程。这种互动只能使用无状态协议 HTTP,也就是说,服务端必须保存所有的状态,客户端可以使用 HTTP 的几个基本操作,包括 GET(获取)、 POST(创建)、 PUT(更新)与DELETE(删除),使得服务端上的资源发“状态转化”(State Transfer),也就是所谓的“表述性状态转移” 。

    Restful 相比于 SOAP 更加简单明了,它并没有一个明确的标准,而更像是一种设计的风格。

    Restful 特点包括:
      1、每一个URI代表1种资源;
      2、客户端使用GET、POST、PUT、DELETE4个表示操作方式的动词对服务端资源进行操作:GET用来获取资源,POST用来新建资源(也可以用于更新资源),PUT用来更新资源,DELETE用来删除资源;
      3、通过操作资源的表现形式来操作资源;
      4、资源的表现形式是XML或者HTML;
      5、客户端与服务端之间的交互在请求之间是无状态的,从客户端到服务端的每个请求都必须包含理解请求所必需的信息。
     

    二、Spring Boot 实现Restful 方案

    Spring Boot 开发Restful j接口非常简单,通过不同的注解来支持前端的请求,除了经常使用的@RestController 注解外,Spring Boot 还提了一些组合注解。这些注解来帮助简化常用的 HTTP 方法的映射,并更好地表达被注解方法的语义 。

    Srping Boot 提供了与Rest 操作方式(GET、POST、PUT、DELETE)对应的注解:

      1、@GetMapping,处理 Get 请求
      2、@PostMapping,处理 Post 请求
      3、@PutMapping,用于更新资源
      4、@DeleteMapping,处理删除请求
      5、@PatchMapping,用于更新部分资源

    @PutMapping 主要是用来更新整个资源的,@PatchMapping 主要表示更新部分字段

    之前我们也介绍过,Spring Boot 提供了专门做数据处理的控制器:@RestController ,其实这些注解就是我们使用的 @RequestMapping 的简写版本:@GetMapping 其实就等于@RequestMapping(value = "/xxx",method = RequestMethod.DELETE) 。

    三、Spring Boot 快速实现Restful

    如何创建Spring Boot 项目之前的文章里面都有,这里不在重复了。可以看我之前的系列文章:https://www.cnblogs.com/zhangweizhong/category/1657780.html

    1、设计接口

    根据之前介绍的Restful 设计风格设计一组对用户操作的 RESTful API

    • /user         POST         创建用户
    • /user/id     GET            根据 id 获取用户信息
    • /user         PUT            更新用户
    • /user/id     DELETE     根据 id删除对应的用户

    以上,就是对user操作的接口定义,在实际项目的Restful API 接口文档还会定义全部请求的数据结构体。

    2、实现接口

    首先创建UserController 控制器,定义之前设计的相关接口。

    package com.weiz.controller;

    import com.weiz.pojo.SysUser;
    import com.weiz.service.UserService;
    import com.weiz.utils.JSONResult;
    import org.n3r.idworker.Sid;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.web.bind.annotation.*;

    import java.util.Date;

    @RestController
    @RequestMapping("/")
    public class UserController {

    @Autowired
    private UserService userService;

    @Autowired
    private Sid sid;

    @PostMapping(value = "user")
    public JSONResult create() throws Exception {

    String userId = sid.nextShort();
    SysUser user = new SysUser();
    user.setId(userId);
    user.setUsername("spring boot" + new Date());
    user.setNickname("spring boot" + new Date());
    user.setPassword("abc123");
    user.setIsDelete(0);
    user.setRegistTime(new Date());

    userService.saveUser(user);
    return JSONResult.ok("保存成功");
    }

    @PutMapping(value = "user")
    public JSONResult update() {
    SysUser user = new SysUser();
    user.setId("10011001");
    user.setUsername("10011001-updated" + new Date());
    user.setNickname("10011001-updated" + new Date());
    user.setPassword("10011001-updated");
    user.setIsDelete(0);
    user.setRegistTime(new Date());
    userService.updateUser(user);

    return JSONResult.ok("保存成功");
    }


    @DeleteMapping("user/{userId}")
    public JSONResult delete(@PathVariable String userId) {
    userService.deleteUser(userId);
    return JSONResult.ok("删除成功");
    }

    @GetMapping("user/{userId}")
    public JSONResult queryUserById(@PathVariable String userId) {
    return JSONResult.ok(userService.queryUserById(userId));
    }

    }

    说明:

      1、@PathVariable 注解,用于参数映射。

      2、Rest需要注意请求的方式,可以看到PUT和POST的URL是相同的,但是后端处理逻辑不同,所以使用的时候千万别搞混了

    3、测试
    实际开发测试的过程中,一般使用postman测试相关的接口。当然,也可以用单元测试来实现。这里简单起见,直接用postman来测试刚刚定义的人员操作接口。

    创建人员:/user

    根据 id 获取人员信息:/user/id 

    以上,测试了人员的创建和查询接口,其他接口的测试也是一样。 

    最后

    以上,就把Spring Boot 实现Restful API 接口介绍完了。 Restful 是一种非常优雅的设计,采用RESTful 设计API之后 /user/api一个URL地址解决,前端一看就能明白。

    这个系列课程的完整源码,也会提供给大家。大家关注我的微信公众号(架构师精进),回复:springboot源码。获取这个系列课程的完整源码。

  • 相关阅读:
    正则表达式贪婪与非贪婪模式
    GPGPU OpenCL 获取设备信息
    GPGPU OpenCL编程步骤与简单实例
    去掉linux 系统vi中出现^M字符的方法
    OpenMP 线程互斥锁
    CUDA使用Event进行程序计时
    Python日志库logging总结-可能是目前为止将logging库总结的最好的一篇文章
    Python-文件读写及修改
    有关Python的import...和from...import...的区别
    Python中调用其他程序的方式
  • 原文地址:https://www.cnblogs.com/zhangweizhong/p/13169243.html
Copyright © 2011-2022 走看看