Java实践之路——Gson
在java中采用ajax技术难免会遇到将java对象序列化的问题,而json作为一种轻量级且易懂易操作的数据格式得到广泛的应用。所以,这里我们讲一下将Java对象序列化为Json数据的方法,这里主要讲一下google开发的开源工具Gson。
Gson继承了谷歌的优良传统,简单易用。Gson这个Java类库可以把Java对象转换成JSON,也可以把JSON字符串转换成一个相等的Java对象。Gson支持任意复杂Java对象包括没有源代码的对象。
这里我们主要讲一下Gson在序列化时一些需要注意的操作,一般的应用网上都有大量的资料,最好的方法还是查看API
我们这里先写个转化为Json数据的通用工具类ConvertToJson.java
package meetyou.util;
import java.lang.reflect.Type;
import java.util.List;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
public class ConvertToJson {
public static String toJsonWithGson(Object obj)
{
Gson gson=new Gson();
return gson.toJson(obj);
}
public static String toJsonWithGson(Object obj,Type type)
{
Gson gson=new Gson();
return gson.toJson(obj,type);
}
@SuppressWarnings("unchecked")
public static String toJsonWithGson(List list)
{
Gson gson=new Gson();
return gson.toJson(list);
}
@SuppressWarnings("unchecked")
public static String toJsonWithGson(List list,Type type)
{
Gson gson=new Gson();
return gson.toJson(list,type);
}
public static String toJsonWithGsonBuilder(Object obj)
{
Gson gson=new GsonBuilder().setExclusionStrategies(new MyExclusionStrategy()).serializeNulls().create();
return gson.toJson(obj);
}
public static String toJsonWithGsonBuilder(Object obj,Type type)
{
Gson gson=new GsonBuilder().setExclusionStrategies(new MyExclusionStrategy()).serializeNulls().create();
return gson.toJson(obj,type);
}
@SuppressWarnings("unchecked")
public static String toJsonWithGsonBuilder(List list)
{
Gson gson=new GsonBuilder().setExclusionStrategies(new MyExclusionStrategy()).serializeNulls().create();
return gson.toJson(list);
}
@SuppressWarnings("unchecked")
public static String toJsonWithGsonBuilder(List list,Type type)
{
Gson gson=new GsonBuilder().setExclusionStrategies(new MyExclusionStrategy()).serializeNulls().create();
return gson.toJson(list,type);
}
}
从代码我们开始讲
1、Gson如何使用。
Gson对象主要有两个方法toJson()序列化,fromJson()反序列化
2、如何获取Gson对象
两种方式,1、new Gson().2、new GsonBuilder().create();
3、两种方式获取gson对象的区别
利用GsonBuilder创建gson对象时,可以增加一些特殊处理,应该说是比第一种方式功能更强大
4、参数中的type如何创建
(1)、普通对象,如User user=new User();得到type方式,user.class
(2)、复杂点的对象,如List<User> users=new ArrayList<User>();得到type方式,new com.google.gson.reflect.TypeToken<List<User>>(){}.getType()
5、GsonBuilder有哪些优势
(1)、可以采用注解的方式,个性化定制需要序列化和方序列化的字段,如在字段前面添加@Expose注解,当采用GsonBuilder.excludeFieldsWithoutExposeAnnotation()方法时,没有该注解的字段将被排除在外。其他注解还有@SerializeName、@Since和@Until,具体意思参见Gson API文档
(2)、定制自己的注解和排除策略。如上述代码中的类 MyExclusionStrategy,代码如下
package meetyou.util;
import com.google.gson.ExclusionStrategy;
import com.google.gson.FieldAttributes;
public class MyExclusionStrategy implements ExclusionStrategy {
private final Class<?> typeToSkip;
public MyExclusionStrategy(){
this.typeToSkip=null;
}
public MyExclusionStrategy(Class<?> typeToSkip) {
this.typeToSkip = typeToSkip;
}
public boolean shouldSkipClass(Class<?> clazz) {
return (clazz == typeToSkip);
}
public boolean shouldSkipField(FieldAttributes f) {
return f.getAnnotation(NotSerialize.class) != null;
}
}
实现ExclusionStrategy接口
自己的注解接口NotSerialize,代码如下
package meetyou.util;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD})
public @interface NotSerialize {
}
这时,我们用的时候,只要在不序列化的字段前面加上@NotSerialize注解(比如说密码字段,保证其安全性就没必要序列化出来了),采用new GsonBuilder().setExclusionStrategies()方法设置排除策略创建的Gson对象时,该字段将不再被序列化
至于Gson的反序列化,这里就不讲了。参考Gson API文档吧
AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。
更多推荐


所有评论(0)