gson配置

1.配置gson替代默认序列化工具

@Configuration
@EnableWebMvc
public class HttpMessageConverterConfig implements WebMvcConfigurer {

    @Autowired
    private GsonHttpMessageConverter gsonHttpMessageConverter;

    /**
     * 注册gson消息转换器
     */
    @Override
    public void configureMessageConverters(
            List<HttpMessageConverter<?>> converters) {
        converters.add(gsonHttpMessageConverter);
    }

}

2.配置gson的信息转换处理

@Component
public class GsonHttpMessageConverter extends AbstractJsonHttpMessageConverter {
    @Autowired
    private GsonExclusionStrategy gsonExclusionStrategy;
    @Autowired
    private JsonSchemaRepo jsonSchemaRepo;

    /**
     * 用于读取定义的类型的资源,将其转化为JSONObject对象
     */
    @Override
    protected Object readInternal(Type resolvedType, Reader reader)
            throws Exception {
        Optional<JsonSchemaEntity> optional = jsonSchemaRepo
                .findById(resolvedType.getTypeName());
        if (optional.isPresent()) {
            // 将reader转换成字符串
            BufferedReader br = new BufferedReader(reader);
            StringBuilder sb = new StringBuilder();
            String line = null;
            while ((line = br.readLine()) != null) {
                sb.append(line);
            }
            String json = sb.toString();
            // json格式校验
            JsonNode schema = new JsonNodeReader().fromReader(
                    new StringReader(optional.get().getJosnSchema()));
            JsonNode data = new JsonNodeReader()
                    .fromReader(new StringReader(json));
            ProcessingReport report = JsonSchemaFactory.byDefault()
                    .getValidator().validate(schema, data);
            if (report.isSuccess()) {
                // 校验通过
                return gsonDeserialize().fromJson(json, resolvedType);
            } else {
                // 校验没有通过
                Iterator<ProcessingMessage> iterator = report.iterator();
                StringBuilder msgsb = new StringBuilder();
                while (iterator.hasNext()) {
                    msgsb.append(iterator.next().getMessage());
                }
                throw new JsonSchemaException("请求的Json格式不正确:{0}", msgsb);
            }
        } else {
            // 不需要校验
            return gsonDeserialize().fromJson(reader, resolvedType);
        }
    }

    /**
     * 用于在推送此种类型的资源时,将JSONObject对象转化为自定义的格式返回给调用者
     * 这里所有的返回JSONObject对象给前端的请求,都会执行此方法
     * 原调用Spring的默认的mappingJackson2HttpMessageConverter来处理
     */
    @Override
    protected void writeInternal(Object o, Type type, Writer writer)
            throws Exception {
        if (type instanceof ParameterizedType) {
            gsonSerialize().toJson(o, type, writer);
        } else {
            gsonSerialize().toJson(o, writer);
        }

    }

    /**
     * Gson基础配置
     * 
     * @return
     */
    private GsonBuilder gsonBuilder() {
        GsonBuilder b = new GsonBuilder();
        // 注册特殊类型格式数据适配器
        b.registerTypeAdapter(LocalDateTime.class,
                new CustomLocalDateTypeAdapter());
        return b;
    }

    /**
     * 序列化Gson配置
     * 
     * @return
     */
    private Gson gsonSerialize() {
        return gsonBuilder().setExclusionStrategies(gsonExclusionStrategy)
                .create();
    }

    /**
     * 反序列化Gson配置
     * 
     * @return
     */
    private Gson gsonDeserialize() {
        return gsonBuilder().create();
    }

}

3.序列化排除策略

@Component
public class GsonExclusionStrategy implements ExclusionStrategy {

    @Override
    public boolean shouldSkipField(FieldAttributes f) {
        if (f.getAnnotation(Expose.class) != null
                && !f.getAnnotation(Expose.class).serialize()) {
            // 如果被Expose注解,且Expose的serialize为false的情况下,不序列化
            return true;
        } else {
            return false;
        }

    }

    @Override
    public boolean shouldSkipClass(Class<?> clazz) {
        return false;
    }

}

4.自定义特殊格式数据适配器

         4.1 第一种方式,实现JsonDeserializer和JsonSerializer接口

public class LocalDateTypeAdapter implements JsonDeserializer<LocalDateTime>,
        JsonSerializer<LocalDateTime> {
    private static final DateTimeFormatter FORMAT = DateTimeFormatter.ISO_DATE_TIME;

    @Override
    public JsonElement serialize(LocalDateTime src, Type typeOfSrc,
            JsonSerializationContext context) {
        return new JsonPrimitive(src.format(FORMAT));
    }

    @Override
    public LocalDateTime deserialize(JsonElement json, Type typeOfT,
            JsonDeserializationContext context) throws JsonParseException {
        return LocalDateTime.parse(json.getAsString(), FORMAT);
    }

}

         4.2 第二种方式,继承TypeAdapter类

public class CustomLocalDateTypeAdapter extends TypeAdapter<LocalDateTime> {

    private static final DateTimeFormatter FORMAT = DateTimeFormatter.ISO_DATE_TIME;

    @Override
    public void write(JsonWriter out, LocalDateTime value) throws IOException {
        if (value == null) {
            out.nullValue();
        } else {
            out.value(value.format(FORMAT));
        }
    }

    @Override
    public LocalDateTime read(JsonReader in) throws IOException {
        if (in.peek() == null) {
            return null;
        }
        String str = in.nextString();
        LocalDateTime date = LocalDateTime.parse(str, FORMAT);
        return date;
    }

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要在 Maven 项目中使用 Gson 库,需要在 pom.xml 文件中添加以下依赖项: ```xml <dependency> <groupId>com.google.code.gson</groupId> <artifactId>gson</artifactId> <version>2.8.7</version> </dependency> ``` 添加依赖项后,Maven 会自动从 Maven 仓库下载 Gson 库并将其添加到项目的 classpath 中。然后,你可以通过在代码中导入 Gson 类来使用它,例如: ```java import com.google.gson.Gson; public class Example { public static void main(String[] args) { Gson gson = new Gson(); // 使用 Gson 进行 JSON 序列化和反序列化等操作 } } ``` ### 回答2: 要配置 Maven 使用 Gson,首先需要在项目的 pom.xml 文件中引入 Gson 的依赖。在 `<dependencies>` 标签中添加以下代码: ```xml <dependency> <groupId>com.google.code.gson</groupId> <artifactId>gson</artifactId> <version>2.8.8</version> </dependency> ``` 这将下载 Gson 的 jar 文件并添加到项目的类路径中。 完成依赖配置后,你可以在代码中使用 Gson 了。首先,需要导入 Gson 类: ```java import com.google.gson.Gson; ``` 然后,你可以创建 Gson 对象并使用其提供的方法进行序列化和反序列化操作。例如,将一个对象转换为 JSON 字符串: ```java Gson gson = new Gson(); String json = gson.toJson(object); ``` 其中,`object` 是你要转换的对象。你可以将 JSON 字符串转换为对象: ```java String json = "{'name':'John', 'age':30}"; Person person = gson.fromJson(json, Person.class); ``` 其中,`Person` 是你的对象类。 配置完成后,你便可以在项目中使用 Gson 进行 JSON 数据的序列化和反序列化操作了。 ### 回答3: 在Maven项目中配置Gson非常简单。首先,需要在项目的pom.xml文件中添加Gson依赖项。可以使用以下代码将Gson添加到Maven项目中: ```xml <dependencies> <dependency> <groupId>com.google.code.gson</groupId> <artifactId>gson</artifactId> <version>2.8.6</version> </dependency> </dependencies> ``` 在添加依赖项之后,Maven会自动下载并将Gson库添加到项目中。 完成这一步骤后,就可以在项目的Java代码中使用Gson了。首先,需要在代码中导入Gson类。代码示例如下: ```java import com.google.gson.Gson; ``` 然后,可以创建一个Gson对象并使用其提供的方法进行相关操作。例如,可以将一个Java对象序列化为JSON字符串,或将一个JSON字符串反序列化为一个Java对象。以下是一个简单的示例: ```java public class Main { public static void main(String[] args) { // 创建Gson对象 Gson gson = new Gson(); // 将Java对象序列化为JSON字符串 Person person = new Person("John", "Doe", 30); String json = gson.toJson(person); System.out.println(json); // 将JSON字符串反序列化为Java对象 String json2 = "{\"firstName\":\"Jane\",\"lastName\":\"Smith\",\"age\":25}"; Person person2 = gson.fromJson(json2, Person.class); System.out.println(person2.getFirstName()); System.out.println(person2.getLastName()); System.out.println(person2.getAge()); } } ``` 这样,我们就成功地在Maven项目中配置Gson并使用它进行了相关操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值