Spring MVC集成springfox-swagger2构建restful API的方法详解
发布时间 - 2026-01-11 01:51:46 点击率:次前言

在集成springfox-swagger2之前,我也尝试着集成了swagger-springmvc,方式差不多,但是swagger-springmvc相对麻烦一点,因为要把它的静态文件copy到自己的项目中。所以还是用新版本的。
至于两者有什么不同,为什么进行版本变更请参见官方说明文档
方法如下
这里先写下需要的pom.xml配置(我引用的2.4.0,相对稳定)
<dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.4.0</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>2.4.0</version> </dependency>
还需要在spring-mvc.xml中添加映射静态的配置:
<mvc:default-servlet-handler />
然后就是swagger2的配置类:
package com.xingguo.logistics.swagger;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
@Configuration
@EnableSwagger2
public class SwaggerConfig {
@Bean
public Docket buildDocket(){
return new Docket(DocumentationType.SWAGGER_2)
.apiInfo(buildApiInf())
.select() .apis(RequestHandlerSelectors.basePackage("com.xingguo.logistics.controller"))//controller路径
.paths(PathSelectors.any())
.build();
}
private ApiInfo buildApiInf(){
return new ApiInfoBuilder()
.title("xingguo大标题")
.termsOfServiceUrl("http://blog.csdn.net/u014231523网址链接")
.description("springmvc swagger2")
.contact(new Contact("diaoxingguo", "http://blog.csdn.net/u014231523", "diaoxingguo@163.com"))
.build();
}
}
然后运行项目,输入自己的url。
http://{ip}:{port}/{projectname}/swagger-ui.html#/
我的url:
http://localhost:8989/logistics/swagger-ui.html#/
然后就可以看到效果图:
它会把按照controller,把所有的接口都加载进来。
我的目录结构如图:
然后,就是接口名称和参数的说明:
常用注解:
- @Api()用于类名
- @ApiOperation()用于方法名
- @ApiParam()用于参数说明
- @ApiModel()用于实体类
- @ApiModelProperty用于实体类属性
更详细的说明请参见官方注解说明文档
使用方法如图:
@Controller
//类上使用@Api
@Api(value="用户controller",description="用户相关操作")
public class UserController {
@RequestMapping(value="index",method=RequestMethod.POST)
//方法上使用@ApiOperation
@ApiOperation(value="首页",notes="跳转到首页")
//参数使用@ApiParam
public Object getIndex(@ApiParam(name="topic实体",value="json格式",required=true) @RequestBody Topic topic){
//业务内容,被我删除了,请忽略,主要看上面的注解
Object obj = new Object();
return obj;
}
}
//一般添加个@ApiModel()就可以,看情况使用里面的属性
@ApiModel(value="Topic", discriminator = "foo", subTypes = {Topic.class})
public class Topic{
}
效果图如下:
我在springboot中也集成了swagger2,集成方式基本相同,使用方式也基本一样。请参考Spring Boot集成springfox-swagger2构建restful API的方法教程
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如有疑问大家可以留言交流,谢谢大家对的支持。
# spring
# mvc
# swagger2
# springmvc集成swagger
# springmvc整合swagger
# Spring Boot集成springfox-swagger2构建restful API的方法教程
# Springboot整合Swagger2和Swagger3全过程
# SpringBoot Swagger2 接口规范示例详解
# Springboot整合Swagger2后访问swagger-ui.html 404报错问
# 解决springboot接入springfox-swagger2遇到的一些问题
# 自己的
# 如图
# 首页
# 我也
# 文档
# 我在
# 如有
# 要在
# 集成了
# 要把
# 可以看到
# 实体类
# 会把
# 这篇文章
# 中也
# 谢谢大家
# 还需
# 新版本
# 请参考
# 有什么不同
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?
佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】
魔方云NAT建站如何实现端口转发?
Laravel中的Facade(门面)到底是什么原理
如何在宝塔面板中创建新站点?
Laravel怎么创建控制器Controller_Laravel路由绑定与控制器逻辑编写【指南】
Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】
如何挑选高效建站主机与优质域名?
Swift中swift中的switch 语句
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
在线教育网站制作平台,山西立德教育官网?
教你用AI将一段旋律扩展成一首完整的曲子
php静态变量怎么调试_php静态变量作用域调试技巧【解答】
在线制作视频网站免费,都有哪些好的动漫网站?
Laravel怎么自定义错误页面_Laravel修改404和500页面模板
详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南
实例解析Array和String方法
米侠浏览器网页图片不显示怎么办 米侠图片加载修复
如何在Ubuntu系统下快速搭建WordPress个人网站?
Laravel如何自定义错误页面(404, 500)?(代码示例)
php打包exe后无法访问网络共享_共享权限设置方法【教程】
Laravel如何与Inertia.js和Vue/React构建现代单页应用
长沙做网站要多少钱,长沙国安网络怎么样?
香港网站服务器数量如何影响SEO优化效果?
大学网站设计制作软件有哪些,如何将网站制作成自己app?
html5audio标签播放结束怎么触发事件_onended回调方法【教程】
Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比
作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】
QQ浏览器网页版登录入口 个人中心在线进入
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门
Laravel如何实现多语言支持_Laravel本地化与国际化(i18n)配置教程
如何快速搭建虚拟主机网站?新手必看指南
深圳网站制作的公司有哪些,dido官方网站?
如何基于云服务器快速搭建网站及云盘系统?
jQuery 常见小例汇总
HTML 中如何正确使用模板变量为元素的 name 属性赋值
JS弹性运动实现方法分析
零基础网站服务器架设实战:轻量应用与域名解析配置指南
如何快速搭建高效WAP手机网站吸引移动用户?
Laravel模型关联查询教程_Laravel Eloquent一对多关联写法
香港服务器如何优化才能显著提升网站加载速度?
DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解
JS去除重复并统计数量的实现方法
php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】
Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程
香港服务器建站指南:外贸独立站搭建与跨境电商配置流程
高防服务器如何保障网站安全无虞?
什么是JavaScript解构赋值_解构赋值有哪些实用技巧
Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能

