开发者社区> rollenholt> 正文

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

简介:
+关注继续查看

java-web-common

java-web-common

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" />
  • 不需要配置<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;
   }

返回:

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

示例2

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

返回:

{
    "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

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
开源SPL助力JAVA处理公共数据文件(txt/csv/json/xml/xsl)
开源SPL助力JAVA处理公共数据文件(txt/csv/json/xml/xsl)
2083 0
JSON正确的下载网址及编译
JSON正确的下载网址及编译
27 0
Python csv、xlsx、json、二进制(MP3) 文件读写基本使用
“流”是一种抽象的概念,也是一种比喻,水流是从—端流向另一端的,而在python中的“水流"就是数据,数据会从一端"流向”另一端,根据流的方向性,我们可以将流分为输入流和输出流,当程序需要从数据源中读入数据的时候就会开启一个输入流,相反,写出数据也会开启一个输出流,需要写入的数据源可以是文件、内存或者网络等。
53 0
《Python编程:从入门到实践》学习记录(16)项目-解析CSV与JSON;matplotlib, pygal绘图
《Python编程:从入门到实践》学习记录(16)项目-解析CSV与JSON;matplotlib, pygal绘图
65 0
js读取csv文件为json显示
js读取csv文件为json显示
178 0
js将json数据以csv格式下载
js将json数据以csv格式下载
116 0
JSON正确的下载网址及编译
JSON正确的下载网址及编译
54 0
JS: json 数据转化为 demo.json 并下载文件
JS: json 数据转化为 demo.json 并下载文件
92 0
json转换为csv-基于python2
非常实用的工具,可以很方便得将json文件转换为csv文件,然后使用Excel软件打开查看。使用时只需要将要读取的json文件名更改为你需要的文件名即可(注:请将json文件放在和本文件同一路径下,否则需要使用绝对路径)。
1687 0
+关注
文章
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载