mirror of
https://gitee.com/dromara/hutool.git
synced 2025-04-05 17:37:59 +08:00
修复JSONUtil.parse()溢出问题
This commit is contained in:
parent
afbe2ce99c
commit
5c4486b9f5
@ -2,7 +2,7 @@
|
|||||||
# 🚀Changelog
|
# 🚀Changelog
|
||||||
|
|
||||||
-------------------------------------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------------------------------------
|
||||||
# 5.8.22(2023-09-01)
|
# 5.8.22(2023-09-05)
|
||||||
|
|
||||||
### 🐣新特性
|
### 🐣新特性
|
||||||
* 【core 】 NumberUtil.nullToZero增加重载(issue#I7PPD2@Gitee)
|
* 【core 】 NumberUtil.nullToZero增加重载(issue#I7PPD2@Gitee)
|
||||||
@ -30,6 +30,7 @@
|
|||||||
* 【core 】 修复fillColumns空指针问题(issue#3284@Github)
|
* 【core 】 修复fillColumns空指针问题(issue#3284@Github)
|
||||||
* 【core 】 修复Convert不能转换Optional和Opt问题(issue#I7WJHH@Gitee)
|
* 【core 】 修复Convert不能转换Optional和Opt问题(issue#I7WJHH@Gitee)
|
||||||
* 【core 】 修复DateUtil.age年龄计算问题(issue#I7XMYW@Gitee)
|
* 【core 】 修复DateUtil.age年龄计算问题(issue#I7XMYW@Gitee)
|
||||||
|
* 【core 】 修复JSONUtil.parse()溢出问题(issue#3289@Github)
|
||||||
|
|
||||||
-------------------------------------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------------------------------------
|
||||||
# 5.8.21(2023-07-29)
|
# 5.8.21(2023-07-29)
|
||||||
|
@ -5,6 +5,7 @@ import cn.hutool.core.comparator.PropertyComparator;
|
|||||||
import cn.hutool.core.exceptions.UtilException;
|
import cn.hutool.core.exceptions.UtilException;
|
||||||
import cn.hutool.core.lang.Assert;
|
import cn.hutool.core.lang.Assert;
|
||||||
import cn.hutool.core.lang.Matcher;
|
import cn.hutool.core.lang.Matcher;
|
||||||
|
import cn.hutool.core.lang.Validator;
|
||||||
import cn.hutool.core.util.ArrayUtil;
|
import cn.hutool.core.util.ArrayUtil;
|
||||||
import cn.hutool.core.util.ObjectUtil;
|
import cn.hutool.core.util.ObjectUtil;
|
||||||
import cn.hutool.core.util.PageUtil;
|
import cn.hutool.core.util.PageUtil;
|
||||||
@ -432,10 +433,8 @@ public class ListUtil {
|
|||||||
if (index < size) {
|
if (index < size) {
|
||||||
list.set(index, element);
|
list.set(index, element);
|
||||||
} else {
|
} else {
|
||||||
// issue#3286, 增加安全检查,最多增加2倍
|
// issue#3286, 增加安全检查,最多增加10倍
|
||||||
if(index > (list.size() + 1) * 2) {
|
Validator.checkIndexLimit(index, list.size());
|
||||||
throw new UtilException("Index is too large:", index);
|
|
||||||
}
|
|
||||||
for (int i = size; i < index; i++) {
|
for (int i = size; i < index; i++) {
|
||||||
list.add(paddingElement);
|
list.add(paddingElement);
|
||||||
}
|
}
|
||||||
|
@ -1257,4 +1257,23 @@ public class Validator {
|
|||||||
}
|
}
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 检查给定的index是否超出长度限制,默认检查超出倍数(10倍),此方法主要用于内部,检查包括:
|
||||||
|
* <ul>
|
||||||
|
* <li>数组调用setOrPadding时,最多允许padding的长度</li>
|
||||||
|
* <li>List调用setOrPadding时,最多允许padding的长度</li>
|
||||||
|
* <li>JSONArray调用setOrPadding时,最多允许padding的长度</li>
|
||||||
|
* </ul>
|
||||||
|
*
|
||||||
|
* @param index 索引
|
||||||
|
* @param size 数组、列表长度
|
||||||
|
* @since 5.8.22
|
||||||
|
*/
|
||||||
|
public static void checkIndexLimit(final int index, final int size) {
|
||||||
|
// issue#3286, 增加安全检查,最多增加10倍
|
||||||
|
if (index > (size + 1) * 10) {
|
||||||
|
throw new ValidateException("Index [{}] is too large for size: [{}]", index, size);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@ package cn.hutool.json;
|
|||||||
import cn.hutool.core.bean.BeanPath;
|
import cn.hutool.core.bean.BeanPath;
|
||||||
import cn.hutool.core.collection.CollUtil;
|
import cn.hutool.core.collection.CollUtil;
|
||||||
import cn.hutool.core.lang.Filter;
|
import cn.hutool.core.lang.Filter;
|
||||||
|
import cn.hutool.core.lang.Validator;
|
||||||
import cn.hutool.core.lang.mutable.Mutable;
|
import cn.hutool.core.lang.mutable.Mutable;
|
||||||
import cn.hutool.core.lang.mutable.MutableObj;
|
import cn.hutool.core.lang.mutable.MutableObj;
|
||||||
import cn.hutool.core.lang.mutable.MutablePair;
|
import cn.hutool.core.lang.mutable.MutablePair;
|
||||||
@ -457,10 +458,8 @@ public class JSONArray implements JSON, JSONGetter<Integer>, List<Object>, Rando
|
|||||||
InternalJSONUtil.testValidity(element);
|
InternalJSONUtil.testValidity(element);
|
||||||
this.rawList.add(index, JSONUtil.wrap(element, this.config));
|
this.rawList.add(index, JSONUtil.wrap(element, this.config));
|
||||||
} else {
|
} else {
|
||||||
// issue#3286, 增加安全检查,最多增加2倍
|
// issue#3286, 增加安全检查,最多增加10倍
|
||||||
if(index > (this.size() + 1) * 2) {
|
Validator.checkIndexLimit(index, this.size());
|
||||||
throw new JSONException("Index is too large:", index);
|
|
||||||
}
|
|
||||||
while (index != this.size()) {
|
while (index != this.size()) {
|
||||||
this.add(JSONNull.NULL);
|
this.add(JSONNull.NULL);
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package cn.hutool.json;
|
package cn.hutool.json;
|
||||||
|
|
||||||
|
import cn.hutool.core.lang.Console;
|
||||||
import cn.hutool.core.lang.Filter;
|
import cn.hutool.core.lang.Filter;
|
||||||
import cn.hutool.core.lang.mutable.Mutable;
|
import cn.hutool.core.lang.mutable.Mutable;
|
||||||
import cn.hutool.core.lang.mutable.MutablePair;
|
import cn.hutool.core.lang.mutable.MutablePair;
|
||||||
@ -66,7 +67,7 @@ public class JSONParser {
|
|||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
tokener.back();
|
tokener.back();
|
||||||
key = tokener.nextValue().toString();
|
key = tokener.nextStringValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
// The key is followed by ':'.
|
// The key is followed by ':'.
|
||||||
|
@ -322,6 +322,43 @@ public class JSONTokener {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取下一个String格式的值,用户获取key
|
||||||
|
* @return String格式的值
|
||||||
|
* @since 5.8.22
|
||||||
|
*/
|
||||||
|
public String nextStringValue(){
|
||||||
|
char c = this.nextClean();
|
||||||
|
|
||||||
|
switch (c) {
|
||||||
|
case '"':
|
||||||
|
case '\'':
|
||||||
|
return this.nextString(c);
|
||||||
|
case '{':
|
||||||
|
case '[':
|
||||||
|
throw this.syntaxError("Sting value must be not begin with a '{' or '['");
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Handle unquoted text. This could be the values true, false, or null, or it can be a number.
|
||||||
|
* An implementation (such as this one) is allowed to also accept non-standard forms. Accumulate
|
||||||
|
* characters until we reach the end of the text or a formatting character.
|
||||||
|
*/
|
||||||
|
|
||||||
|
final StringBuilder sb = new StringBuilder();
|
||||||
|
while (c >= ' ' && ",:]}/\\\"[{;=#".indexOf(c) < 0) {
|
||||||
|
sb.append(c);
|
||||||
|
c = this.next();
|
||||||
|
}
|
||||||
|
this.back();
|
||||||
|
|
||||||
|
final String string = sb.toString().trim();
|
||||||
|
if (string.isEmpty()) {
|
||||||
|
throw this.syntaxError("Missing value");
|
||||||
|
}
|
||||||
|
return string;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获得下一个值,值类型可以是Boolean, Double, Integer, JSONArray, JSONObject, Long, or String, or the JSONObject.NULL
|
* 获得下一个值,值类型可以是Boolean, Double, Integer, JSONArray, JSONObject, Long, or String, or the JSONObject.NULL
|
||||||
*
|
*
|
||||||
@ -366,7 +403,7 @@ public class JSONTokener {
|
|||||||
this.back();
|
this.back();
|
||||||
|
|
||||||
string = sb.toString().trim();
|
string = sb.toString().trim();
|
||||||
if (0 == string.length()) {
|
if (string.isEmpty()) {
|
||||||
throw this.syntaxError("Missing value");
|
throw this.syntaxError("Missing value");
|
||||||
}
|
}
|
||||||
return InternalJSONUtil.stringToValue(string);
|
return InternalJSONUtil.stringToValue(string);
|
||||||
|
23
hutool-json/src/test/java/cn/hutool/json/Issue3289Test.java
Executable file
23
hutool-json/src/test/java/cn/hutool/json/Issue3289Test.java
Executable file
@ -0,0 +1,23 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2023 looly(loolly@aliyun.com)
|
||||||
|
* Hutool is licensed under Mulan PSL v2.
|
||||||
|
* You can use this software according to the terms and conditions of the Mulan PSL v2.
|
||||||
|
* You may obtain a copy of Mulan PSL v2 at:
|
||||||
|
* http://license.coscl.org.cn/MulanPSL2
|
||||||
|
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
|
||||||
|
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
|
||||||
|
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
|
||||||
|
* See the Mulan PSL v2 for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package cn.hutool.json;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
public class Issue3289Test {
|
||||||
|
@Test(expected = JSONException.class)
|
||||||
|
public void parseTest() {
|
||||||
|
final String s = "{\"a\":1,[6E962756779]}";
|
||||||
|
JSONUtil.parse(s);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user