统一的Json组件和csv下载组件

技术杂谈47

Json组件

  • 规范Json接口格式
  • Controller中一律返回 Java object,组件将自动转换数据格式,满足Json接口格式
  • 统一处理Json接口中出现的异常,controller中不再需要 try-catch.Spring只有针对页面请求的SimpleMappingExceptionResolver异常解决方案,并没有针对使用@ResponseBody的方法异常处理

  • 在Spring配置文件中增加: <context:component-scan base-package="ren.wenchao.web.common, your-controller-packages"></context:component-scan>

  • 不需要配置 <mvn:annotation-driven></mvn:annotation-driven>
  • 在需要返回Json的Controller的方法上标注: @JsonResponseBody 注解,默认是V2版本。可以参考 TestController.java文件

示例1

  @RequestMapping(value = "/testJsonResponceBodyV2ReturnMap")
   @JsonResponseBody(version = JsonResponseBody.Version.V2)
   public Map testJsonResponceBodyV2ReturnMap() {
       HashMap<object, object> hashMap = Maps.newHashMap();
       hashMap.put("key", "value");
       return hashMap;
   }
</object,>

返回:

{
    "code":0,
    "msg":"",
    "data":{
        "key":"value"
    }
}

示例2

    @RequestMapping(value = "/testJsonResponceBodyV1WithException")
    @JsonResponseBody(version = JsonResponseBody.Version.V1)
    public List<string> testJsonResponceBodyV1WithException() {
        throw new RuntimeException("some exception");
    }
</string>

返回:

{
    "ret":false,
    "msg":"some exception"
}

更多示例请参考: TestController.java

CSV组件

  • 提供一个统一的CSV文件下载功能,各个系统就不需要重复编写了
  • 简化「cvs下载功能」的实现

  • 假设你的业务model为 Payload,有可能你最终需要的csv的列和业务model Payload的属性不完全一致,
    因此你需要创建一个 SomeCSVPayload(名字随意)来实现 BaseCSVPayload接口,并制定csv的列头等信息

  • 在对应的Controller方法上增加 @CSVResponceBody(fileName = "output", payloadClass = SomeCSVPayload.class),如下:
    @RequestMapping(value = "/testCSVResponceBody")
    @CSVResponceBody(fileName = "output", payloadClass = SomeCSVPayload.class)
   public SomeCSVPayload testCSVResponceBody() {
       return new SomeCSVPayload();
   }

示例使用请查看TestController.java中的 testCSVResponceBody方法

Excel组件

暂时没打算支持Excel下载,因为Excel需要区分版本,不同版本的限制也有些不同,而CSV比较通用,因此目前只支持csv

Original: https://www.cnblogs.com/rollenholt/p/4933881.html
Author: Rollen Holt
Title: 统一的Json组件和csv下载组件