java:一个springfox swagger2的简单例子

# 示例程序

【pom.xml】

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><version>2.3.12.RELEASE</version>
</dependency>
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId><version>2.3.12.RELEASE</version>
</dependency>
<dependency><groupId>io.springfox</groupId><artifactId>springfox-boot-starter</artifactId><version>3.0.0</version>
</dependency>
<dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger-ui</artifactId><version>3.0.0</version>
</dependency>

【application.properties】

server.port=8080
spring.application.name=mySwaggermanagement.server.port=8080
management.endpoints.web.exposure.include=*

【SwaggerConfig.java】

package com.chz.mySwagger.config;@Configuration
public class SwaggerConfig {@Autowiredprivate TypeResolver typeResolver;@Beanpublic Docket petApi() {return new Docket(DocumentationType.SWAGGER_2).select().apis(RequestHandlerSelectors.any()).paths(PathSelectors.any()).build().pathMapping("/").directModelSubstitute(LocalDate.class, String.class).genericModelSubstitutes(ResponseEntity.class).alternateTypeRules(newRule(typeResolver.resolve(DeferredResult.class, typeResolver.resolve(ResponseEntity.class, WildcardType.class)),typeResolver.resolve(WildcardType.class))).useDefaultResponseMessages(false).globalResponses(HttpMethod.GET,singletonList(new ResponseBuilder().code("500").description("500 message").representation(MediaType.TEXT_XML).apply(r ->r.model(m ->m.referenceModel(ref ->ref.key(k ->k.qualifiedModelName(q ->q.namespace("some:namespace").name("ERROR")))))).build())).securitySchemes(singletonList(apiKey())).securityContexts(singletonList(securityContext())).enableUrlTemplating(true).globalRequestParameters(singletonList(new springfox.documentation.builders.RequestParameterBuilder().name("someGlobalParameter").description("Description of someGlobalParameter").in(ParameterType.QUERY).required(true).query(q -> q.model(m -> m.scalarModel(ScalarType.STRING))).build())).tags(new Tag("Pet Service", "All apis relating to pets"));}private ApiKey apiKey() {return new ApiKey("mykey", "api_key", "header");}private SecurityContext securityContext() {return SecurityContext.builder().securityReferences(defaultAuth()).forPaths(PathSelectors.regex("/anyPath.*")).build();}List<SecurityReference> defaultAuth() {AuthorizationScope authorizationScope = new AuthorizationScope("global", "accessEverything");AuthorizationScope[] authorizationScopes = new AuthorizationScope[1];authorizationScopes[0] = authorizationScope;return singletonList(new SecurityReference("mykey", authorizationScopes));}@BeanSecurityConfiguration security() {return SecurityConfigurationBuilder.builder().clientId("test-app-client-id").clientSecret("test-app-client-secret").realm("test-app-realm").appName("test-app").scopeSeparator(",").additionalQueryStringParams(null).useBasicAuthenticationWithAccessCodeGrant(false).enableCsrfSupport(false).build();}@BeanUiConfiguration uiConfig() {return UiConfigurationBuilder.builder().deepLinking(true).displayOperationId(false).defaultModelsExpandDepth(1).defaultModelExpandDepth(1).defaultModelRendering(ModelRendering.EXAMPLE).displayRequestDuration(false).docExpansion(DocExpansion.NONE).filter(false).maxDisplayedTags(null).operationsSorter(OperationsSorter.ALPHA).showExtensions(false).showCommonExtensions(false).tagsSorter(TagsSorter.ALPHA).supportedSubmitMethods(UiConfiguration.Constants.DEFAULT_SUBMIT_METHODS).validatorUrl(null).build();}
}

【Test1Controller.java】

package com.chz.mySwagger.controller1;@Api(tags="chz-Test1Controller")
@Slf4j
@RestController
@RequestMapping("/test1")
public class Test1Controller {@ApiOperation(value="第一个测试方法-value",notes="第一个测试方法-notes")@ApiImplicitParams({@ApiImplicitParam(name="p1",value="p1-value", defaultValue = "p1-defaultValue"),@ApiImplicitParam(name="p2",value="p2-value", defaultValue = "p2-defaultValue")})@ApiResponses({@ApiResponse(code = 200, message = "请求成功"),})@GetMapping("/test1")public String test1(@RequestParam(value = "p1")String p1,@RequestParam(value = "p2")String p2) {return "test1: p1="+p1+", p2="+p2+";";}
}

【Test2Controller.java】

package com.chz.mySwagger.controller2;@Api(tags="chz-Test2Controller")
@Slf4j
@RestController
@RequestMapping("/test2")
public class Test2Controller {@ApiOperation(value="第一个测试方法-value",notes="第一个测试方法-notes")@ApiImplicitParams({@ApiImplicitParam(name="p1",value="p1-value", defaultValue = "p1-defaultValue"),@ApiImplicitParam(name="p2",value="p2-value", defaultValue = "p2-defaultValue")})@ApiResponses({@ApiResponse(code = 200, message = "请求成功"),})@GetMapping("/test1")public String test1(@RequestParam(value = "p1")String p1,@RequestParam(value = "p2")String p2) {return "test1: p1="+p1+", p2="+p2+";";}
}

【IndexController.java】

package com.chz.mySwagger.controller1;@Slf4j
@Controller
@RequestMapping("/")
public class IndexController {@GetMapping("/")public String index() {return "redirect:/swagger-ui/index.html";}
}

【MySwaggerTest.java】

package com.chz.mySwagger;@SpringBootApplication
@EnableSwagger2
@ComponentScan(basePackageClasses = {Test1Controller.class,Test2Controller.class,
})
public class MySwaggerTest {public static void main(String[] args) {SpringApplication.run(MySwaggerTest.class, args);}
}

启动【MySwaggerTest】,访问【http://localhost:8080/swagger-ui/index.html】
在这里插入图片描述

# 参考资料

https://springfox.github.io/springfox/docs/current/#introduction

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/28186.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

视图-什么是(VIEW)?怎么创建(CREATE VIEW)?怎么删除(DROP)?怎么用(SELECT/INSERT/UPDATE/DELETE)?

一、引言 之前对数据库的操作都是针对基本关系表&#xff0c;操作都是在数据库的全局逻辑模式上进行的&#xff0c;而在实际的数据库系统中&#xff0c;可能用户只关心或只被允许使用数据库中的某些基本关系表或基本关系表中的某些属性列&#xff0c;这些数据构成了数据库的外…

vue(v-if,v-else-if-else-show)

基本应用 例子 <!DOCTYPE html> <html lang"en"> <head> <meta charset"UTE-8"> <meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice-w…

实战篇(一):软体2D模拟详解

import java.util.ArrayList; import com.thomasdiewald.pixelflow.java.DwPixelFlow; import com.thomasdiewald.pixelflow.java

LabView_波形控件

波形图表 将一定数量的数据点存储在缓冲区&#xff0c;并通过这种方式存储并显示这些数据点。当缓冲区被填满后&#xff0c;波形图表将会用新的数据点覆盖缓冲区中存在时间最久的数据点。 当数据点可用时&#xff0c;波形图表将显示已有的数据点外加最新接收到的数据点 。 您可…

nodejs安装及环境配置常见报错解决

Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行时环境,它允许 JavaScript 代码在服务器端运行。Node.js 的出现极大地扩展了 JavaScript 的应用场景,使其不仅仅局限于前端开发,还能够处理服务器端逻辑、数据库操作、网络编程等任务。以下是 Node.js 的一些主要功能详…

NVIDIA Triton系列02-功能与架构简介

NVIDIA Triton系列02-功能与架构简介 B站&#xff1a;肆十二-的个人空间-肆十二-个人主页-哔哩哔哩视频 (bilibili.com) 博客&#xff1a;肆十二-CSDN博客 问答&#xff1a;(10 封私信 / 72 条消息) 肆十二 - 知乎 (zhihu.com) 前面文章介绍微软 Teams 会议系统、微信软件与腾讯…

使用file.transferTo()做Java文件复制,目标文件存在时,是抛异常还是覆盖写入?

背景 最近在做一个项目&#xff0c;在服务端涉及到文件的复制操作&#xff0c;于是想到了 Java 中 FileInputStream 类的 transferTo() 方法。这里简单记录一下用法&#xff0c;另外&#xff0c;如果目标文件已经存在&#xff0c;该如何处理这种情况呢&#xff1f;是出现异常还…

儿童编程语言

儿童编程是指为儿童设计的编程教育活动&#xff0c;旨在通过有趣、互动的方式教授儿童编程的基本概念和技能。随着科技的发展&#xff0c;编程教育越来越受到重视&#xff0c;因为它不仅能够培养儿童的逻辑思维、问题解决能力和创造力&#xff0c;还能为他们未来的学习和职业发…

C语言怎样复制图形?

一、问题 C语⾔中如何实现把屏幕某⼀处的图形复制到另⼀处&#xff1f; 二、解答 复制图形要⽤到以下3个函数&#xff1a; void far getimage(int xl,nt yl, int x2,int y2, void far *mapbuf); void far putimge(int x,int,y,void *mapbuf, int op); unsined far imagesiz…

Thinkphp一文鸡富贵鸡玫瑰庄园富农场仿皮皮果理财农场源码

Thinkphp一文鸡富贵鸡玫瑰庄园富农场仿皮皮果理财农场源码&#xff0c;喜欢的朋友可以下载研究 一文鸡富贵鸡玫瑰庄园富农场仿皮皮果理财农场源码

Django初学者指南

文章目录 Django初学者指南1 Django简介1.1 Django的历史1.2 使用Django的知名网站1.4 Django的主要特点1.5 Django的工作原理 2 Django 使用2.1 Django 支持的 Python 版本2.2 Django 版本 3 Django 开发 Web 程序3.1 安装Django3.2 创建Django项目3.3 运行开发服务器3.4 创建…

数据结构02 队列及其应用【C++实现】

目录 队列及其特点 利用数组模拟队列的基本操作 创建队列 空队条件 元素入队 元素出队 模拟超市收银问题 队列操作 初始化 入队操作 出队操作 取出队首元素 STL模板中队列的基本使用 训练&#xff1a;约瑟夫问题 参考程序 队列及其特点 队列是一种特殊的线性表&am…

求导,积分

求导公式&#xff1a; 复合函数求导法则&#xff1a;两个函数导函数的乘积. 例如&#xff1a;f(x)2x1,f(x)2,g(x)x^24x4,g(x)2x4 那么复合函数&#xff1a; g(f(x))(2x1)^24(2x1)4 把&#xff08;2x1&#xff09;看做整体,则g2(2x1)4 然后再求&#xff08;2x1&#xff09;的导函…

Stable Diffusion vs DALL·E3

大模型技术论文不断&#xff0c;每个月总会新增上千篇。本专栏精选论文重点解读&#xff0c;主题还是围绕着行业实践和工程量产。若在某个环节出现卡点&#xff0c;可以回到大模型必备腔调或者LLM背后的基础模型新阅读。而最新科技&#xff08;Mamba,xLSTM,KAN&#xff09;则提…

网络编程(五)IO模型

文章目录 一、 阻塞IO&#xff08;一&#xff09;阻塞IO模式&#xff08;二&#xff09;示例 二、非阻塞IO&#xff08;一&#xff09;特点&#xff08;二&#xff09;fcntl&#xff08;三&#xff09;示例 三、IO多路复用&#xff08;一&#xff09;实现原理&#xff08;二&am…

基于System-Verilog的流水灯设计与仿真

文章目录 一、system Verilog1.语言基本介绍2.过程赋值和连续赋值 二、编写testbench仿真1.流水灯testbench2.2位全加器3.实验结果 一、system Verilog 1.语言基本介绍 像 Verilog 和 VHDL 之类的硬件描述语言 (HDL) 主要用于描述硬件行为&#xff0c;以便将其转换为由组合门…

【实用技巧】Unity中的3D物理系统:刚体——使用技巧

在使用Unity的3D物理系统中的刚体&#xff08;Rigidbody&#xff09;时&#xff0c;有一些技巧可以帮助你更有效地实现物理效果和优化性能。以下是一些使用刚体的技巧&#xff1a; 合理使用Is Kinematic属性&#xff1a; 对于那些不需要物理计算的对象&#xff0c;比如玩家控制…

海底管缆先敷后埋与边敷边埋有什么区别?

海缆铺设有两种方式&#xff1a;“边敷边埋”和“先敷后埋”。 “边敷边埋”冲埋式埋设犁施工法———通过埋设犁(水力开沟机)泵送高压水&#xff0c;在海底冲出一条沟槽的同时&#xff0c;将海缆平铺下去,然后利用在潮汐作用下海床面自行回填(必要时采取压盖保护施工)。主要施…

[linux]如何跟踪linux 内核运行的流程呢

前面已经可以把内核编译出来&#xff0c;但是作为技术狗想看到内核是怎么运行的怎么办&#xff1f; 内核很多代码都是C语言写的&#xff0c;那简单&#xff0c;添加2行代码&#xff1a; include/linux/printk.h 529和530原来的&#xff1a; #define pr_info(fmt, ...) \ …

python查看包的版本

在Python中,有多种方法可以查看已安装包的版本。以下是几种常用的方法: 使用pip命令: 在命令行或终端中,你可以使用pip命令来查看已安装包的版本。例如,要查看numpy的版本,可以运行: pip show numpy这将显示numpy包的详细信息,包括版本号。 如果你使用的是pip3(对应于…