All Downloads are FREE. Search and download functionalities are using the official Maven repository.

cn.hutool.json.JSONConfig Maven / Gradle / Ivy

The newest version!
package cn.hutool.json;

import cn.hutool.core.comparator.CompareUtil;

import java.io.Serializable;
import java.util.Comparator;

/**
 * JSON配置项
 *
 * @author looly
 * @since 4.1.19
 */
public class JSONConfig implements Serializable {
	private static final long serialVersionUID = 119730355204738278L;

	/**
	 * 键排序规则,{@code null}表示不排序,不排序情况下,按照加入顺序排序
	 */
	private Comparator keyComparator;
	/**
	 * 是否忽略转换过程中的异常
	 */
	private boolean ignoreError;
	/**
	 * 是否忽略键的大小写
	 */
	private boolean ignoreCase;
	/**
	 * 日期格式,null表示默认的时间戳
	 */
	private String dateFormat;
	/**
	 * 是否忽略null值
	 */
	private boolean ignoreNullValue = true;
	/**
	 * 是否支持transient关键字修饰和@Transient注解,如果支持,被修饰的字段或方法对应的字段将被忽略。
	 */
	private boolean transientSupport = true;

	/**
	 * 是否去除末尾多余0,例如如果为true,5.0返回5
	 */
	private boolean stripTrailingZeros = true;

	/**
	 * 是否检查重复key
	 */
	private boolean checkDuplicate;

	/**
	 * 是否将Long值写出为字符串类型
	 * @since 5.8.28
	 */
	private boolean writeLongAsString;

	/**
	 * 创建默认的配置项
	 *
	 * @return JSONConfig
	 */
	public static JSONConfig create() {
		return new JSONConfig();
	}

	/**
	 * 是否有序,顺序按照加入顺序排序,只针对JSONObject有效
	 *
	 * @return 是否有序
	 * @deprecated 始终返回 {@code true}
	 */
	@Deprecated
	public boolean isOrder() {
		return true;
	}

	/**
	 * 设置是否有序,顺序按照加入顺序排序,只针对JSONObject有效
	 *
	 * @param order 是否有序
	 * @return this
	 * @deprecated 始终有序,无需设置
	 */
	@SuppressWarnings("unused")
	@Deprecated
	public JSONConfig setOrder(boolean order) {
		return this;
	}

	/**
	 * 获取键排序规则
* 键排序规则,{@code null}表示不排序,不排序情况下,按照加入顺序排序 * * @return 键排序规则 * @since 5.7.21 */ public Comparator getKeyComparator() { return this.keyComparator; } /** * 设置自然排序,即按照字母顺序排序 * * @return this * @since 5.7.21 */ public JSONConfig setNatureKeyComparator() { return setKeyComparator(CompareUtil.naturalComparator()); } /** * 设置键排序规则
* 键排序规则,{@code null}表示不排序,不排序情况下,按照加入顺序排序 * * @param keyComparator 键排序规则 * @return this * @since 5.7.21 */ public JSONConfig setKeyComparator(Comparator keyComparator) { this.keyComparator = keyComparator; return this; } /** * 是否忽略转换过程中的异常 * * @return 是否忽略转换过程中的异常 */ public boolean isIgnoreError() { return ignoreError; } /** * 设置是否忽略转换过程中的异常 * * @param ignoreError 是否忽略转换过程中的异常 * @return this */ public JSONConfig setIgnoreError(boolean ignoreError) { this.ignoreError = ignoreError; return this; } /** * 是否忽略键的大小写 * * @return 是否忽略键的大小写 */ public boolean isIgnoreCase() { return ignoreCase; } /** * 设置是否忽略键的大小写 * * @param ignoreCase 是否忽略键的大小写 * @return this */ public JSONConfig setIgnoreCase(boolean ignoreCase) { this.ignoreCase = ignoreCase; return this; } /** * 日期格式,null表示默认的时间戳 * * @return 日期格式,null表示默认的时间戳 */ public String getDateFormat() { return dateFormat; } /** * 设置日期格式,null表示默认的时间戳
* 此方法设置的日期格式仅对转换为JSON字符串有效,对解析JSON为bean无效。 * * @param dateFormat 日期格式,null表示默认的时间戳 * @return this */ public JSONConfig setDateFormat(String dateFormat) { this.dateFormat = dateFormat; return this; } /** * 是否忽略null值 * * @return 是否忽略null值 */ public boolean isIgnoreNullValue() { return this.ignoreNullValue; } /** * 设置是否忽略null值 * * @param ignoreNullValue 是否忽略null值 * @return this */ public JSONConfig setIgnoreNullValue(boolean ignoreNullValue) { this.ignoreNullValue = ignoreNullValue; return this; } /** * 是否支持transient关键字修饰和@Transient注解,如果支持,被修饰的字段或方法对应的字段将被忽略。 * * @return 是否支持 * @since 5.4.2 */ public boolean isTransientSupport() { return this.transientSupport; } /** * 设置是否支持transient关键字修饰和@Transient注解,如果支持,被修饰的字段或方法对应的字段将被忽略。 * * @param transientSupport 是否支持 * @return this * @since 5.4.2 */ public JSONConfig setTransientSupport(boolean transientSupport) { this.transientSupport = transientSupport; return this; } /** * 是否去除末尾多余0,例如如果为true,5.0返回5 * * @return 是否去除末尾多余0,例如如果为true,5.0返回5 * @since 5.6.2 */ public boolean isStripTrailingZeros() { return stripTrailingZeros; } /** * 设置是否去除末尾多余0,例如如果为true,5.0返回5 * * @param stripTrailingZeros 是否去除末尾多余0,例如如果为true,5.0返回5 * @return this * @since 5.6.2 */ public JSONConfig setStripTrailingZeros(boolean stripTrailingZeros) { this.stripTrailingZeros = stripTrailingZeros; return this; } /** * 是否检查多个相同的key * * @return 是否检查多个相同的key * @since 5.8.5 */ public boolean isCheckDuplicate() { return checkDuplicate; } /** * 是否检查多个相同的key * * @param checkDuplicate 是否检查多个相同的key * @return this * @since 5.8.5 */ public JSONConfig setCheckDuplicate(boolean checkDuplicate) { this.checkDuplicate = checkDuplicate; return this; } /** * 是否将Long值写出为字符串类型 * @return 是否将Long值写出为字符串类型 * @since 5.8.28 */ public boolean isWriteLongAsString() { return writeLongAsString; } /** * 设置是否将Long值写出为字符串类型 * @param writeLongAsString 是否将Long值写出为字符串类型 * @return this */ public JSONConfig setWriteLongAsString(boolean writeLongAsString) { this.writeLongAsString = writeLongAsString; return this; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy