jackson过滤属性分为静态和动态两种。

静态如下:

定义两个Bean 先,这两个bean 是父子关系。

  1. public class User {
  2. private String name;
  3. private Date createDate;
  4. private Set<Article> articles = Sets.newHashSet();
  5. public String getName() {
  6. return name;
  7. }
  8. public void setName(String name) {
  9. this.name = name;
  10. }
  11. public Date getCreateDate() {
  12. return createDate;
  13. }
  14. public void setCreateDate(Date createDate) {
  15. this.createDate = createDate;
  16. }
  17. public Set<Article> getArticles() {
  18. return articles;
  19. }
  20. public void setArticles(Set<Article> articles) {
  21. this.articles = articles;
  22. }
  23. }
  1. public class Article {
  2. private String title;
  3. private User user;
  4. public String getTitle() {
  5. return title;
  6. }
  7. public void setTitle(String title) {
  8. this.title = title;
  9. }
  10. public User getUser() {
  11. return user;
  12. }
  13. public void setUser(User user) {
  14. this.user = user;
  15. }
  16. }

然后自己写的一个Jackson实用类

  1. public class Jacksons {
  2. private ObjectMapper objectMapper;
  3. public static Jacksons me() {
  4. return new Jacksons();
  5. }
  6. private Jacksons() {
  7. objectMapper = new ObjectMapper();
  8. // 设置输入时忽略在JSON字符串中存在但Java对象实际没有的属性
  9. objectMapper.disable(DeserializationConfig.Feature.FAIL_ON_UNKNOWN_PROPERTIES);
  10. objectMapper.configure(SerializationConfig.Feature.FAIL_ON_EMPTY_BEANS, false);
  11. objectMapper.setDateFormat(new SimpleDateFormat("yyyy-MM-dd"));
  12. }
  13. public Jacksons filter(String filterName, String... properties) {
  14. FilterProvider filterProvider = new SimpleFilterProvider().addFilter(filterName,
  15. SimpleBeanPropertyFilter.serializeAllExcept(properties));
  16. objectMapper.setFilters(filterProvider);
  17. return this;
  18. }
  19. public Jacksons addMixInAnnotations(Class<?> target, Class<?> mixinSource) {
  20. objectMapper.getSerializationConfig().addMixInAnnotations(target, mixinSource);
  21. objectMapper.getDeserializationConfig().addMixInAnnotations(target, mixinSource);
  22. return this;
  23. }
  24. public Jacksons setDateFormate(DateFormat dateFormat) {
  25. objectMapper.setDateFormat(dateFormat);
  26. return this;
  27. }
  28. public <T> T json2Obj(String json, Class<T> clazz) {
  29. try {
  30. return objectMapper.readValue(json, clazz);
  31. } catch (Exception e) {
  32. e.printStackTrace();
  33. throw new RuntimeException("解析json错误");
  34. }
  35. }
  36. public String readAsString(Object obj) {
  37. try {
  38. return objectMapper.writeValueAsString(obj);
  39. } catch (Exception e) {
  40. e.printStackTrace();
  41. throw new RuntimeException("解析对象错误");
  42. }
  43. }
  44. @SuppressWarnings("unchecked")
  45. public List<Map<String, Object>> json2List(String json) {
  46. try {
  47. return objectMapper.readValue(json, List.class);
  48. } catch (Exception e) {
  49. e.printStackTrace();
  50. throw new RuntimeException("解析json错误");
  51. }
  52. }
  53. }

最后是测试:

  1. public class Test {
  2. public static void main(String args[]) {
  3. User user = new User();
  4. user.setName("chris");
  5. user.setCreateDate(new Date());
  6. Article article = new Article();
  7. article.setTitle("title");
  8. article.setUser(user);
  9. Set<Article> articles = Sets.newHashSet(article);
  10. user.setArticles(articles);
  11. String userJson = Jacksons.me().readAsString(user);
  12. String articleJson = Jacksons.me().readAsString(article);
  13. System.out.println(userJson);
  14. System.out.println(articleJson);
  15. }
  16. }

1.父子关系引用

直接输出肯定是报循环错误,Jackson 提供了两个注解

@JsonManagedReference

public Set<Article> getArticles() {

return articles;

}

@JsonBackReference

public User getUser() {

return user;

}

打印结果为:{"name":"chris","createDate":"2012-04-18","articles":[{"title":"title"}]}, {"title":"title"}

2.@JsonIgnore注解

只说父子引用关系的。父子两边都加@JsonIgnore打印字符串为:

{"name":"chris","createDate":"2012-04-18"},{"title":"title"}

单向User加该注解

@JsonIgnore

public Set<Article> getArticles() {

return articles;

}

打印结果为:

{"name":"chris","createDate":"2012-04-18"}

{"title":"title","user":{"name":"chris","createDate":"2012-04-18"}}

单向Article 加该注解

@JsonIgnore

public User getUser() {

return user;

}

打印结果:

{"name":"chris","createDate":"2012-04-18","articles":[{"title":"title"}]}

{"title":"title"}

3.@JsonIgnoreType(没用过)

4.@JsonIgnoreProperties

这个加在类级别上, 用法很简单@JsonIgnoreProperties({"property1", "property2"})

动态过滤属性:

这个比较麻烦方法如下(有如下两种方法):

1.使用@JsonFilter注解

使用方法为先给ObjectMapper添加一个filter,然后还要在需要过滤的类上加@JsonFilter("filterName")注解。

比如说要过滤User 上的name属性,先

Jacksons.me().filter("myFilter", "name").readAsString(user),具体看Jacksons代码。并在User类上加@JsonFilter("myFilter")。

有点不爽的是如果用另外一个没有添加该filter的ObjectMapper解析的话会报错。

如果这个User类已经添加了@JsonFilter("myFilter")注解,但在另外一个地方又要解析它并不想过滤name 属性,那只能是

Jacksons.me().filter("myFilter", ""),然后在读出来。

如果要过滤多个属性可以如下:

Set<String> rolePros = new HashSet<String>();
rolePros.add("rank");
rolePros.add("areaId");
rolePros.add("areaName");
rolePros.add("areaCode");

Set<String> titleFilter = new HashSet<String>();
titleFilter.add("status");
titleFilter.add("ottVisible");
titleFilter.add("dvbVisible");
titleFilter.add("roleRelationList");

objectMapper = new ObjectMapper();
FilterProvider filterProvider = new SimpleFilterProvider().
addFilter("RoleFilter",SimpleBeanPropertyFilter.serializeAllExcept(rolePros)).
addFilter("TitleFilter", SimpleBeanPropertyFilter.serializeAllExcept(titleFilter));
objectMapper.setFilters(filterProvider);

写完这个后,还需要在需过滤的Bean上加@JsonFilter(filterName),

2.添加混入注解(暂时这么翻译)

定义一个接口或类先, 在该类上添加@JsonIgnoreProperties("name"), 然后在ObjectMapper的配置项上添加混入注解

输出为:

String mixInUser = Jacksons.me().addMixInAnnotations(User.class, MixInUser.class).readAsString(user);

System.out.println(mixInUser);

引自:http://yxb1990.iteye.com/blog/1489712

Jackson 过滤属性的更多相关文章

  1. (转)DataRow的各种状态和DataView的两种过滤属性

    DataRow的各种状态 http://www.cnblogs.com/zxjyuan/archive/2008/08/20/1271987.html 一个DataRow对象刚被创建之后(DataTa ...

  2. Jackson 动态过滤属性,编程式过滤对象中的属性

    场景:有时候我们做系统的时候,比如两个请求,返回同一个对象,但是需要的返回字段并不相同. 常见与写前端接口的时候,尤其是手机端,一般需要什么数据就返回什么样的数据.此时对于返回同一个对象我们就要动态过 ...

  3. java spring使用Jackson过滤

    一.问题的提出. 项目使用Spring MVC框架,并用jackson库处理JSON和POJO的转换.在POJO转化成JSON时,希望动态的过滤掉对象的某些属性.所谓动态,是指的运行时,不同的cont ...

  4. C#在数据层过滤属性中的主键

    C#使用泛型+反射做为数据层时,一个很都头疼的问题,如何让C#属性在程序里识别出哪个属性是主键,在拼接SQL时,不能把主键拼接到SQL语句里. 这个需要自定义一个属性.新建一个类文件,命名为Prosp ...

  5. shiro过滤器过滤属性含义

    securityManager:这个属性是必须的. loginUrl :没有登录的用户请求需要登录的页面时自动跳转到登录页面,不是必须的属性,不输入地址的话会自动寻找项目web项目的根目录下的”/lo ...

  6. Maven过滤属性文件,替换属性值

    pom.xml 1.resources: resources中是定义哪些目录下的文件会被配置文件中定义的变量替换,一般我们会把项目的配置文件放在src/main/resources下,像db,bean ...

  7. Asp .Net MVC中常用过滤属性类

    /// <summary> /// /// </summary> public class AjaxOnlyAttribute : ActionFilterAttribute ...

  8. C# openfiledialog设置filter属性后达不到过滤效果的原因之一

    此处用RichTextBox控件举例>>> 在窗体对应的类中处理Load事件可以为openfiledialog设置Filter的属性: private void Form1_Load ...

  9. fastjson过滤不需要的属性

    以下是一个通用的对象转json的方法,使用的fastjson的SimplePropertyPreFilter 对象,个人感觉比使用PropertyPreFilter的匿名内部类形式的过滤器更好用!直接 ...

随机推荐

  1. CockroachDB——类似spanner的开源版,底层使用rocksdb存储,mvcc,支持事务,raft一致性,licence是CockroachDB Community License Agreement

    摘自:https://github.com/cockroachdb/cockroach/blob/master/docs/design.md CockroachDB is a distributed ...

  2. go的语言结构

    一.文件名.关键字与标识符 1.1 文件名 1.go 的源文件已 .go 为后缀名 2.文件名已小写组成 如:simple.go 3.如多个部分组成可用"_" 分割 4.不要包含有 ...

  3. go之变量、指针、引用地址

    一.值类型 定义和说明 定义:变量直接指向存在内存中的值,我们称之为值类型. 值类型的变量的值存储在栈中. 值类型 将一个变量赋值给另一个变量 被称为值拷贝 实例 package main impor ...

  4. mysql行列转置

    --创建行转列表及插入数据 create table tb_RowConvertToColumn ( username nvarchar(100) null, course nvarchar(100) ...

  5. iOS 点击事件传递及响应

    1.iOS中的事件 iOS中的事件可以分为3大类型: 触摸事件 加速计事件 远程控制事件这里我们只讨论iOS中的触摸事件. 1.1响应者对象(UIResponder) 在iOS中不是任何对象都能处理事 ...

  6. C - Gravity Flip

    Problem description Little Chris is bored during his physics lessons (too easy), so he has built a t ...

  7. 5.13Junit单元测试-反射-注解

    一.Junit单元测试 * 测试分类: 1.黑盒测试:不需要写代码,给输入值,看程序是否能够输出期望的值 2.白盒测试:需要些代码的.关注程序具体的执行流程 Junit使用:白盒测试 步骤: 1.定义 ...

  8. Laravel5.1学习笔记8 Blade模板

    简介 模板继承 定义一个页面布局模板 扩展一个页面布局模板 展示数据 控制语法的结构 Service Injection 扩展 Blade   简介 Blade 是 Laravel 提供的一个既简单又 ...

  9. 大白话理解cookie

    HTTP协议是一个无状态的协议,服务器无法区分出两次请求是否发送自同一服务器. 需要通过会话控制来解决这个问题,会话控制主要有两种方式Cookie 和 Session. Cookie就是一个头,Coo ...

  10. android黑科技系列——分析某直播App的协议加密原理以及调用加密方法进行协议参数构造

    一.前言 随着直播技术火爆之后,各家都出了直播app,早期直播app的各种请求协议的参数信息都没有做任何加密措施,但是慢慢的有人开始利用这个后门开始弄刷粉关注工具,可以让一个新生的小花旦分分钟变成网红 ...