springboot学习四:RESTful风格+swagger

RESTful风格下,代码需遵守安全性(例如get操作获取资源时,不应该引起资源本身的改变或者服务器状态的改变。什么样的方法做什么样的事)和幂等性(服务器中资源的第一次请求和第n次请求返回的效果是相同的)

RESTful风格下,一些常用的http方法使用如下:

状态码补充:

springboot实现RESTful API过程中,spring-boot-starter-web组件提供了REST操纵方法的对应注解(GET,POST,DELETE,PUT):

传统的设计方法中,对于增删改查数据往往在导航栏中有动词的参入。RESTful风格中。则要求url不要带有动词的出现。

例如:

传统删除用户:get方法 http://localhost/del?id=10

RESTful删除用户:delete http;//localhost/user/10

RESTful API实现的用户管理模块API示例:

(put之所以不用id是输入在请求体中而非导航栏)

复制代码
@RestController
public class usercontroller {
    @GetMapping("/user/{id}")
    public String getuserbyid(@PathVariable int id){
        System.out.println(id);
        return "根据ID获取用户";
    }
    @PostMapping("/user")
    public String insertuser(User user){
        return "添加用户";
    }
    @PutMapping("/user")
    public String updateuser(User user){
        return "更新用户";
    }
    @DeleteMapping("/user/{id}")
    public String deleteuserbyid(@PathVariable int id){
        System.out.println(id);
        return "根据id删除用户";
    }
}

@GetMapping注解中id作为动态值,需要加上{ }符号,{}的值应与下面方法名中的变量名相同。同时id作为动态变量,应在前面加上注解@PathVariable。否则只能用"?"来连接变量。

更新以及添加用户,id等信息一般写在请求体中,方法变量中则使用实体类变量。

**Swagger UI:**简单说:它是后端接口的 "可视化调试面板 + 自动更新的说明书",开发者 / 测试人员可通过网页直观查看、测试所有接口。后端开发者通过此网页直观方便的展示给前端开发者接口或传输方式等信息。

配置如下:

1,pom.xml中添加如下两个依赖

复制代码
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.9.2</version>
        </dependency>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.9.2</version>
        </dependency>

2,编写配置类

复制代码
@Configuration //告诉spring容器此类为配置类
@EnableSwagger2 //启用swagger2的功能
public class Swaggerconfig {
    @Bean
    public Docket createRestApi() {
        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                .select()
                .apis(RequestHandlerSelectors.basePackage("com"))// 让swagger作用于com开头的根目录,也可另做修改
                .paths(PathSelectors.any()).build();
    }

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

3,在application.properties中添加以下代码,让2.6+至2.9.x间的高版本springboot可以适配使用。

复制代码
spring.mvc.pathmatch.matching-strategy=ant_path_matcher

(注意检查application.properties中是否有' #spring.mvc.static-path-pattern=/images/** '此行修改静态文件路径的代码,这会一同修改swagger的访问路径,若有则会冲突)

4,配置好后通过访问localhost:8080/swagger-ui.html来访问网页

显示的是自己程序中的controller类

5,可以在controller类中添加注解来注释对应的方法

相关推荐
han_hanker26 分钟前
springboot 一个请求的顺序解释
java·spring boot·后端
2501_9216494926 分钟前
原油期货量化策略开发:历史 K 线获取、RSI、MACD 布林带计算到多指标共振策略回测
后端·python·金融·数据分析·restful
MaCa .BaKa27 分钟前
44-校园二手交易系统(小程序)
java·spring boot·mysql·小程序·maven·intellij-idea·mybatis
希望永不加班44 分钟前
SpringBoot 静态资源访问(图片/JS/CSS)配置详解
java·javascript·css·spring boot·后端
ada0_ada11 小时前
qt模块学习记录
开发语言·qt·学习
Xudde.1 小时前
班级作业笔记报告0x10
笔记·学习·安全·web安全·php
oh LAN1 小时前
RuoYi-Vue-master:Spring Boot 4.x (JDK 17+) (环境搭建)
java·vue.js·spring boot
知识分享小能手2 小时前
MongoDB入门学习教程,从入门到精通,MongoDB的选择片键 - 完整知识点(16)
数据库·学习·mongodb
知识分享小能手2 小时前
MongoDB入门学习教程,从入门到精通,MongoDB分片配置完全指南(15)
数据库·学习·mongodb
秋风不问归客2 小时前
Springboot面试全面整理
spring boot·后端·面试