码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • SpringBoot - SWAGGER中配置.pathMapping(“XXXX“)引发的404错误


    写在前面

    SpringBoot - SWAGGER2的集成与使用(一)
    SpringBoot - SWAGGER2公共模块的抽象集成与使用(二)
    SpringBoot - SWAGGER3公共模块的抽象集成与使用(三)
    SpringBoot - 集成SWAGGER的常见问题

    问题描述

    A. 前端UI将SWAGGER-UI集成到系统的菜单中了,SWAGGER-UI是用iframe形式打开的;
    B. 直接在前端UI的菜单中访问SWAGGER-UI正常,接口访问正常;
    C. 如果直接使用:http://后端服务地址:后端端口/swagger-ui/index.html访问SWAGGER-UI,页面显示正常,但是测试接口的时候报404错误;
    D. SWAGGER的配置如下:

    @Bean
    public Docket createRestApi() {
        return new Docket(DocumentationType.OAS_30)
                // 是否启用Swagger
                .enable(enabled)
                // 用来创建该API的基本信息,展示在文档的页面中(自定义展示的信息)
                .apiInfo(apiInfo())
                // 设置哪些接口暴露给Swagger展示
                .select()
                // 扫描所有有注解的api, 用这种方式更灵活(本系统默认方式)
                //.apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class))
                // 扫描指定包中的swagger注解
                .apis(RequestHandlerSelectors.basePackage("cn.hadoopx.web.controller.system"))
                // 扫描所有
                //.apis(RequestHandlerSelectors.any())
                .paths(PathSelectors.any())
                .build()
                /* 设置安全模式,swagger可以设置访问token */
                .securitySchemes(securitySchemes())
                .securityContexts(securityContexts())
                .pathMapping("/dev-api");
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    问题分析

    A. 为什么直接在前端UI的菜单中访问SWAGGER-UI正常,接口访问正常?
    在前后端分离架构上,SWAGGER-UI使用iframe方式嵌套,生成的服务地址也是前端暴露的地址端口,然后请求过来时将请求代理到后端的目标地址上,同时前端会去掉’.pathMapping(“/dev-api”)'设置的请求前缀,所以访问是正常的。

    B. 为什么直接使用:http://后端服务地址:后端端口/swagger-ui/index.html访问SWAGGER-UI,页面显示正常,但是测试接口的时候报404错误?
    .pathMapping(“/dev-api”),只是一个附加的虚拟的路径,并没有实际映射作用到对应的@RequestMapping的路径上,实际的访问路径依然是去掉请求前缀"/dev-api"的,但是它会作用到生成SWAGGER-DOC里的API路径上,会在API路径的前面拼接上前缀,所以直接访问会报错。

    C. 如何解决?
    第一种方式:针对这个情况可以写个全局过滤器,将请求路径的前缀去掉;
    第二种方式:测试的时候,不使用SWAGGER,直接使用POST-MAN测试,使用服务接口真实的调用地址+端口(不带/dev-api前缀);
    第三种方式:直接通过前端的UI菜单来访问SWAGGER-UI。

  • 相关阅读:
    数据结构数组 Array 手写实现,扩容原理
    The file Structure
    【完美世界】石昊偷渡出境四人组产生分歧,云曦和石昊牵手,二人世界要开始了
    SpringBoot SSMP项目搭建保姆级教程
    决策树之算法CART(二)
    【项目】5.1阻塞和非阻塞、同步和异步 5.2Unix、Linux上的五种IO模型
    Docker
    Power BI----几个常用的分析方法和相适应的视觉对象
    码蹄集 - MT2322 - 还是跑图:还是简单图问题
    Fiber 架构实现流程
  • 原文地址:https://blog.csdn.net/goodjava2007/article/details/126390414
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号