当前位置: 首页 > news >正文

42、响应处理-【源码分析】-浏览器与PostMan内容协商完全适配

42、响应处理源码分析浏览器与PostMan内容协商完全适配

要实现浏览器与PostMan在内容协商上的完全适配,需要在Spring Boot应用中自定义内容协商策略,确保服务器能根据浏览器和PostMan的请求头正确返回合适格式的数据。以下是详细的步骤:

### 1. 理解内容协商

**内容协商**是HTTP协议中的一种机制,允许服务器根据客户端的请求头信息(如`Accept`、`Accept-Language`、`Accept-Encoding`等),选择最合适的响应内容格式。例如,客户端可以通过`Accept`头指定希望接收的数据格式,如`application/json`或`application/xml`。

### 2. 默认内容协商行为

Spring Boot默认使用`HeaderContentNegotiationStrategy`,根据请求头中的`Accept`字段进行内容协商。但对于浏览器请求,通常不显式设置`Accept`头,Spring Boot会默认返回HTML格式。

### 3. 自定义内容协商策略

为了实现浏览器与PostMan的完全适配,可以添加基于请求参数的内容协商策略,同时保留基于请求头的策略。

#### 步骤1:引入依赖

如果需要支持XML格式,引入Jackson的XML处理模块:

```xml

<dependency>

    <groupId>com.fasterxml.jackson.dataformat</groupId>

    <artifactId>jackson-dataformat-xml</artifactId>

</dependency>

```

#### 步骤2:配置内容协商

创建配置类,自定义内容协商策略:

```java

@Configuration

public class WebConfig implements WebMvcConfigurer {

    @Override

    public void configureContentNegotiation(ContentNegotiationConfigurer configurer) {

        // 定义支持的媒体类型和参数映射

        Map<String, MediaType> mediaTypes = new HashMap<>();

        mediaTypes.put("json", MediaType.APPLICATION_JSON);

        mediaTypes.put("xml", MediaType.APPLICATION_XML);

        mediaTypes.put("gg", MediaType.parseMediaType("application/x-guigu")); // 自定义格式

        // 创建基于请求参数的内容协商策略

        ParameterContentNegotiationStrategy parameterStrategy = 

            new ParameterContentNegotiationStrategy(mediaTypes);

        parameterStrategy.setParameterName("format"); // 指定参数名为format

        // 保留基于请求头的策略

        HeaderContentNegotiationStrategy headerStrategy = new HeaderContentNegotiationStrategy();

        // 配置内容协商策略

        configurer.strategies(Arrays.asList(parameterStrategy, headerStrategy));

    }

}

```

#### 步骤3:启用请求参数内容协商(可选)

在`application.properties`中开启基于请求参数的内容协商:

```properties

spring.contentnegotiation.favor-parameter=true

```

### 4. 测试与验证

#### PostMan测试

- 发送GET请求到`http://localhost:8080/test/person`,设置请求头`Accept: application/json`,返回JSON格式数据。

- 发送GET请求到`http://localhost:8080/test/person?format=xml`,返回XML格式数据。

- 发送GET请求到`http://localhost:8080/test/person?format=gg`,返回自定义格式数据。

#### 浏览器测试

- 在浏览器中访问`http://localhost:8080/test/person`,返回HTML格式数据(如果未配置视图解析器,可能报错)。

- 在浏览器中访问`http://localhost:8080/test/person?format=json`,返回JSON格式数据。

- 在浏览器中访问`http://localhost:8080/test/person?format=xml`,返回XML格式数据。

### 5. 注意事项

- **默认行为覆盖**:自定义内容协商策略可能会覆盖默认行为,需确保所有功能正常。

- **媒体类型注册**:确保所有自定义媒体类型在`mediaTypes`中注册。

- **Converter支持**:确保有对应的`MessageConverter`支持转换自定义格式。

通过以上步骤,可以实现浏览器与PostMan在内容协商上的完全适配,根据请求头或请求参数返回合适格式的数据。

相关文章:

  • 面试题小结(真实面试)
  • Elasticsearch中的语义搜索(Semantic Search)介绍
  • Go语言学习-->项目中引用第三方库方式
  • Zookeeper 集群部署与故障转移
  • 细说C语言将格式化输出到字符串的函数sprintf、_sprintf_l、swprintf、_swprintf_l、__swprintf_l
  • Git安装与常用命令全攻略
  • 机器翻译模型笔记
  • 股指期货合约价值怎么算?
  • (C++)STL:vector的认识与使用全解析
  • App 上线后还能加固吗?iOS 应用的动态安全补强方案实战分享(含 Ipa Guard 等工具组合)
  • OpenCV CUDA模块图像处理------图像连通域标记接口函数connectedComponents()
  • 纹理压缩格式优化
  • 【DeepSeek】【Dify】:用 Dify 对话流+标题关键词注入,让 RAG 准确率飞跃
  • python打卡第44天
  • 安全-JAVA开发-第二天
  • AI Agent 能否理解人类的行为和决策?
  • Kafka broker 写消息的过程
  • Vue3+Vite中lodash-es安装与使用指南
  • 48V带极性反接保护-差共模浪涌防护方案
  • 9.RV1126-OPENCV 视频的膨胀和腐蚀
  • 潍坊市网站制作/怎么提交百度收录
  • 做ebay货物查找的网站/网页怎么做出来的
  • 网站建设 武汉/友缘在线官网
  • 为什么大网站的百度快照更新速度慢还排第一/百度快照客服人工电话
  • 编程scratch网站/百度的人工客服电话
  • 网站运营改进的点/美国最新新闻头条