Json是一种轻量级的数据交换格式。客户端与服务器间数据交互采用Json字符串,必然涉及Json字符串的生成与解析。本文主要介绍Java对象和Json字符串的映射。
需要建立Java Maven工程,依赖相关Json Jar包
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-core-lgpl</artifactId>
<version>1.8.1</version>
</dependency>
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-mapper-lgpl</artifactId>
<version>1.8.1</version>
</dependency>
Json字符串与Java对象映射 工具类
public class JsonUtil {
private static final Logger LOGGER = LoggerFactory.getLogger(JsonUtil.class);
//提供解码、编码方法
private final static ObjectMapper OBJECT_MAPPER = new ObjectMapper();
static {
//允许Json字符串包含注释,如:{id:6677654,name:小佳}//客户信息
OBJECT_MAPPER.configure(JsonParser.Feature.ALLOW_COMMENTS, true);
//允许使用非双引号属性名字,如:{id:6677654,name:小佳}
OBJECT_MAPPER.configure(JsonParser.Feature.ALLOW_UNQUOTED_FIELD_NAMES, true);
//允许使用单引号属性名字,如:{'id':'6677654','name':'小佳'}
OBJECT_MAPPER.configure(JsonParser.Feature.ALLOW_SINGLE_QUOTES, true);
//允许JSON字符串包含非引号控制字符(值小于32的ASCII字符,包含制表符和换行符)
OBJECT_MAPPER.configure(JsonParser.Feature.ALLOW_UNQUOTED_CONTROL_CHARS, true);
/**
* 该特性决定JSON对象属性名称是否可以被String#intern 规范化表示。
*
* 如果允许,则JSON所有的属性名将会 intern() ;如果不设置,则不会规范化,
*
* 默认下,该属性是开放的。此外,必须设置CANONICALIZE_FIELD_NAMES为true
*
* 关于intern方法作用:当调用 intern 方法时,如果池已经包含一个等于此 String 对象的字符串,则返回池中的字串;
* 否则,将此 String对象添加到池中, 并且返回此 String 对象的引用。
* @since 1.3
*/
OBJECT_MAPPER.configure(JsonParser.Feature.INTERN_FIELD_NAMES, true);
/**
* 该特性决定JSON对象的属性名称是否被规范化。
*
* @since 1.5
*/ OBJECT_MAPPER.configure(JsonParser.Feature.CANONICALIZE_FIELD_NAMES, true);
//当Json字符串属性与Java对象属性不匹配时,不报错
OBJECT_MAPPER.configure(DeserializationConfig.Feature.FAIL_ON_UNKNOWN_PROPERTIES, false);
}
//注意!这是一个私有构造器!
private JsonUtil() {
}
public static String encode(Object obj) {
try {
return OBJECT_MAPPER.writeValueAsString(obj);
} catch (Exception e) {
LOGGER.error("encode(Object),e:", e);
}
return null;
}
/**
* 将json string反序列化成对象
*
* @param json
* @param valueType
* @return
*/
public static <T> T decode(String json, Class<T> valueType) {
if (json == null){
return null;
}
try {
return OBJECT_MAPPER.readValue(json, valueType);
} catch (Exception e) {
LOGGER.error("decode(String, Class<T>),json:{},e:",json, e);
}
return null;
}
}