当前位置:网站首页>13. 内容协商

13. 内容协商

2022-08-10 23:35:00 要学就学灰太狼


13.1 基本介绍

  1. 根据客户端接收能力不同,SpringBoot 返回不同媒体类型的数据

  2. 比如:

    ● 客户端 Http 请求 Accept: application/xml 则返回 xml 数据
    ● 客户端 Http 请求 Accept: application/json 则返回 json 数据

  3. 比如下面的示意图

在这里插入图片描述

在这里插入图片描述

13.2 内容协商-应用实例

  • 需求说明:
    • 使用Postman发送Http请求
    • 根据请求头不同,返回对应的 json数据 或者 xml 数据
    • 如下图所示

在这里插入图片描述

在这里插入图片描述

  1. 在 pom.xml 增加处理 xml 的依赖
 <!--引入处理xml的依赖-->
 <dependency>
     <groupId>com.fasterxml.jackson.dataformat</groupId>
     <artifactId>jackson-dataformat-xml</artifactId>
 </dependency>
  1. 使用Postman发出不同的 Http Header ,可以看到返回对应的数据格式 (特别说明:测试前请重启一把项目)

  2. 切换 Postman 不同的 Accept 类型,来 Debug 源码,看看对应的 JsonGenerator 类型

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

----- Accept 切换成 application/xml 进行Degug -----

在这里插入图片描述

在这里插入图片描述

  1. 使用浏览器请求,为什么会返回 xml 数据,而不是 json

在这里插入图片描述


在这里插入图片描述

13.3 注意事项和使用细节

  1. Postman 可以通过修改 Accept 的值,来返回不同的数据格式

  2. 对于浏览器,我们无法修改其 Accept 的值,怎么办?

    => 解决方案:开启支持基于请求参数的内容协商功能

  • 修改 application.yml,开启基于请求参数的内容协商功能

在这里插入图片描述

spring:
  mvc:
# static-path-pattern: /xjsres/** #修改静态资源访问的路径/前缀
    hiddenmethod:
      filter:
        enabled: true #启用了 HiddenHttpMethodFilter 支持 rest风格请求
    view:    # 配置了视图解析器
      suffix: .html
      prefix: /       # 这里需要注意 前缀prefix 要考虑 static-path-pattern 的配置
    contentnegotiation:
      favor-parameter: true # 开启基于请求参数的内容协商功能
  web:
    resources:
      #修改/指定 静态资源的 存放路径/位置 # String[] staticLocations
      #注意:配置了 static-locations 原来的访问路径就被覆盖了,如果需要保留,要再指定一下
      static-locations: ["classpath:/xjsimg/", "classpath:/META-INF/resources/",
                         "classpath:/resources/", "classpath:/static/", "classpath:/public/"]


在这里插入图片描述

  • 完成测试

在这里插入图片描述


在这里插入图片描述

  • 注意,参数 format 是规定好的 , 在开启请求参数的内容协商功能后,SpringBoot 底层 ParameterContentNegotiationStrategy 会通过 format 来接收参数,然后返回对应的 媒体类型/数据格式,当然 format=xx 这个 xx 媒体类型/数据格式 是 SpringBoot 可以处理的才行,不能乱写

在这里插入图片描述

  • 也可以自定义配置 内容协商的请求参数名

在这里插入图片描述

spring:
  mvc:
# static-path-pattern: /xjsres/** #修改静态资源访问的路径/前缀
    hiddenmethod:
      filter:
        enabled: true #启用了 HiddenHttpMethodFilter 支持 rest风格请求
    view:    # 配置了视图解析器
      suffix: .html
      prefix: /       # 这里需要注意 前缀prefix 要考虑 static-path-pattern 的配置
    contentnegotiation:
      favor-parameter: true # 开启基于请求参数的内容协商功能
      parameter-name: xjsformat # 我们自定义一个 内容协商的参数名 [默认是format]
  web:
    resources:
      #修改/指定 静态资源的 存放路径/位置 # String[] staticLocations
      #注意:配置了 static-locations 原来的访问路径就被覆盖了,如果需要保留,要再指定一下
      static-locations: ["classpath:/xjsimg/", "classpath:/META-INF/resources/",
                         "classpath:/resources/", "classpath:/static/", "classpath:/public/"]

在这里插入图片描述


在这里插入图片描述


原网站

版权声明
本文为[要学就学灰太狼]所创,转载请带上原文链接,感谢
https://blog.csdn.net/weixin_60766221/article/details/126177629