91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java中Fastjson處理枚舉的方法

發布時間:2021-06-25 11:21:52 來源:億速云 閱讀:835 作者:chen 欄目:編程語言

這篇文章主要講解了“java中Fastjson處理枚舉的方法”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“java中Fastjson處理枚舉的方法”吧!

Fastjson

這玩意兒不多說,Alibaba出品,出過幾次嚴重的安全漏洞,但是依然很流行。這里寫一下它怎么處理枚舉。

<!-- https://mvnrepository.com/artifact/com.alibaba/fastjson -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.76</version>
</dependency>

序列化為name()值

默認就是,啥也不用動

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()值

全局設置

代碼跟上面沒有變化,就需要在開頭添加一句代碼,任何枚舉,都會被序列化為ordinal()值

JSON.DEFAULT_GENERATE_FEATURE &= ~SerializerFeature.WriteEnumUsingName.mask;
		// 全局設置,枚舉的序列化使用 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

特殊設置

只想針對某一次序列化生效。只需要調用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的序列化和反序列化實現了。Fastjson提供了2個接口。用戶控制序列化和反序列化行為,這個實在是太簡單,這里不多說。看代碼

  • 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 {
		// 強制把值轉換為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
	public <T> T deserialze(DefaultJSONParser parser, Type type, Object fieldName) {
		// 解析值為字符串
		String value = parser.parseObject(String.class);
		// 遍歷所有的枚舉實例
		for (Gender gender : Gender.values()) {
			if (gender.getName().equals(value)) {
				// 成功匹配,返回實例
				return (T) gender;
			}
		}
		// 沒有匹配到,可以拋出異常或者返回null
		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;
	
	// 標識注解,指定枚舉的序列化。反序列化實現類
	@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 的方式最為靈活,可以考慮抽象一個接口出來,讓所有的枚舉都實現接口。這樣針對接口編寫ObjectSerializer /ObjectDeserializer實現,就可以很好的復用了。

感謝各位的閱讀,以上就是“java中Fastjson處理枚舉的方法”的內容了,經過本文的學習后,相信大家對java中Fastjson處理枚舉的方法這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

新巴尔虎右旗| 巧家县| 海淀区| 广宗县| 互助| 历史| 金阳县| 太仆寺旗| 吉木乃县| 樟树市| 北京市| 诏安县| 六枝特区| 德江县| 喀喇| 密山市| 洪泽县| 南召县| 偏关县| 邓州市| 洪雅县| 阳朔县| 都匀市| 广安市| 广德县| 仙桃市| 卢氏县| 北流市| 安平县| 嘉义市| 鹤壁市| 万全县| 阳江市| 安国市| 都昌县| 城固县| 胶南市| 雷山县| 乌拉特前旗| 张家川| 信阳市|