FastJson 学习之 SerializerFeature

FastJson 版本:1.2.75
eg:{ “name”: “zhangsan”, “age”: 18 }

一、序列化特性

引号

特性默认值作用示例
QuoteFieldNamestrue使用双引号
UseSingleQuotesfalse使用单引号{ ‘name’: ‘zhangsan’, ‘age’: 18 }

null

特性默认值作用示例
WriteMapNullValuefalse值为 null 字段也返回
WriteNullStringAsEmptyfalsenull -> “”
WriteNullNumberAsZerofalsenull -> 0
WriteNullBooleanAsFalsefalsenull -> false
WriteNullListAsEmptyfalsenull -> []

值特殊处理

特性默认值作用示例
NotWriteDefaultValuefalse不使用默认属性值
WriteNonStringKeyAsStringfalse将 JSON 中 非 String 类型 key 值 转为 String
WriteNonStringValueAsStringfalse将 JSON 中 非 String 类型 value 值 转为 String 类型
WriteBigDecimalAsPlainfalse禁用科学计数,显示原内容
BeanToArrayfalse返回对象属性值 array[“zhangsan”, 22]
PrettyFormatfalse美化 JSONpostman 响应 -> body -> Row 看效果

序列化时忽略

特性默认值作用示例
SkipTransientFieldtrue序列化时忽略 transient 字段private transient String userId;
IgnoreNonFieldGettertrue忽略没有 Getter 方法的属性
IgnoreErrorGetterfalse忽略 Getter 方法报错,正常执行下边的序列化

时间

特性默认值作用示例
UseISO8601DateFormatfalseDate 使用 ISO8601 格式输出
WriteDateUseDateFormat使用指定的 DateFormat 格式化 Date

排序

特性默认值作用示例
SortFieldfalse按字段名称排序后输出{“aa”: “zhangsan”, “ab”: “lisi” }
MapSortFieldfalse使用 Map key 值排序后输出

枚举

特性默认值作用示例
WriteEnumUsingToString用枚举 toString() 值输出
WriteEnumUsingName用枚举 name() 输出

类信息

特性默认值作用示例
WriteClassNamefalse序列化时写入类型信息{"@type": “com.zxguan.mvc.po.Stu”, “age”: 22, “name”: “zhangsan” }
NotWriteRootClassName
DisableCircularReferenceDetect禁止同一对象循环引用序列化

安全、转义

特性默认值作用示例
BrowserCompatible将中文序列化为 \uXXXX 格式
BrowserSecureXSS 攻击处理,安全转义
WriteSlashAsSpecial斜杠 / 进行转义
@Deprecated WriteTabAsSpecial\t 做转义

二、enum SerializerFeature

package com.alibaba.fastjson.serializer;

/**
 * @author wenshao[szujobs@hotmail.com]
 */
public enum SerializerFeature {

    /**
     * 输出 key 时是否使用双引号,默认为 true
     * */
    QuoteFieldNames,

    /**
     * 使用单引号而不是双引号,默认为 false
     * <p>
     *     {
     *          'name': 'zhangsan',
     *          'age': 18
     *     }
     * </p>
     * */
    UseSingleQuotes,

    /**
     * 是否输出值为 null 的字段,默认为 false
     * */
    WriteMapNullValue,

    /**
     * 用枚举 toString() 值输出
     * */
    WriteEnumUsingToString,

    /**
     * 用枚举 name() 输出
     * */
    WriteEnumUsingName,

    /**
     * Date 使用 ISO8601 格式输出,默认为 false
     * */
    UseISO8601DateFormat,

    /**
     * List     null -> []
     * @since 1.1
     * */
    WriteNullListAsEmpty,

    /**
     * String   null -> ""
     * @since 1.1
     * */
    WriteNullStringAsEmpty,

    /**
     * Number   null -> 0
     * @since 1.1
     * */
    WriteNullNumberAsZero,

    /**
     * Boolean  null -> false
     * @since 1.1
     * */
    WriteNullBooleanAsFalse,

    /**
     * 序列化时忽略 transient 字段,默认为 true
     * <p>
     *      private transient String userId;
     * </p>
     * @since 1.1
     * */
    SkipTransientField,

    /**
     * 按字段名称排序后输出。默认为 false
     * <p>
     *     {
     *         "aa": "zhangsan",
     *         "ab": "lisi"
     *     }
     * </p>
     * @since 1.1
     * */
    SortField,

    /**
     * 把 '\t' 做转义输出,默认为 false
     * @since 1.1
     * @Deprecated
     * */
    WriteTabAsSpecial,

    /**
     * 美化 JSON,默认为 false
     * <p>
     * postman 响应 -> body -> Row
     * {
     *     "age": 22,
     *     "name": "zhangsan"
     * }
     * </p>
     * @since 1.1.2
     * */
    PrettyFormat,

    /**
     * 序列化时写入类型信息,默认为 false。反序列化是需用到
     * <p>
     * {
     *     "@type": "com.zxguan.mvc.po.Stu",
     *     "age": 22,
     *     "name": "zhangsan"
     * }
     * </p>
     * @since 1.1.2
     * */
    WriteClassName,

    /**
     * 消除对同一对象循环引用的问题,默认为 false
     * @since 1.1.6
     * */
    DisableCircularReferenceDetect, // 32768

    /**
     * 对斜杠 ’/’ 进行转义
     * @since 1.1.9
     * */
    WriteSlashAsSpecial,

    /**
     * 将中文都会序列化为 \uXXXX 格式,字节数会多一些,但是能兼容 IE6,默认为 false
     * <p>
     * {
     *     "age": 22,
     *     "name":"\u5566\u5566\u5566"
     * }
     * </p>
     * @since 1.1.10
     * */
    BrowserCompatible,

    /**
     * 使用指定的 DateFormat 格式化 Date ,默认为 false
     * <p>
     *     long 类型时间戳按着给定的格式格式化
     * </p>
     * @since 1.1.14
     * */
    WriteDateUseDateFormat,

    /**
     * @since 1.1.15
     * */
    NotWriteRootClassName,

    /**
     * 一个对象的字符串属性中如果有特殊字符如双引号,将会在转成 json 时带有反斜杠转移符。如果不需要转义,可以使用这个属性。默认为 false
     * @since 1.1.19
     * @deprecated
     * */
    DisableCheckSpecialChar,

    /**
     * 将对象属性值转为 array 输出
     * @since 1.1.35
     * */
    BeanToArray,

    /**
     * 将 JSON key 类型转为 String
     * @since 1.1.37
     * */
    WriteNonStringKeyAsString,
    
    /**
     * 不写默认属性值
     * @since 1.1.42
     * */
    NotWriteDefaultValue,
    
    /**
     * XSS攻击处理 安全转义
     * @since 1.2.6
     * */
    BrowserSecure,
    
    /**
     * 忽略没有 Getter 方法的属性
     * @since 1.2.7
     * */
    IgnoreNonFieldGetter,
    
    /**
     * 将 非 String 类型属性值转为 String 类型
     * @since 1.2.9
     * */
    WriteNonStringValueAsString,
    
    /**
     * 正常来说,服务端序列化时,get方法抛异常,导致序列化失败
     * 此属性用于忽略那些抛错的 getter 方法,正常执行下边的序列化
     * @since 1.2.11
     * */
    IgnoreErrorGetter,

    /**
     * 禁用科学计数,显示原内容
     * @since 1.2.16
     * */
    WriteBigDecimalAsPlain,

    /**
     * 使用 Map key 值排序后输出
     * @since 1.2.27
     * */
    MapSortField;

    SerializerFeature(){
    	// 掩码 = ordinal() 左移一位
        mask = (1 << ordinal());
    }

    public final int mask;

    public final int getMask() {
        return mask;
    }

    public static boolean isEnabled(int features, SerializerFeature feature) {
        return (features & feature.mask) != 0;
    }
    
    public static boolean isEnabled(int features, int featuresB, SerializerFeature feature) {
        int mask = feature.mask;
        
        return (features & mask) != 0 || (featuresB & mask) != 0;
    }

    public static int config(int features, SerializerFeature feature, boolean state) {
        if (state) {
            features |= feature.mask;
        } else {
            features &= ~feature.mask;
        }

        return features;
    }
    
    public static int of(SerializerFeature[] features) {
        if (features == null) {
            return 0;
        }
        
        int value = 0;
        
        for (SerializerFeature feature: features) {
            value |= feature.mask;
        }
        
        return value;
    }
    
    public final static SerializerFeature[] EMPTY = new SerializerFeature[0];

    public static final int WRITE_MAP_NULL_FEATURES
            = WriteMapNullValue.getMask()
            | WriteNullBooleanAsFalse.getMask()
            | WriteNullListAsEmpty.getMask()
            | WriteNullNumberAsZero.getMask()
            | WriteNullStringAsEmpty.getMask()
            ;
}
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值