struts2,hibernate java.lang.NumberFormatException: For input string 错误

本文详细描述了在Java项目中遇到的NumberFormatException错误的原因及解决办法,主要涉及action方法中使用通用service执行SQL查询并返回object类型的问题,以及jsp页面中如何正确处理和展示查询结果,避免错误发生。

java.lang.NumberFormatException: For input string

最近做项目,出现一个错误,如下:
java.lang.NumberFormatException: For input string: "article"
at java.lang.NumberFormatException.forInputString(NumberFormatException.java:48)
at java.lang.Integer.parseInt(Integer.java:449)
at java.lang.Integer.parseInt(Integer.java:499)
at javax.el.ArrayELResolver.coerce(ArrayELResolver.java:161)
at javax.el.ArrayELResolver.getValue(ArrayELResolver.java:45)
at javax.el.CompositeELResolver.getValue(CompositeELResolver.java:54)
at org.apache.el.parser.AstValue.getValue(AstValue.java:123)
at org.apache.el.ValueExpressionImpl.getValue(ValueExpressionImpl.java:186)
at org.apache.jasper.runtime.PageContextImpl.proprietaryEvaluate(PageContextImpl.java:935)
at org.apache.jsp.personShow_jsp._jspx_meth_s_005fiterator_005f0(personShow_jsp.java:226)
at org.apache.jsp.personShow_jsp._jspService(personShow_jsp.java:178)
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:377)
at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:313)
at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:260)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:646)
at org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:436)
at org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:374)
at org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:302)
at org.apache.struts2.dispatcher.ServletDispatcherResult.doExecute(ServletDispatcherResult.java:139)
at org.apache.struts2.dispatcher.StrutsResultSupport.execute(StrutsResultSupport.java:178)
at com.opensymphony.xwork2.DefaultActionInvocation.executeResult(DefaultActionInvocation.java:348)
at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:253)
at com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor.doIntercept(DefaultWorkflowInterceptor.java:221)
at com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:224)
at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:223)
at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455)
at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:221)
at com.opensymphony.xwork2.validator.ValidationInterceptor.doIntercept(ValidationInterceptor.java:150)
at org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor.doIntercept(AnnotationValidationInterceptor.java:48)
at com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:224)
at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:223)
at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455)
at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:221)
at com.opensymphony.xwork2.interceptor.ConversionErrorInterceptor.intercept(ConversionErrorInterceptor.java:123)
at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:224)
at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:223)
at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455)
at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:221)
......
花费了我好长时间,不过最后还是发现了问题所在,分享一下,希望能帮到大家。
action中方法代码:(注:generalService为通用service)
public String personShow() throws Exception{
person = (Person) generalService.findByProperty(Person.class, "id", personId).get(0);
String allCountSql = "SELECT count(id) FROM Doc where personId ='"+personId+"'";
String hql = "select * FROM doc where person_id = '"+personId+"' ORDER BY 'insertTime' DESC";
int allCount = ((Long)(generalService.find(allCountSql)).get(0)).intValue();
//  docList = generalService.find(hql,page.start*10,10);
 docList = generalService.executeSQL(hql);   //错误所在
page.setAllCount(allCount);
page.setStart(page.getStart());
return "personShow";
}
jsp中代码:
 <s:iterator value="docList" id="m" status="index">
                <table width="100%" >
<tr>
  <td colspan="4" align="left">${m.article}</td>
</tr>
<tr>
  <td width="25%" align="center">${m.insertTime}</td>
  <td width="25%" align="center">&nbsp;<a href="">${m.origin }</a></td>
  <td width="25%" align="center">&nbsp; ${m.transmit}</td>
  <td width="25%" align="center">&nbsp;${m.discuss}</td>
  </tr>
</table>
        </s:iterator>
此问题的主要是因为   generalService.executeSQL(hql)返回的list集合中的元素为object类型,没有转化为doc类对象,导致显示时找不到对应的article等。

`java.lang.NumberFormatException: For input string: "日"` 错误表示在尝试将字符串 `"日"` 转换为数值类型时失败了,因为 `"日"` 不是一个有效的数值表示[^1]。在 `CalendarAdapter` 类中,出现这个错误的位置很可能是在 `onBindViewHolder` 方法里的 `Integer.parseInt(day)` 这行代码。 为了解决这个问题,需要在调用 `Integer.parseInt` 之前,先判断字符串是否是有效的数字。可以使用正则表达式来检查字符串是否只包含数字。 以下是修改后的 `CalendarAdapter` 类代码: ```java import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.TextView; import androidx.annotation.NonNull; import androidx.recyclerview.widget.RecyclerView; import java.util.Calendar; import java.util.List; import java.util.regex.Pattern; public class CalendarAdapter extends RecyclerView.Adapter<CalendarAdapter.ViewHolder> { private List<String> days; private int currentDay; private static final Pattern NUMBER_PATTERN = Pattern.compile("^\\d+$"); public CalendarAdapter(List<String> days) { this.days = days; Calendar calendar = Calendar.getInstance(); this.currentDay = calendar.get(Calendar.DAY_OF_MONTH); } @NonNull @Override public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()).inflate(android.R.layout.simple_list_item_1, parent, false); return new ViewHolder(view); } @Override public void onBindViewHolder(@NonNull ViewHolder holder, int position) { String day = days.get(position); holder.textView.setText(day); if (NUMBER_PATTERN.matcher(day).matches() && Integer.parseInt(day) == currentDay) { // 设置当天日期的样式,例如改变背景颜色 holder.textView.setBackgroundColor(holder.itemView.getContext().getResources().getColor(android.R.color.holo_blue_light)); } else { // 恢复默认样式 holder.textView.setBackgroundColor(holder.itemView.getContext().getResources().getColor(android.R.color.transparent)); } } @Override public int getItemCount() { return days.size(); } public static class ViewHolder extends RecyclerView.ViewHolder { public TextView textView; public ViewHolder(View itemView) { super(itemView); textView = itemView.findViewById(android.R.id.text1); } } } ``` ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值