我们经常都需要封装统一JSON格式 例如以下形式

  1. {
  2. “data”:“输出的数据”,
  3. “code”:“响应代码”,
  4. “msg”:“响应信息”
  5. }
  1. /**
  2. * Created by linli on 2017/7/31.
  3. */
  4. public class Result<T> {
  5. String code;
  6. String msg;
  7. T data;
  8. public String getCode() {
  9. return code;
  10. }
  11. public void setCode(String code) {
  12. this.code = code;
  13. }
  14. public String getMsg() {
  15. return msg;
  16. }
  17. public void setMsg(String msg) {
  18. this.msg = msg;
  19. }
  20. public T getData() {
  21. return data;
  22. }
  23. public void setData(T data) {
  24. this.data = data;
  25. }
  26. }

而我们经常是这么做的 new Result<>() 返回;

  1. @ResponseBody
  2. @RequestMapping("/test")
  3. public Result<BusinessResult> test() {
  4. //模拟业务成返回数据
  5. Result<BusinessResult> result = new Result<>();
  6. return result;
  7. }

这样做看起来好像没有什么不对,我已经通过 Result 封装了我的数据格式,返回去的结果是统一的。

但是我们仔细想想 ,我每个接口,每个Service ,每个业务实现类都要 返回一个 Result 这是不是重复的工作,可不可以统一封装呢?
重复的工作我们都应该想办法避免。
而且再仔细想想 们的业务Service ,注重点是完成我们的业务工作而不是花费大量的时间在 new Result() 上。

这样是三层架构的精髓。每一层都负责不一样的事情,尽可能的处理与自己关注点,避免无干的事情,
Service 的重点就是业务,而封装数据应该由Contrller 完成。
思想很重!!!!

于是我们想办法把他简化,正确的做法应该是这样的:

  1. @ResponseBody
  2. @RequestMapping("/test")
  3. public BusinessResult test() {
  4. //模拟业务成返回数据
  5. BusinessResult result = new BusinessResult();
  6. return result;
  7. }

我们的返回结果应该是我们的业务数据,封装数据 由spring mvc 控制层完成。

HttpMessageConverter 是 Spring3.0 新添加的一个接口,负责将请求信息转换为一个对象(类型为 T),将对象(类型为 T)输出为响应信息。

MappingJackson2HttpMessageConverter ,FastJsonHttpMessageConverter 等都是通过继承
HttpMessageConverter 达到json 转换效果, 有兴趣的同学可以看看源码。

我们也可以利用 重写 MappingJackson2HttpMessageConverter 或 FastJsonHttpMessageConverter 达到我们的 统一数据输出:

  1. /**
  2. * Created by Administrator on 2017/6/14.
  3. * 全局数据 统一输出
  4. */
  5. public class GlobalMessageConverter extends MappingJackson2HttpMessageConverter {
  6. public static Logger logger = LoggerFactory.getLogger(GlobalMessageConverter.class);
  7. /**
  8. * 写出数据
  9. *
  10. * @param object
  11. * @param type
  12. * @param outputMessage
  13. * @throws IOException
  14. * @throws HttpMessageNotWritableException
  15. */
  16. @Override
  17. protected void writeInternal(Object object, Type type, HttpOutputMessage outputMessage) throws IOException, HttpMessageNotWritableException {
  18. //Result 类型的 不用处理
  19. if (object instanceof Result ) {
  20. super.writeInternal(object, type, outputMessage);
  21. return;
  22. }
  23. Result<Object> baseRes = new Result<>();
  24. baseRes.setData(object);
  25. baseRes.setMsg("操作成功");
  26. baseRes.setCode(0);
  27. logger.info("输出参数:" + JsonUtil.toJson(baseRes));
  28. super.writeInternal(baseRes, Result.class, outputMessage);
  29. }
  30. @Override
  31. protected void init(ObjectMapper objectMapper) {
  32. super.init(objectMapper);
  33. getObjectMapper().setSerializationInclusion(JsonInclude.Include.NON_NULL);
  34. }
  35. @Override
  36. protected boolean supports(Class<?> clazz) {
  37. return super.supports(clazz);
  38. }
  39. @Override
  40. public void setSupportedMediaTypes(List<MediaType> supportedMediaTypes) {
  41. super.setSupportedMediaTypes(supportedMediaTypes);
  42. }
  43. }

spring boot 配置 HttpMessageConverter:

  1. @EnableFeignClients
  2. @SpringBootApplication
  3. @Configuration
  4. @EnableEurekaClient
  5. @EnableScheduling
  6. @EnableHystrix
  7. public class MicroBlogArticleCommentsServiceApplication {
  8. public static void main(String[] args) {
  9. SpringApplication.run(MicroBlogArticleCommentsServiceApplication.class, args);
  10. }
  11. @Bean
  12. @LoadBalanced
  13. public RestTemplate restTemplate() {
  14. return new RestTemplate();
  15. }
  16. @Bean
  17. public HttpMessageConverters fastJsonHttpMessageConverters() {
  18. GlobalMessageConverter converter = new GlobalMessageConverter();
  19. return new HttpMessageConverters(converter);
  20. }
  21. }

细心的同学可能会发现,如果我发生错误需要返回错误类型的 Result 怎么办? 你这样只能返回正确结果的Result(业务正常的Result),要是业务失败,如密码错误,用户不存在等怎么处理?

Spring mvc Json 的正确返回姿势的更多相关文章

  1. spring mvc json 返回乱码问题解决(vestion:3.x.x)

    本文是转载文章,感觉比较好,如有侵权,请联系本人,我将及时删除. 原文网址:<spring mvc json 返回乱码问题解决(vestion:3.x.x)> 工程中用springmvc返 ...

  2. spring mvc: json练习

    spring mvc: json练习 本例需要用到的json包: 如下: jackson-databind jackson-core jackson-annotations <!-- https ...

  3. Spring MVC JSON自己定义类型转换(续)

    前面提到了两种转换类型的方法(Spring MVC JSON自己定义类型转换),这里针对Json转换提供一种更简便的方法. 通过配置全局的日期转换来避免使用麻烦的注解. 首先用到了一个简单的日期工具类 ...

  4. 160506、Spring mvc新手入门(11)-返回json 字符串的其他方式

    Spring MVC返回 json字符串的方式有很多种方法,这里介绍最简单,也是最常使用的两种方式 一.使用  PrintWriter printWriter  直接输出字符串到返回结果中    不需 ...

  5. Spring MVC全局异常后返回JSON异常数据

    问题: 当前项目是作为手机APP后台支持,使用spring mvc + mybaits + shiro进行开发.后台服务与手机端交互是发送JSON数据.如果后台发生异常,会直接返回异常页面,显示异常内 ...

  6. spring mvc json返回防止乱码

    乱码问题 乱码一直是编程的常见问题,spring mvc 返回json数据时可能导致乱码,需要在controller中添加如下代码: @RequestMapping("/test" ...

  7. [Spring MVC] - JSON

    Spring MVC中使用JSON,先必需引用两个包:jackson-core-asl-1.9.13.jar.jackson-mapper-asl-1.9.13.jar 因为需要使用到jquery测试 ...

  8. Spring MVC json配置

    接口类的Controller,一般返回的是json数据,而Spring MVC中默认返回的string,而jsp页面的话,会按配置中自己行匹配转义字符串为对应的jsp文件. @Controller @ ...

  9. Spring MVC JSON 实现JsonSerializer Date类型转换

    转载至:http://blog.csdn.net/lantianzhange/article/details/40920933 在Spring MVC中存在两大类的类型转换,一类是Json,一个是Sp ...

随机推荐

  1. TJU Problem 2101 Bullseye

    注意代码中: result1 << " to " << result2 << ", PLAYER 1 WINS."<& ...

  2. 纯C:AES256

    尼玛的WordPress把格式全搞乱了 aes256.h #ifndef _AES256_H_ #define _AES256_H_ #include <stdio.h> #include ...

  3. react 路由跳转问题

    1.采用Link方法跳转 <Link to="/Index2" > 不要用link,回不来,也不能next </Link> 2.用context控制路由跳转 ...

  4. java错误:找不到或无法加载主类

    问题: 在 windows cmd 中编译后,运行 java 文件时,出现此错误 分析: 源文件 ClientDemo.java: package netdemo; public class Clie ...

  5. 硬盘安装Linux(ubuntu,centos)

    硬盘安装Linux 使用硬盘安装Linux最大的好处不只是方便,是快速.之前使用U盘安装,很慢,没有记录具体时间.Ubuntu区别不大,本身比较小,安装介质只有2G(ubuntu18.10):Cent ...

  6. python------模块定义、导入、优化 ------->hashlib模块

    一.hashlib模块 用于加密相关的操作,3.x版本里代替了md5模块和sha模块,主要提供SHA1,SHA224,SHA256,SHA384,SHA512,MD5算法. (MD5消息摘要算法(英语 ...

  7. window.location.herf=url参数有中文,到后台乱码问题解决

    js中的代码: /*将中文的参数进行两次编码 */ function queryByName(){                    //获取查询条件的用户名                   ...

  8. 新一代构建工具gradle学习

    简介:Gradle的出现,是技术发展的必然,站在了Ant.maven等构建工具的肩膀上,使用了一种强大且具有表达性的基于Groovy的领域特定语言(DSL),使其拥有易用且灵活的方式去实现定制逻辑.方 ...

  9. python——psutil的使用(获取进程信息)

    import psutil psutil.pids() [1, 2, 3, 7, 8, 9, 10, 12, 13, 14, 15, 16, 17, 18, 19, 20, 26, 27, 28, 2 ...

  10. 目前支持WebGL的浏览器有哪些?

    Google Chrome 9+ Mozilla Firefox 4+ Safari 5.1+(仅限于Mac OS X操作系统,不包括Windows) Opera 12 alpha及以上版本 IE9+ ...