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类中添加注解来注释对应的方法

相关推荐
weixin_458872612 小时前
东华复试OJ二刷复盘8
学习
海奥华22 小时前
Rust初步学习
开发语言·学习·rust
王知无(import_bigdata)3 小时前
一个极简的AI Agentic Engineering技术栈学习路线
人工智能·学习
y = xⁿ3 小时前
【从零开始学习Redis|第七篇】Redis 进阶原理篇:消息队列、分布式锁、缓存击穿与事务实现
java·redis·学习·缓存
式5163 小时前
VLLM架构学习(一)VLLM是什么、VLLM的原理
学习·vllm
beata3 小时前
Spring Boot基础-2:Spring Boot 3.x 起步依赖(Starter)深度拆解:为什么引入一个依赖就够了?
spring boot·后端
成长的小牛2334 小时前
MCP 学习笔记
笔记·学习·ai
深蓝轨迹4 小时前
SpringBoot YAML配置文件全解析:语法+读取+高级用法
java·spring boot·后端·学习
深蓝轨迹4 小时前
乐观锁 vs 悲观锁 含面试模板
java·spring boot·笔记·后端·学习·mysql·面试