因为公司使用的spring版本太高,在集成swagger的时候会存在一些问题,而网上的很多实例大多都是版本比较低的,为了是朋友们少才坑,我这边将集成的过程记录一下:
1. 引入spring、swagger的相关jar包(springfox-swagger2、springfox-swagger-ui),在pom.xml中配置:
<dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.4.0</version> <exclusions> <exclusion> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> </exclusion> <exclusion> <groupId>org.springframework</groupId> <artifactId>spring-beans</artifactId> </exclusion> <exclusion> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> </exclusion> <exclusion> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> </exclusion> <exclusion> <groupId>org.springframework</groupId> <artifactId>spring-aop</artifactId> </exclusion> <exclusion> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> </exclusion> <exclusion> <groupId>org.springframework</groupId> <artifactId>spring-orm</artifactId> </exclusion> <exclusion> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> </exclusion> <exclusion> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> </exclusion> <exclusion> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> </exclusion> <exclusion> <groupId>org.springframework</groupId> <artifactId>spring-oxm</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>2.4.0</version> </dependency>
提醒: 特别注意,springfox-swagger2在集成的时候,已经引入了spring的相关jar,特别是spring-context、spring-context-support的版本和项目中使用的版本完全不一致,项目在启动的时候出现很多包冲突的问题,这边在引入pom.xml文件的时候过滤掉了spring的相关jar包,如绿色标志。
2. 编写Swagger的配置类:
package com.ml.honghu.swagger.web; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.EnableWebMvc; 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; @EnableWebMvc @EnableSwagger2 @Configuration @ComponentScan(basePackages ={"com.ml.honghu.**.rest"}) public class SwaggerConfig { @Bean public Docket createRestApi() { return new Docket(DocumentationType.SWAGGER_2) .apiInfo(apiInfo()) .select() .apis(RequestHandlerSelectors.basePackage("com.ml.honghu")) .paths(PathSelectors.any()) .build(); } private ApiInfo apiInfo() { return new ApiInfoBuilder() .title("接口列表 v1.0") .description("接口信息") .termsOfServiceUrl("http://honghu.com") .contact(new Contact("", "", "HongHu")) .version("1.1.0") .build(); } }
提醒:注意红色标注的地方
3. 在spring-mvc.xml文件中进行过滤器的配置,过滤掉swagger的相关访问配置:
<mvc:exclude-mapping path="/swagger*/**"/> <mvc:exclude-mapping path="/v2/**"/> <mvc:exclude-mapping path="/webjars/**"/>
4. 服务配置项
@Api("区域服务") @RestController @RequestMapping(value = "/rest/area") public class AreaService { @Autowired private AreaService areaService; @ApiOperation(value = "区域列表", httpMethod = "GET", notes = "区域列表") @IsLogin @ResponseBody @RequestMapping(value = "treeData", method = RequestMethod.GET) public List<Map<String, Object>> treeData( @ApiParam(required = true, value = "区域ID") @RequestParam(required=false) String extId, HttpServletResponse response) { List<Map<String, Object>> mapList = Lists.newArrayList(); List<Area> list = areaService.findAll(); for (int i=0; i<list.size(); i++){ Area e = list.get(i); if (StringUtils.isBlank(extId) || (extId!=null && !extId.equals(e.getId()) && e.getParentIds().indexOf(","+extId+",")==-1)){ Map<String, Object> map = Maps.newHashMap(); map.put("id", e.getId()); map.put("pId", e.getParentId()); map.put("name", e.getName()); mapList.add(map); } } return mapList; } }
4. 启动项目,查看结果:
到此结束!!
相关推荐
标题 "spring4.2.2 springMVC4.2.2 mybatis3.3.1" 暗示了这是一个关于三大主流Java企业级开发框架的整合应用:Spring、Spring MVC和MyBatis的版本集合。这三个框架在现代Java Web开发中占据了核心地位,为开发者提供...
本资源是一个最新 Spring 4.2.2 集成 Quartz Scheduler 2.2.2 的一个简单的 demo,也是博客《最新 Spring 4.2.2 集成 Quartz Scheduler 2.2.2 任务调度示例》的配套示例项目,该博客地址是:...
在Spring 4.2.2版本中,有以下几个重要的更新和改进: 1. 支持Java 8:这个版本完全兼容Java 8,包括Lambda表达式和日期时间API,使开发者能更好地利用Java 8的新特性。 2. 异步方法支持:Spring MVC引入了更强大的...
Spring Framework的4.2.2.RELEASE版本提供了许多新的特性和增强功能,以及对旧特性的改进。 首先,Spring Framework 4.2.2.RELEASE遵循了依赖注入和控制反转的设计模式。依赖注入(Dependency Injection, DI)是...
spring-framework-4.2.2.zip 进行spring开发必不可少的文件 该压缩包解压后的目录为: |----lib 所使用到的jar文件 |----docs 帮助文档 |----schema 结构 包含WEB开发程序所使用的spring jar文件、包含spring开发...
SSH整合是指将Spring、Struts2和Hibernate三个开源框架集成在一起,用于构建高效、灵活的企业级Web应用程序。这里我们讨论的是SSH整合的具体实现,基于Struts2.3.24、Spring4.2.2和Hibernate5.0.2这三个版本。 首先...
本文将深入探讨Spring Framework 4.2.2.RELEASE这一稳定版本,涵盖其主要模块、关键特性、使用方法以及源码分析。 1. **模块介绍** Spring框架由多个模块组成,包括Core Container(核心容器)、Data Access/...
主要内容: 提供了一步一步的操作指南来将Struts2从2.3.30版本平滑过渡至2.5.12版本,Spring由4.2.2更新至4.3.9以及Hibernate进阶提升到5.2.11版本的具体路径和技术要点阐述。详细讲述了每个阶段所需更改的内容,比如...
标题中的"spring-context-support-4.2.2和quartz-2.2.3所需Jar包"涉及到两个关键的Java库:Spring Context Support 4.2.2版本和Quartz Scheduler 2.2.3版本。这两个库在企业级Java应用开发中扮演着重要角色,特别是...
赠送jar包:spring-test-4.2.2.RELEASE.jar; 赠送原API文档:spring-test-4.2.2.RELEASE-javadoc.jar; 赠送源代码:spring-test-4.2.2.RELEASE-sources.jar; 赠送Maven依赖信息文件:spring-test-4.2.2.RELEASE....
分两个包(当前第二个)spring4.2.2最新最稳定版
7. **版本控制集成**:与Git等版本控制系统无缝集成,便于团队协作和代码管理。 8. **热重载**:在运行状态下,可以实时修改代码并立即看到效果,无需频繁重启应用。 9. **Kotlin支持**:作为首选的编程语言,...
spring-security-4.2.2.RELEASE相关的jar包和源码。包含核心的认证和连接控制类和接口,用spring security的框架都需要这些。支持单独的应用程序,远程客户端,方法(服务层) 安全和jdbc的基本服务.
这个版本,即"sts-4.2.2.RELEASE",是Spring社区为了提升Spring开发者的工作效率而精心打造的集成开发环境。 **STS的主要特性:** 1. **Spring项目向导**:STS包含了创建新Spring Boot、Spring MVC、Spring Web ...
总结,Spring Framework 4.2.2.RELEASE是一个功能强大且稳定的版本,它提供的完整jar包、源代码和文档为开发者提供了全方位的支持。无论是初学者还是经验丰富的开发者,都能从中受益匪浅,提升开发效率和应用质量。
Android ADB(Android Debug Bridge)是Google为...总之,这个最新版的Android ADB针对Windows系统和Android 4.2.2的支持,为开发者提供了更便捷、稳定的设备管理和调试环境,有助于提升开发效率和问题排查能力。
spring-framework-4.2.2.RELEASE官方完整包加官方文档
spring-framework-4.2.2.zip 进行spring开发必不可少的文件 该压缩包解压后的目录为: |----lib 所使用到的jar文件 |----docs 帮助文档 |----schema 结构 包含WEB开发程序所使用的spring jar文件、包含spring开发...
spring-core-4.2.2.RELEASE.jar (spring 4.4.2的核心jar包),Java开发中spring框架开发必须的依赖包。