這篇文章主要講解了“java中Fastjson處理枚舉的方法”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“java中Fastjson處理枚舉的方法”吧!
創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都做網(wǎng)站、成都網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的扎蘭屯網(wǎng)站設(shè)計(jì)、移動媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
這玩意兒不多說,Alibaba出品,出過幾次嚴(yán)重的安全漏洞,但是依然很流行。這里寫一下它怎么處理枚舉。
com.alibaba fastjson 1.2.76
默認(rèn)就是,啥也不用動
import com.alibaba.fastjson.JSON; enum Gender { BOY, GIRL, UNKNOW } class User { private Integer id; private Gender gender; public User() { } public User(Integer id, Gender gender) { super(); this.id = id; this.gender = gender; } public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public Gender getGender() { return gender; } public void setGender(Gender gender) { this.gender = gender; } } public class MainTest { public static void main(String[] args) throws Exception { // 序列化為JSON輸出 User user = new User(1, Gender.BOY); String jsonString = JSON.toJSONString(user); System.out.println(jsonString); // {"gender":"BOY","id":1} // 反序列化為對象 user = JSON.parseObject(jsonString, User.class); System.out.println(user.getGender()); // BOY } }
代碼跟上面沒有變化,就需要在開頭添加一句代碼,任何枚舉,都會被序列化為ordinal()值
JSON.DEFAULT_GENERATE_FEATURE &= ~SerializerFeature.WriteEnumUsingName.mask;
// 全局設(shè)置,枚舉的序列化使用 ordinal() JSON.DEFAULT_GENERATE_FEATURE &= ~SerializerFeature.WriteEnumUsingName.mask; // 序列化為JSON輸出,枚舉值為 ordinal() User user = new User(1, Gender.BOY); String jsonString = JSON.toJSONString(user); System.out.println(jsonString); // {"gender":0,"id":1} // 反序列化為對象 user = JSON.parseObject(jsonString, User.class); System.out.println(user.getGender()); // BOY
只想針對某一次序列化生效。只需要調(diào)用JSON.toJSONString
的重載方法,添加配置就行。
public static String toJSONString(Object object, int defaultFeatures, SerializerFeature... features)
// 序列化為JSON輸出,本次把枚舉值序列化為 ordinal() User user = new User(1, Gender.BOY); String jsonString = JSON.toJSONString(user, JSON.DEFAULT_GENERATE_FEATURE & ~SerializerFeature.WriteEnumUsingName.mask); System.out.println(jsonString); // {"gender":0,"id":1} // 反序列化為對象 user = JSON.parseObject(jsonString, User.class); System.out.println(user.getGender()); // BOY
很多人也喜歡給枚舉定義一個私有的屬性,序列化為JSON時,希望以這個屬性值作為value,這個時候就需要自己定義JSON的序列化和反序列化實(shí)現(xiàn)了。Fastjson提供了2個接口。用戶控制序列化和反序列化行為,這個實(shí)在是太簡單,這里不多說??创a
ObjectSerializer
ObjectDeserializer
import java.io.IOException; import java.lang.reflect.Type; import com.alibaba.fastjson.serializer.JSONSerializer; import com.alibaba.fastjson.serializer.ObjectSerializer; public class GenderEnumSerializer implements ObjectSerializer { @Override public void write(JSONSerializer serializer, Object object, Object fieldName, Type fieldType, int features) throws IOException { // 強(qiáng)制把值轉(zhuǎn)換為Gender Gender gender = (Gender) object; // 序列化為自定義的name屬性,輸出就行 serializer.out.writeString(gender.getName()); } }
import java.lang.reflect.Type; import com.alibaba.fastjson.parser.DefaultJSONParser; import com.alibaba.fastjson.parser.JSONToken; import com.alibaba.fastjson.parser.deserializer.ObjectDeserializer; public class GenderEnumDeserializer implements ObjectDeserializer { @SuppressWarnings("unchecked") @Override publicT deserialze(DefaultJSONParser parser, Type type, Object fieldName) { // 解析值為字符串 String value = parser.parseObject(String.class); // 遍歷所有的枚舉實(shí)例 for (Gender gender : Gender.values()) { if (gender.getName().equals(value)) { // 成功匹配,返回實(shí)例 return (T) gender; } } // 沒有匹配到,可以拋出異?;蛘叻祷豱ull return null; } @Override public int getFastMatchToken() { // 僅僅匹配字符串類型的值 return JSONToken.LITERAL_STRING; } }
enum Gender { BOY("男"), GIRL("女"), UNKNOW("不知道"); public final String name; Gender(String name) { this.name = name; } public String getName() { return name; } } class User { private Integer id; // 標(biāo)識注解,指定枚舉的序列化。反序列化實(shí)現(xiàn)類 @JSONField(serializeUsing = GenderEnumSerializer.class, deserializeUsing = GenderEnumDeserializer.class) private Gender gender; public User() { } public User(Integer id, Gender gender) { super(); this.id = id; this.gender = gender; } public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public Gender getGender() { return gender; } public void setGender(Gender gender) { this.gender = gender; } }
public class MainTest { public static void main(String[] args) throws Exception { // 序列化為JSON輸出,枚舉值為 getName() User user = new User(1, Gender.UNKNOW); String jsonString = JSON.toJSONString(user); System.out.println(jsonString); // {"gender":"不知道","id":1} // 反序列化為對象 user = JSON.parseObject(jsonString, User.class); System.out.println(user.getGender()); // UNKNOW } }
很顯然,自定義 ObjectSerializer /ObjectDeserializer 的方式最為靈活,可以考慮抽象一個接口出來,讓所有的枚舉都實(shí)現(xiàn)接口。這樣針對接口編寫ObjectSerializer /ObjectDeserializer實(shí)現(xiàn),就可以很好的復(fù)用了。
感謝各位的閱讀,以上就是“java中Fastjson處理枚舉的方法”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對java中Fastjson處理枚舉的方法這一問題有了更深刻的體會,具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!