long类型精度丢失问题
package com.csw.shuanfa.GlobalConfig.format;
import com.fasterxml.jackson.databind.SerializationFeature;
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
import com.fasterxml.jackson.datatype.jsr310.ser.LocalDateTimeSerializer;
import org.springframework.boot.autoconfigure.jackson.Jackson2ObjectMapperBuilderCustomizer;
import org.springframework.boot.jackson.JsonComponent;
import org.springframework.context.annotation.Bean;
import org.springframework.stereotype.Component;
import java.math.BigDecimal;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.TimeZone;
/**
* 【此方法仅仅用于返回格式化,如果是入参的话还要手动加注解特别是LocalDateTime】
* 全局日期格式化 如果某个字段不使用该格式
* 依旧可以使用 @JsonFormat(locale = "zh", timezone = "GMT+8", pattern = "yyyy-MM-dd") 修改某个字段的格式化信息,且@JsonFormat优先级高于@JsonComponent配置的格式类型
*
* LocalDateTime注意-单个时间接收
* public Result<LocalDateTime> aa(@RequestParam(required = false) @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") LocalDateTime date) {
* LocalDateTime注意-嵌套对象接收(两个注解是不一样的)
* @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
* private LocalDateTime date;
*
* 如果需要打印日志,拿到的参数里面含有T有两种解决方法(obj可以手单个LocalDateTime,也可以是单个实体包含LocalDateTime的对象)
* 方法一
* String string = JSON.toJSONStringWithDateFormat(obj, "yyyy-MM-dd HH:mm:ss", SerializerFeature.WriteDateUseDateFormat).toString();
* 方法二
* SerializeConfig serializeConfig = new SerializeConfig();
* serializeConfig.put(LocalDateTime.class, new LocalDateTimeSerializer());
* String json = JSON.toJSONString(date, serializeConfig);
*
*
* private static class LocalDateTimeSerializer implements ObjectSerializer {
* private final DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
*
* @Override
* public void write(JSONSerializer serializer, Object object, Object fieldName, Type fieldType, int features) {
* LocalDateTime dateTime = (LocalDateTime) object;
* String formattedDateTime = dateTime.format(formatter);
* serializer.write(formattedDateTime);
* }
* }
*
*/
@JsonComponent
@Component
public class DateFormatConfig {
private String pattern = "yyyy-MM-dd HH:mm:ss";
/**
* 类型全局时间格式化
*/
@Bean
public Jackson2ObjectMapperBuilderCustomizer jackson2ObjectMapperBuilder() {
return builder -> {
// long -> String
builder.serializerByType(Long.TYPE, ToStringSerializer.instance);
// Long -> String
builder.serializerByType(Long.class, ToStringSerializer.instance);
// Long -> String
builder.serializerByType(BigDecimal.class, ToStringSerializer.instance);
//序列化
builder.serializerByType(LocalDateTime.class, new LocalDateTimeSerializer(DateTimeFormatter.ofPattern(pattern)));
};
}
}
//将Long.TYPE(也就是基本类型long)序列化为字符串。这意味着当你使用这个ObjectMapper实例将包含long类型字段的对象序列化为JSON时,这些字段的值会被转换成字符串形式。
//将Long.class(也就是包装类型Long)序列化为字符串。这与上一步类似,但是针对的是Long对象,而不是基本类型long。
日期全局返回格式化,【需要特殊格式用下面指定】或者让前端截取
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone = "GMT+8:00")
spring:
jackson:
date-format: yyyy-MM-dd HH:mm:ss
time-zone: GMT+8
serialization:
fail-on-empty-beans: false
deserialization:
READ_UNKNOWN_ENUM_VALUES_AS_NULL: true
//date-format: 这个属性设置了日期和时间的序列化和反序列化的格式。在这里,它被设置为 yyyy-MM-dd HH:mm:ss,意味着日期和时间将被格式化为“年-月-日 时:分:秒”的形式。例如,日期时间 2024-10-14 12:00:00 将按照这种格式进行序列化和反序列化。
//time-zone: 这个属性设置了Jackson处理日期和时间时使用的时区。在这里,它被设置为 GMT+8,即中国标准时间。这意味着所有日期时间的序列化和反序列化都将使用这个时区。
//serialization.fail-on-empty-beans: 这个属性控制当序列化一个空的Java Bean(没有属性的类实例)时的行为。在这里,它被设置为 false,意味着即使一个Bean没有任何属性,Jackson也不会抛出异常,而是会序列化一个空的对象。
//deserialization.READ_UNKNOWN_ENUM_VALUES_AS_NULL: 这个属性影响枚举类型的反序列化行为。在这里,它被设置为 true,意味着如果反序列化过程中遇到未知的枚举值,Jackson将把它解析为 null 而不是抛出异常。
富文本图片返回去除
String patternString = "<img[^>]*>";
resVo.forEach(a -> {
a.setContent(a.getContent().replaceAll(patternString, ""));
});
前端/java/mapper去除换行符、回车符、制表符
js-> str.replace(/[\n\r\t\s]/g, '');
java->replaceAll("\\s+", "")
mapper->REPLACE(REPLACE(REPLACE(REPLACE(column_name, '\n', ''), '\r', ''), '\t', ''), ' ', '')