fix NPE bug

This commit is contained in:
Looly 2022-04-02 00:42:27 +08:00
parent aaa88dad81
commit 8196941b6e
3 changed files with 16 additions and 16 deletions

View File

@ -25,6 +25,7 @@
* 【core 】 修复urlWithParamIfGet函数逻辑问题issue#I50IUD@Gitee
* 【core 】 修复IoUtil.readBytes限制长度读取问题issue#2230@Github
* 【http 】 修复HttpRequest中编码对URL无效的问题issue#I50NHQ@Gitee
* 【poi 】 修复读取excel抛NPE错误pr#2234@Github
-------------------------------------------------------------------------------------------------------------

View File

@ -23,7 +23,7 @@ import java.util.Map;
/**
* 数据结果集处理辅助类
*
*
* @author loolly
*
*/
@ -60,7 +60,7 @@ public class HandleHelper {
@SuppressWarnings("unchecked")
public static <T> T handleRow(int columnCount, ResultSetMetaData meta, ResultSet rs, Class<T> beanClass) throws SQLException {
Assert.notNull(beanClass, "Bean Class must be not null !");
if(beanClass.isArray()) {
//返回数组
final Class<?> componentType = beanClass.getComponentType();
@ -81,7 +81,7 @@ public class HandleHelper {
final Object[] objRow = handleRow(columnCount, meta, rs, Object[].class);
return (T) StrUtil.join(", ", objRow);
}
//普通bean
final T bean = ReflectUtil.newInstanceIfPossible(beanClass);
//忽略字段大小写
@ -108,7 +108,7 @@ public class HandleHelper {
/**
* 处理单条数据
*
*
* @param columnCount 列数
* @param meta ResultSetMetaData
* @param rs 数据集
@ -118,10 +118,10 @@ public class HandleHelper {
public static Entity handleRow(int columnCount, ResultSetMetaData meta, ResultSet rs) throws SQLException {
return handleRow(columnCount, meta, rs, false);
}
/**
* 处理单条数据
*
*
* @param columnCount 列数
* @param meta ResultSetMetaData
* @param rs 数据集
@ -136,7 +136,7 @@ public class HandleHelper {
/**
* 处理单条数据
*
*
* @param <T> Entity及其子对象
* @param row Entity对象
* @param columnCount 列数
@ -199,7 +199,7 @@ public class HandleHelper {
/**
* 处理多条数据
*
*
* @param <T> 集合类型
* @param rs 数据集
* @param collection 数据集
@ -209,10 +209,10 @@ public class HandleHelper {
public static <T extends Collection<Entity>> T handleRs(ResultSet rs, T collection) throws SQLException {
return handleRs(rs, collection, false);
}
/**
* 处理多条数据
*
*
* @param <T> 集合类型
* @param rs 数据集
* @param collection 数据集
@ -234,7 +234,7 @@ public class HandleHelper {
/**
* 处理多条数据并返回一个Bean列表
*
*
* @param <E> 集合元素类型
* @param <T> 集合类型
* @param rs 数据集
@ -259,8 +259,7 @@ public class HandleHelper {
/**
* 获取字段值<br>
* 针对日期时间等做单独处理判断
*
* @param <T> 返回类型
*
* @param rs {@link ResultSet}
* @param columnIndex 字段索引
* @param type 字段类型默认Object
@ -268,7 +267,7 @@ public class HandleHelper {
* @return 字段值
* @throws SQLException SQL异常
*/
private static <T> Object getColumnValue(ResultSet rs, int columnIndex, int type, Type targetColumnType) throws SQLException {
private static Object getColumnValue(ResultSet rs, int columnIndex, int type, Type targetColumnType) throws SQLException {
Object rawValue = null;
switch (type) {
case Types.TIMESTAMP:

View File

@ -245,9 +245,9 @@ public class ExcelReadTest {
Assert.assertEquals("", objects.get(2));
}
@Test(expected = NullPointerException.class)
@Ignore
@Test
public void readColumnNPETest() {
// https://github.com/dromara/hutool/pull/2234
ExcelReader reader = ExcelUtil.getReader(ResourceUtil.getStream("read_row_npe.xlsx"));
reader.readColumn(0, 1);
}