在做用户批量删除时,后台通过:
String[] userChecks = request.getParameterValues("userCheck");
来获取jsp页面表单提交的所有选中id,getParameterValues返回的是字符串数组,而dao层是通过Integer类型的id去删除对应的数据,所以需要转换数据类型:
for (String userCheck : userChecks) {
userService.delete(Integer.parseInt(userCheck));
}
但是运行后会报错:
java.lang.NumberFormatException: For input string: " 1212"
java.base/java.lang.NumberFormatException.forInputString(NumberFormatException.java:68)
java.base/java.lang.Integer.parseInt(Integer.java:644)
java.base/java.lang.Integer.parseInt(Integer.java:776)
com.luckySheep.edu.web.controller.UserController.delAllUser(UserController.java:199)
java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
java.base/java.lang.reflect.Method.invoke(Method.java:567)
........
仔细查看报错信息第一行:
可以发现遍历字符串数组,每个字符串前面都有一个空格,这就是导致字符串类型通过==Integer.parseInt(userCheck)==转换失败。
解决:
在遍历得到字符串后,去除字符串前后可能存在的空格,然后在转换Integer类型!方法:
for (String userCheck : userChecks) {
String trim = userCheck.trim();//去除字符串前后的空格
userService.delete(Integer.parseInt(trim));
}