Spring 4.2.2以上版本和swagger集成方案和踩過的坑

因為公司使用的spring版本太高是整,在集成swagger的時候會存在一些問題,而網(wǎng)上的很多實例大多都是版本比較低的,為了是朋友們少才坑莺治,我這邊將集成的過程記錄一下:

  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在集成的時候翁锡,已經(jīng)引入了spring的相關jar蔓挖,特別是spring-context、spring-context-support的版本和項目中使用的版本完全不一致馆衔,項目在啟動的時候出現(xiàn)很多包沖突的問題,這邊在引入pom.xml文件的時候過濾掉了spring的相關jar包怨绣,如綠色標志角溃。

  1. 編寫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();    
    }    
}    

提醒:注意紅色標注的地方

  1. 在spring-mvc.xml文件中進行過濾器的配置,過濾掉swagger的相關訪問配置:
 [view plain](https://blog.csdn.net/qq_40354025/article/details/79383884# "view plain")[copy](https://blog.csdn.net/qq_40354025/article/details/79383884# "copy")

<embed id="ZeroClipboardMovie_3" src="https://csdnimg.cn/public/highlighter/ZeroClipboard.swf" loop="false" menu="false" quality="best" bgcolor="#ffffff" width="16" height="16" name="ZeroClipboardMovie_3" align="middle" allowscriptaccess="always" allowfullscreen="false" type="application/x-shockwave-flash" pluginspage="http://www.macromedia.com/go/getflashplayer" flashvars="id=3&amp;width=16&amp;height=16" wmode="transparent" style="box-sizing: border-box; outline: 0px; word-break: break-all;">

<embed id="ZeroClipboardMovie_8" src="https://csdnimg.cn/public/highlighter/ZeroClipboard.swf" loop="false" menu="false" quality="best" bgcolor="#ffffff" width="16" height="16" name="ZeroClipboardMovie_8" align="middle" allowscriptaccess="always" allowfullscreen="false" type="application/x-shockwave-flash" pluginspage="http://www.macromedia.com/go/getflashplayer" flashvars="id=8&amp;width=16&amp;height=16" wmode="transparent" style="box-sizing: border-box; outline: 0px; word-break: break-all;"> 

1.  <mvc:exclude-mapping path="/swagger*/**"/>    
2.  <mvc:exclude-mapping path="/v2/**"/>    
3.  <mvc:exclude-mapping path="/webjars/**"/>

  1. 服務配置項
<span style="color: #ff0000;">@Api("區(qū)域服務")</span>    
@RestController    
@RequestMapping(value = "/rest/area")    
public class AreaService  {    
    
    @Autowired    
    private AreaService areaService;    
        
    <span style="color: #ff0000;">@ApiOperation(value = "區(qū)域列表", httpMethod = "GET", notes = "區(qū)域列表")</span>    
    @IsLogin    
    @ResponseBody    
    @RequestMapping(value = "treeData", method = RequestMethod.GET)    
    public List<Map<String, Object>> treeData(    
            <span style="color: #ff0000;">@ApiParam(required = true, value = "區(qū)域ID")</span>  @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. 啟動項目篮撑,查看結果:

image

分布式的一些解決方案减细,有愿意了解的朋友可以找我們團隊探討
完整項目的源碼來源 技術支持1791743380

?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市赢笨,隨后出現(xiàn)的幾起案子未蝌,更是在濱河造成了極大的恐慌,老刑警劉巖茧妒,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件萧吠,死亡現(xiàn)場離奇詭異,居然都是意外死亡桐筏,警方通過查閱死者的電腦和手機纸型,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人狰腌,你說我怎么就攤上這事除破。” “怎么了琼腔?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵瑰枫,是天一觀的道長。 經(jīng)常有香客問我丹莲,道長光坝,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任圾笨,我火速辦了婚禮教馆,結果婚禮上,老公的妹妹穿的比我還像新娘擂达。我一直安慰自己土铺,他們只是感情好,可當我...
    茶點故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布板鬓。 她就那樣靜靜地躺著悲敷,像睡著了一般。 火紅的嫁衣襯著肌膚如雪俭令。 梳的紋絲不亂的頭發(fā)上后德,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天,我揣著相機與錄音抄腔,去河邊找鬼瓢湃。 笑死,一個胖子當著我的面吹牛赫蛇,可吹牛的內(nèi)容都是我干的绵患。 我是一名探鬼主播,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼悟耘,長吁一口氣:“原來是場噩夢啊……” “哼落蝙!你這毒婦竟也來了?” 一聲冷哼從身側響起暂幼,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤筏勒,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后旺嬉,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體管行,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年鹰服,在試婚紗的時候發(fā)現(xiàn)自己被綠了病瞳。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片揽咕。...
    茶點故事閱讀 38,137評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖套菜,靈堂內(nèi)的尸體忽然破棺而出亲善,到底是詐尸還是另有隱情,我是刑警寧澤逗柴,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布蛹头,位于F島的核電站,受9級特大地震影響戏溺,放射性物質發(fā)生泄漏渣蜗。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一旷祸、第九天 我趴在偏房一處隱蔽的房頂上張望耕拷。 院中可真熱鬧,春花似錦托享、人聲如沸骚烧。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽赃绊。三九已至,卻和暖如春羡榴,著一層夾襖步出監(jiān)牢的瞬間碧查,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工校仑, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留忠售,地道東北人。 一個月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓迄沫,卻偏偏與公主長得像档痪,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子邢滑,可洞房花燭夜當晚...
    茶點故事閱讀 42,901評論 2 345

推薦閱讀更多精彩內(nèi)容