springboot之RESTful接口与Swagger

一、RESTful

GET获取资源、POST新建资源、PUT更新资源、DELETE删除资源。

RESTful两大特性

1、安全性:GET请求不会引起资源本身改变。

2、幂等性:对一个接口请求和多次请求返回的资源应该一致。

2xx:成功

4xx:客户端错误。

5xx:服务器错误。

URI中不要包含动词

通过使用PathVariable注解获取{id}

@GetMapping("/user/{id}")
    public String getUserById(@PathVariable int id){
        System.out.println(id);
        return "根据ID获取用户信息";
    }

二、Swagger

用于生成、描述、调用和可视化RESTful风格的Web服务。

配置方法

添加包。这里使用到的swagger2的版本是2.9.2记得把springboot的版本改成2.5.6!!!

<!-- swagger2相关功能       -->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.9.2</version>
        </dependency>
        <!--  swagger2ui      -->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.9.2</version>
        </dependency>

创建SwaggerConfig.java文件,专门放在config包下。
在这里插入图片描述

把代码放进去就好了。
注意这里重写了addResourceHandlers方法

package com.example.hello.config;


import io.swagger.annotations.ApiOperation;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;


//Spingboot中配置类必须要加注解
@Configuration
@EnableSwagger2
public class SwaggerConfig implements WebMvcConfigurer {

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("swagger-ui.html")
                .addResourceLocations("classpath:/META-INF/resources/");
        registry.addResourceHandler("/webjars/**")
                .addResourceLocations("classpath:/META-INF/resources/webjars/");
    }

    /*
    * 配置swagger2相关Bean
    * */

    @Bean
    public Docket createRestApi(){
        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                .select()
                .apis(RequestHandlerSelectors.basePackage("com"))   //com包下所有API都交给Swagger2管理
                .paths(PathSelectors.any())
                .build();
    }

    /*
    * 此处主要是API文档页面显示信息
    * */
    private ApiInfo apiInfo(){
        return new ApiInfoBuilder()
                .title("演示项目API")   //标题
                .description("演示项目")    //描述
                .version("1.0")
                .build();
    }


}

http://localhost:8080/swagger-ui.html/
然后就成功了

在这里插入图片描述

除此之外,还能给每个接口增加说明,需要到后端指定接口处去增加。

例如说,我在hello2这个方法增加了注解,要使用@ApiOperation("")注解

在这里插入图片描述

在swagger展示如下。在这里插入图片描述

相关推荐

  1. SpringbootRESTful风格

    2024-04-06 21:30:02       42 阅读
  2. SpringBoot 3.0 升级 Swagger 升级

    2024-04-06 21:30:02       53 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-06 21:30:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-06 21:30:02       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-06 21:30:02       87 阅读
  4. Python语言-面向对象

    2024-04-06 21:30:02       96 阅读

热门阅读

  1. 慢SQL问题排查

    2024-04-06 21:30:02       32 阅读
  2. 反转链表(C语言)

    2024-04-06 21:30:02       43 阅读
  3. 蓝桥杯算法题:K倍区间

    2024-04-06 21:30:02       43 阅读
  4. 第六章:CSS最佳实践与优化

    2024-04-06 21:30:02       41 阅读
  5. 第十四届蓝桥杯省赛大学B组(C/C++)整数删除

    2024-04-06 21:30:02       48 阅读
  6. 抖音运营技巧2

    2024-04-06 21:30:02       41 阅读
  7. MyBatis plus 详解

    2024-04-06 21:30:02       144 阅读
  8. 谈谈Python中的正则表达式及其用法。

    2024-04-06 21:30:02       40 阅读
  9. 在MacOS上安装Homebrew:初学者指南

    2024-04-06 21:30:02       50 阅读