别再死记硬背了!用Fastjson 1.2.62处理JSON,这3个真实业务场景你肯定遇到过
Fastjson实战3个高频业务场景深度解析每次看到同事在手动拼接JSON字符串或者用反射处理复杂嵌套结构时我都忍不住想分享Fastjson这个利器。作为阿里巴巴开源的JSON处理库Fastjson在性能上一直保持着领先优势特别是在1.2.62版本中其稳定性和功能完整性都有了显著提升。但很多开发者仅仅停留在基础API调用层面没有真正发挥它的威力。1. 复杂表单数据处理Vue与Java的完美对接上周排查一个生产问题时发现前端提交的嵌套表单数据在后端变成了乱码。这让我意识到很多团队在前后端数据交互上还存在不少误区。现代前端框架如Vue配合Axios提交数据时经常会遇到这样的结构{ order: { items: [ { sku: A001, quantity: 2, specs: {color: red, size: XL} } ], user: { deliveryAddress: { city: 杭州, details: 余杭区... } } } }传统做法可能是逐层解析但用Fastjson可以一步到位// 定义DTO结构 public class OrderDTO { private ListOrderItem items; private UserInfo user; // getters/setters } public class OrderItem { private String sku; private Integer quantity; private MapString, String specs; // getters/setters } // 直接转换 String jsonStr request.getParameter(formData); OrderDTO order JSON.parseObject(jsonStr, OrderDTO.class);几个实用技巧对于不确定的字段可以用JSONObject接收再通过getJSONObject()方法逐层获取日期格式化问题可以在全局配置JSON.DEFFAULT_DATE_FORMAT yyyy-MM-dd HH:mm:ss;遇到特殊字符时使用Feature.OrderedField保持字段顺序注意1.2.62版本对泛型支持有优化处理ListItem这类结构时更稳定2. Redis缓存交互对象序列化的正确姿势我们项目曾因为序列化问题导致缓存命中率骤降后来通过统一Fastjson方案解决了问题。相比Java原生序列化JSON格式有三大优势可读性强便于调试跨语言兼容存储空间更小典型的使用模式// 存储对象 User user getUserFromDB(); String jsonUser JSON.toJSONString(user); redisTemplate.opsForValue().set(user:userId, jsonUser); // 读取对象 String cachedJson redisTemplate.opsForValue().get(user:userId); User cachedUser JSON.parseObject(cachedJson, User.class);性能优化点开启SerializerFeature.WriteClassName可以在反序列化时保留类型信息对于大对象使用JSON.toJSONBytes()比转字符串更节省内存1.2.62版本新增的Feature.SupportAutoType可以自动识别类型对比测试数据10000次操作序列化方式耗时(ms)内存占用(KB)Java原生4501200Fastjson210680Jackson2807103. Spring Boot统一响应体设计在RESTful API设计中统一的响应格式至关重要。我们团队经过多次迭代总结出这样的结构public class ApiResponseT { private Integer code; private String message; private T data; private Long timestamp; // 成功响应快捷方法 public static T ApiResponseT success(T data) { return new ApiResponseT() .setCode(200) .setMessage(success) .setData(data) .setTimestamp(System.currentTimeMillis()); } // getters/setters }Fastjson在此场景下的妙用RestControllerAdvice public class ResponseWrapper implements ResponseBodyAdviceObject { Override public Object beforeBodyWrite(Object body, MethodParameter param, MediaType type, Class? extends HttpMessageConverter? converter, ServerHttpRequest request, ServerHttpResponse response) { if (body instanceof ApiResponse) { return body; } // 处理String类型特殊处理 if (body instanceof String) { return JSON.toJSONString(ApiResponse.success(body)); } return ApiResponse.success(body); } }遇到的坑与解决方案日期格式全局配置不生效试试在WebMvcConfigurer中添加Override public void configureMessageConverters(ListHttpMessageConverter? converters) { FastJsonHttpMessageConverter converter new FastJsonHttpMessageConverter(); FastJsonConfig config new FastJsonConfig(); config.setDateFormat(yyyy-MM-dd HH:mm:ss); converter.setFastJsonConfig(config); converters.add(0, converter); }循环引用问题使用JSONField(serialize false)忽略特定字段1.2.62版本对Spring Boot 2.3的兼容性更好4. 高级特性与版本升级指南在深度使用Fastjson的过程中我发现这些特性特别实用自定义序列化public class MoneySerializer implements ObjectSerializer { Override public void write(JSONSerializer serializer, Object object, Object fieldName, Type fieldType, int features) throws IOException { BigDecimal value (BigDecimal) object; String text value.setScale(2, RoundingMode.HALF_UP) 元; serializer.write(text); } } // 注册自定义序列化器 SerializeConfig.getGlobalInstance().put(BigDecimal.class, new MoneySerializer());安全防护措施// 开启安全模式防止注入攻击 ParserConfig.getGlobalInstance().setSafeMode(true); // 设置白名单 ParserConfig.getGlobalInstance().addAccept(com.yourpackage.);版本迁移注意事项1.2.62修复了多个安全漏洞建议所有低于此版本的立即升级新版本对JSONField注解的支持更完善可以配置JSONField(name user_name, ordinal 1, format yyyy-MM-dd) private String username;序列化过滤器功能增强SimplePropertyPreFilter filter new SimplePropertyPreFilter(); filter.getExcludes().add(password); String json JSON.toJSONString(user, filter);在微服务架构下我们还用Fastjson实现了这样的协议转换中间件public class ProtocolConverter { public static T T convert(Object source, ClassT targetClass) { String json JSON.toJSONString(source); return JSON.parseObject(json, targetClass); } // 支持泛型转换 public static T ListT convertList(List? source, ClassT elementClass) { String json JSON.toJSONString(source); return JSON.parseArray(json, elementClass); } }实际项目中我们团队建立了这样的规范所有DTO类必须实现Serializable敏感字段必须加JSONField(serialize false)跨服务调用使用JSON.toJSONBytes()提高传输效率日志输出对象时使用JSON.toJSONString(obj, SerializerFeature.PrettyFormat)
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2541276.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!