码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • HttpMessageConverter 消息转换器


    HttpMessageConverter 简介

    HttpMessageConverter 是SpringMVC中提供的一个策略接口,它是一个消息转换器类,Spring Mvc中就是由HttpMessageConverter负责转换HTTP的请求和响应。

    默认情况下,Spring Boot 会自动加载如下消息类型转换器:

    常见消息类型转换器介绍:

    • StringHttpMessageConverter:负责读取字符串格式的数据和写出二进制格式的数据(当返回值是或者接受值是String类型时,是由这个处理)
    • MappingJacksonHttpMessageConverter:负责读取和写入json格式的数据;(当返回值是对象或者List,就由这个处理)
    • ByteArrayHttpMessageConverter:负责读取二进制格式的数据和写出二进制格式的数据;
    • FormHttpMessageConverter:负责读取form提交的数据(能读取的数据格式为 application/x-www-form-urlencoded,不能读取multipart/form-data格式数据);负责写入application/x-www-from-urlencoded和multipart/form-data格式的数据;
    • ResourceHttpMessageConverter:负责读取资源文件和写出资源文件数据;
    • SourceHttpMessageConverter:负责读取和写入xml中javax.xml.transform.Source定义的数据;
    • Jaxb2RootElementHttpMessageConverter:负责读取和写入xml 标签格式的数据;
    • AtomFeedHttpMessageConverter:负责读取和写入Atom格式的数据;
    • RssChannelHttpMessageConverter:负责读取和写入RSS格式的数据;

    数据转换流程

    利用SpringMVC框架,可以使得我们在开发时,只要在代码中使用@RequestBody和@ResponseBody两个注解,就可以分别完成从请求报文到对象和从对象到响应报文的转换。而在源码内部,其实这种灵活的消息转换机制就是利用HttpMessageConverter来实现的。

    HttpMessageConverter的调用是RequestResponseBodyMethodProcessor类的解析请求参数的方法resolveArgument()和处理返回值的方法handleReturnValue()中进行调用的。这是关于@RequestBody和@ResponseBody两个注解的原理。

    消息转换器接口

    public interface HttpMessageConverter {
    
    	boolean canRead(Class clazz, @Nullable MediaType mediaType);
    
    	boolean canWrite(Class clazz, @Nullable MediaType mediaType);
    
    	List getSupportedMediaTypes();
    
    	default List getSupportedMediaTypes(Class clazz) {
    		return (canRead(clazz, null) || canWrite(clazz, null) ?
    				getSupportedMediaTypes() : Collections.emptyList());
    	}
    
    	T read(Class clazz, HttpInputMessage inputMessage)
    			throws IOException, HttpMessageNotReadableException;
    
    	void write(T t, @Nullable MediaType contentType, HttpOutputMessage outputMessage)
    			throws IOException, HttpMessageNotWritableException;
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    转换器加载流程

    消息转换器是在项目启动的时候通过WebMvcConfigurationSupport进行加载,当getMessageConverters()被调用的时候会通过configureMessageConverters()、addDefaultHttpMessageConverters()和extendMessageConverters()三个方法进行初始话消息转换器。生成的消息转换器放在List> messageConverters集合中

    	protected final List> getMessageConverters() {
            if (this.messageConverters == null) {
                this.messageConverters = new ArrayList();
                // 加载委托给WebMvcConfigurer类型的Bean
                this.configureMessageConverters(this.messageConverters);
                if (this.messageConverters.isEmpty()) {
                    // 加载默认的转换器
                    this.addDefaultHttpMessageConverters(this.messageConverters);
                }
                // 加载扩展消息转换器
                this.extendMessageConverters(this.messageConverters);
            }
            return this.messageConverters;
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    自定义消息转换器

    1. FastJson 、Gson 等组件自带常用json消息转换器
    2. 实现HttpMessageConverter 接口
    3. 继承 AbstractHttpMessageConverter 类

    加载自定义消息转换器

    1. 直接注入Bean 的方式替换
    2. 实现 WebMvcConfigurer#extendMessageConverters 接口方法
    @Configuration
    public class CustomWebMvcConfigurer implements WebMvcConfigurer {
    
        /**
         * 直接注入 HttpMessageConverters
         */
        @Bean
        public HttpMessageConverters customConverters() {
            return new HttpMessageConverters(configFastJsonHttpMessageConverter());
        }
    
        /**
         * 实现 WebMvcConfigurer#extendMessageConverters 接口
         */
        @Override
        public void extendMessageConverters(List> converters) {
            // 注意加载顺序
            converters.add(0, configFastJsonHttpMessageConverter());
        }
    
        /**
         * 配置JSON 消息转换器
         */
        private HttpMessageConverter configFastJsonHttpMessageConverter() {
            FastJsonHttpMessageConverter converter = new FastJsonHttpMessageConverter();
            FastJsonConfig fastJsonConfig = new FastJsonConfig();
            // 配置转换特性
            fastJsonConfig.setSerializerFeatures(
                SerializerFeature.DisableCircularReferenceDetect,
                SerializerFeature.WriteNonStringKeyAsString,
                SerializerFeature.WriteMapNullValue
            );
            converter.setFastJsonConfig(fastJsonConfig);
            // 设置处理消息类型
            converter.setSupportedMediaTypes(Collections.singletonList(MediaType.APPLICATION_JSON));
            return converter;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
  • 相关阅读:
    MySQL之JDBC编程
    【仿牛客网笔记】初识Spring Boot,开发社区首页-Spring MVC入门
    MySQL调优
    低代码信创开发核心技术(四)动态元数据系统设计
    JVM虚拟机(整体架构、类文件结构)我来了~~~
    优雅的实现符合开闭原则的流水日志抽取demo
    Qt5开发从入门到精通——第十二篇一节(Qt5 事件处理及实例——多线程及简单实例)
    [附源码]java毕业设计一点到家小区微帮服务系统
    eyb:操作员页面设计到高级搜索功能实现(四)
    Syntax Error: Error: PostCSS received undefined instead of CSS string (已解决)
  • 原文地址:https://blog.csdn.net/Huangjiazhen711/article/details/128049682
    • 最新文章
    • 攻防演习之三天拿下官网站群
      数据安全治理学习——前期安全规划和安全管理体系建设
      企业安全 | 企业内一次钓鱼演练准备过程
      内网渗透测试 | 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号