0

0

Spring REST API 406 错误:内容协商与解决方案

心靈之曲

心靈之曲

发布时间:2025-08-31 17:41:01

|

758人浏览过

|

来源于php中文网

原创

Spring REST API 406 错误:内容协商与解决方案

本文旨在深入解析Spring REST API中常见的HTTP状态码406 (Not Acceptable) 错误,该错误通常发生在服务器无法根据客户端的Accept头找到合适的资源表示形式时。教程将详细阐述错误产生的原理,并通过添加@GetMapping和@PostMapping注解中的produces和consumes属性来明确指定API支持的媒体类型,从而提供一个清晰、专业的解决方案,确保Spring应用能够正确地进行内容协商,实现预期的JSON响应。

理解HTTP 406 Not Acceptable 错误

在spring restful api开发中,http 406 not acceptable 错误是一个常见的挑战,尤其是在处理客户端与服务器之间的内容协商时。当客户端发送一个请求,并在其accept请求头中声明了它能够处理的媒体类型(例如application/json或application/xml),而服务器端却无法生成任何符合这些媒体类型的响应时,就会返回406状态码。

错误堆栈信息通常会显示org.springframework.web.HttpMediaTypeNotAcceptableException: Could not find acceptable representation,这明确指出Spring MVC的消息转换器无法找到一个可以将控制器方法返回值转换为客户端可接受格式的处理器。即使项目中引入了Jackson等JSON处理库的依赖,如果Spring无法正确识别或应用这些转换器,问题依然会存在。

错误原因分析

Spring MVC通过HttpMessageConverter接口处理HTTP请求和响应体的序列化与反序列化。当一个控制器方法返回一个Java对象时,Spring会尝试使用注册的HttpMessageConverter将其转换为HTTP响应体。这个过程需要考虑以下几个关键因素:

  1. 客户端的Accept头: 客户端通过此头告诉服务器它期望接收的媒体类型。
  2. 服务器端支持的媒体类型: 服务器通过其配置(例如@RequestMapping注解的produces属性)声明它能够生成的媒体类型。
  3. 可用的HttpMessageConverter: Spring容器中注册的转换器,例如MappingJackson2HttpMessageConverter用于JSON,Jaxb2RootElementHttpMessageConverter用于XML等。

当上述任一环节不匹配时,例如客户端期望JSON,但服务器只声明能生产XML,或者虽然有JSON转换器但控制器方法没有明确声明produces JSON,Spring就可能抛出406错误。在提供的案例中,虽然添加了Jackson相关的依赖,但如果客户端期望JSON而Spring默认或尝试生成XML(可能是因为某种配置或依赖冲突导致XML转换器优先级更高),或者控制器方法没有明确指定produces = MediaType.APPLICATION_JSON_VALUE,那么问题依然会存在。

解决方案:明确指定媒体类型

解决406错误的核心在于明确告诉Spring控制器方法能够produces(生产)哪种媒体类型的响应,以及能够consumes(消费)哪种媒体类型的请求。这可以通过在@RequestMapping及其派生注解(如@GetMapping, @PostMapping)上使用produces和consumes属性来实现。

1. 解决GET请求的406错误(produces)

对于返回响应体的GET请求,我们需要使用produces属性来指定控制器方法能够生成的媒体类型。例如,如果期望返回JSON格式的响应,应将produces设置为MediaType.APPLICATION_JSON_VALUE。

示例代码:

import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.*;
import lombok.extern.log4j.Log4j2;
import org.springframework.beans.factory.annotation.Autowired;

@RestController
@EnableWebMvc
@RequestMapping("/api")
@Log4j2
public class UsersController {

    @Autowired
    UsersService service;

    @ResponseBody
    @GetMapping(value = "/users", 
                produces = MediaType.APPLICATION_JSON_VALUE) // 明确指定生成JSON
    public ResponseEntity findUById(@RequestParam Long userID) {
        // ... 业务逻辑 ...
        return service.getUsersInfoById(userID);
    }

    // ... 其他方法 ...
}

通过添加produces = MediaType.APPLICATION_JSON_VALUE,我们明确告诉Spring,findUById方法将生成JSON格式的响应。当客户端发送带有Accept: application/json头的请求时,Spring就能够找到MappingJackson2HttpMessageConverter来处理响应。

2. 解决POST请求的406/415错误(consumes & produces)

对于POST请求,通常涉及到接收请求体并返回响应体。因此,除了produces,我们还需要考虑consumes属性,它指定了控制器方法能够接受的请求体媒体类型。如果客户端发送的Content-Type头与consumes不匹配,可能会导致415 Unsupported Media Type 错误。

速创猫AI简历
速创猫AI简历

一键生成高质量简历

下载

示例代码:

import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.*;
import lombok.extern.log4j.Log4j2;
import org.springframework.beans.factory.annotation.Autowired;

@RestController
@EnableWebMvc
@RequestMapping("/api")
@Log4j2
public class UsersController {

    @Autowired
    UsersService service;

    @PostMapping(value = "/users",
                 consumes = MediaType.APPLICATION_JSON_VALUE, // 明确指定消费JSON请求体
                 produces = MediaType.APPLICATION_JSON_VALUE)  // 明确指定生成JSON响应体
    public Users createU(@RequestBody UsersPostRequestBody ubody) {
        // ... 业务逻辑 ...
        return service.save(ubody);
    }

    // ... 其他方法 ...
}

在这里,consumes = MediaType.APPLICATION_JSON_VALUE确保控制器方法只接受JSON格式的请求体,而produces = MediaType.APPLICATION_JSON_VALUE则确保响应也是JSON格式。

依赖管理与注意事项

虽然明确指定produces和consumes是解决406错误的关键,但正确的依赖管理也是必不可少的。为了支持JSON处理,jackson-databind是核心依赖:


    com.fasterxml.jackson.core
    jackson-databind
    ${jackson.version} 


    com.fasterxml.jackson.core
    jackson-core
    ${jackson.version}


    com.fasterxml.jackson.annotations
    jackson-annotations
    ${jackson.version}

而jackson-dataformat-xml只有在需要处理XML时才应添加。在尝试获取JSON响应时,如果添加了XML相关的Jackson依赖,可能会导致Spring默认尝试使用XML转换器,从而使问题变得复杂。因此,仅在需要时引入相关依赖,并始终通过produces和consumes明确声明意图,是最佳实践。

总结

HTTP 406 Not Acceptable 错误在Spring REST API中通常是内容协商失败的信号。解决此问题的关键在于:

  1. 理解HTTP内容协商机制,特别是客户端的Accept头与服务器端的Content-Type头。
  2. 在Spring控制器方法中明确使用produces属性来声明该方法能够生成哪些媒体类型的响应。
  3. 对于接收请求体的API,使用consumes属性来声明该方法能够接受哪些媒体类型的请求体。
  4. 确保项目中包含了必要的HttpMessageConverter依赖,例如用于JSON的jackson-databind。

通过遵循这些实践,开发者可以构建更加健壮和可预测的Spring RESTful API,有效避免内容协商相关的错误,确保API能够按照预期提供和消费数据。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

825

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

724

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

728

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

395

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

445

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

429

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16881

2023.08.03

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

65

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.2万人学习

C# 教程
C# 教程

共94课时 | 5.7万人学习

Java 教程
Java 教程

共578课时 | 40.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号