为什么转载@responseBody这个注解的博客呢?因为我在看序列化的时候,就在考虑,Spring中使用@responseBody的Json序列化,为啥不用最常用的Serializable序列化呢?直接转换为二进制流不好吗???

先说@responseBody

1、@responseBody注解的作用是将controller的方法返回的对象通过适当的转换器转换为指定的格式之后,写入到response对象的body区,通常用来返回JSON数据或者是XML数据,需要注意的呢,在使用此注解之后不会再走试图处理器,而是直接将数据写入到输入流中,他的效果等同于通过response对象输出指定格式的数据。

2、使用

@RequestMapping("/login")@ResponseBodypublic User login(User user){return user;}

User字段:userName pwd 那么在前台接收到的数据为:'{"userName":"xxx","pwd":"xxx"}'

效果等同于如下代码:

  @RequestMapping("/login")public void login(User user, HttpServletResponse response){response.getWriter.write(JSONObject.fromObject(user).toString());}

再说序列化

什么是序列化?

内存中的数据对象只有转换为二进制流才可以进行数据持久化和网络传输。将数据对象转换为二进制流的过程称为对象的序列化(Serialization)。反之,将二进制流恢复为数据对象的过程称为反序列化(Deserialization)。序列化需要保留充分的信息以恢复数据对象,但是为了节约存储空间和网络带宽,序列化后的二进制流又要尽可能小。序列化常见的使用场景是RPC框架的数据传输。

1.Java原生序列化

  • Java类通过实现Serializable接口来实现该类对象的序列化,这个接口非常特殊,没有任何方法,只起标识作用.Java序列化保留了对象类的元数据(如类、成员变量、继承类信息等),以及对象数据等,兼容性最好,但不支持跨语言,而且性能一般。
  • 实现Serializable接口的类建议设置serialVersionUID字段值,如果不设置,那么每次运行时,编译器会根据类的内部实现,包括类名、接口名、方法和属性等来自动生成serialVersionUID。如果类的源代码有修改,那么重新编译后serial VersionUID的取值可能会发生变化。因此实现Serializable接口的类一定要显式地定义serialVersionUID属性值。修改类时需要根据兼容性决定是否修改serialVersionUID值:
  • 1.如果是兼容升级,请不要修改serialVersionUID字段,避免反序列化失败。
  • 2.如果是不兼容升级,需要修改serialVersionUID值,避免反序列化混乱。
  • 使用Java原生序列化需注意,Java反序列化时不会调用类的无参构造方法,而是调用native方法将成员变量赋值为对应类型的初始值。基于性能及兼容性考虑,不推荐使用Java 原生序列化。

2.Json序列化

  • JSON ( JavaScript O同ect Notation )是一种轻量级的数据交换格式。
  • JSON 序列化就是将数据对象转换为 JSON 字符串。
  • 在序列化过程中抛弃了类型信息,所以反序列化时只有提供类型信息才能准确地反序列化。
  • 相比前两种方式,JSON 可读性比较好,方便调试。
  • 序列化通常会通过网络传输对象 , 而对象中往往有敏感数据,所以序列化常常成为黑客的攻击点,攻击者巧妙地利用反序列化过程构造恶意代码,使得程序在反序列化的过程中执行任意代码。 Java 工程中广泛使用的 Apache Commons Collections 、Jackson 、 fastjson 等都出现过反序列化漏洞。如何防范这种黑客攻击呢?有些对象的敏感属性不需要进行序列化传输 ,可以加 transient 关键字,避免把此属性信息转化为序列化的二进制流。如果一定要传递对象的敏感属性,可以使用对称与非对称加密方
  • 式独立传输,再使用某个方法把属性还原到对象中。应用开发者对序列化要有一定的安全防范意识 , 对传入数据的内容进行校验或权限控制,及时更新安全漏洞,避免受到攻击。

@responseBody + 序列化相关推荐

  1. Spring MVC常用注解--“姐妹花”@RequestBody和@ResponseBody

    1. 引言 在这篇短文中,我们简要地介绍了Spring MVC中常用的注解 @RequestBody和@ResponseBody. 2. @RequestBody 简单地说,在@RequestBody ...

  2. Flutter开发之JSON及序列化(29)

    本文介绍了使用JSON的两个常规策略: 手动序列化和反序列化 通过代码生成自动序列化和反序列化 不同的项目具有不同的复杂度和场景.对于较小项目,使用代码生成器可能会过度.对于具有多个JSON mode ...

  3. 仅在序列化过程中使用@JsonIgnore,而不是反序列化

    本文翻译自:Only using @JsonIgnore during serialization, but not deserialization I have a user object that ...

  4. 如何在返回String的Spring MVC @ResponseBody方法中响应HTTP 400错误?

    本文翻译自:How to respond with HTTP 400 error in a Spring MVC @ResponseBody method returning String? I'm ...

  5. spring mvc3中JACKSON序列化日期格式的问题 - 墙头草的Java - BlogJava

    spring mvc3中JACKSON序列化日期格式的问题 - 墙头草的Java - BlogJava在SPRING MVC3中,比如做REST时,经常要用JASON去解析,遇到了日期格式化的问题, ...

  6. 使用HttpMessageConverter实现HTTP的序列化和反序列化

    对象的序列化/反序列化大家应该都比较熟悉:序列化就是将object转化为可以传输的二进制,反序列化就是将二进制转化为程序内部的对象.序列化/反序列化主要体现在程序I/O这个过程中,包括网络I/O和磁盘 ...

  7. jaxb util_JAXB自定义绑定– Java.util.Date / Spring 3序列化

    jaxb util JaxB可以处理Java.util.Date序列化,但是需要以下格式: " yyyy-MM-ddTHH:mm:ss ". 如果需要将日期对象格式化为另一种格式怎 ...

  8. Spring MVC –揭秘了@RequestBody和@ResponseBody

    在这篇文章中,我想对Spring MVC进行一些深入的探讨,以揭示将请求转换为参数对象后在幕后发生的情况,反之亦然. 在开始之前,我想解释这些注释的目的. @RequestBody和@Response ...

  9. JAXB自定义绑定– Java.util.Date / Spring 3序列化

    JaxB可以处理Java.util.Date序列化,但是需要以下格式: " yyyy-MM-ddTHH:mm:ss ". 如果需要将日期对象格式化为另一种格式怎么办? 我有同样的问 ...

最新文章

  1. ASP.NET导出文件FileResult的使用
  2. WP8.1学习系列(第二十五章)——控件样式
  3. python集合中的元素是否可以重复_python中集合中的元素是否可以重复
  4. 远程桌面mstsc /console(/admin) 的运用
  5. 在MFC中添加用户自定义消息
  6. 取色器 for Mac
  7. [算法模板]树状数组
  8. 黑客少年手机编 10 万行代码,恶意篡改 App 只为了 “炫技”?
  9. 一篇比较好的高数的学习规划分享
  10. 交通信息工程 实验四:交通仿真实验(一)
  11. Spark大数据技术与应用
  12. Python-Data-Science-Toolbox-Part-1
  13. 知识分享:移动设备的安全管理策略和方法
  14. 分析评估和定位声音质量
  15. Windows XP/2003序列号更换工具 1.0
  16. java exception message_Java 如何摆脱Exception.getMessage()输出带类名
  17. 鼎捷E10视频教程合集19大模块
  18. CKEditor/CKFinder升级心得
  19. 将本地代码push到github上
  20. nodejs q模块

热门文章

  1. TinyURL 的加密与解密(leetcode)
  2. MySQL 设计数据表时,时间类型 datetime、bigint、timestamp MySQL日期函数
  3. ArcGIS河网提取及淹没区分析
  4. Java SE基础知识详解第[18]期—网络编程(通信)
  5. 计算机三级网络怎么复习,计算机三级网络技术复习笔记七
  6. 监控案例实战 -- Zabbix 监控 企业级路由器
  7. 如何给python爬虫加界面_给Python爬虫做一个界面.上
  8. pip3 install 报错 protobuf requires Python ‘>=3.7‘ but the running Python is 3.6.8
  9. axivion和astree_axivion和astree_CALLIVION
  10. CSUST 1024 画画 题解(计算几何)