今天整合一个ssh框架,发现报出这个错误,整了几个钟,都没发现有任何错误。因为报错大概意思是说没有为web层的action类声明一个result返回类型,但是我在struts.xml里明显写了
<action name="studentAction_*" class="studentAction" method="{1}" >
<result name="list">/jsp/student/list.jsp</result>
</action>
有的啊,有木有,后面索性把<result name="error">/error.jsp</result>也给写上,结果发现能进入error界面,这就奇怪了,报错说我没声明一个result返回值,但是我有,回去查看action类我也写了return "list";,我还睁大眼睛前后看了不下20次。。。
public String list() throws Exception {
//封装离线查询对象
DetachedCriteria dc = DetachedCriteria.forClass(Student.class);
//判断接受值不为空并封装参数
if(StringUtils.isNotBlank(student.getStud_name())){
dc.add(Restrictions.like("stud_name", "%"+student.getStud_name()+"%"));
}
//调用Service对象ss查询分页数据
Page pg = ss.getPage(dc,currentPage,pageSize);
//将Page压入request域,并转发至列表届面显示
ActionContext.getContext().put("Page", pg);
return "list";
}
完全没错的,action和struts.xml配置都没有错,然后查看applicationContext.xml文件内也创建了xxAction类,如果没创建肯定报错的啊。
<bean name="studentAction" class="com.mylea.web.action.StudentAction" scope="prototype" >
<property name="ss" ref="studentService" ></property>
</bean>
struts也的确把action的创建交给了spring
<constant name="struts.objectFactory" value="spring"></constant>
等等,我测试error的时候,是可行的,没有报错,说明我的bean创建肯定没问题,然后返回了error说明struts配置也肯定没问题的,上面这些查看代码有没有写错其实都是白费功夫,根本没有问题。
所以问题肯定是发生处理逻辑内部。然后层层寻找,可以线在action层syso一个变量,例如pg,如果没有打印出来,拿肯定在中间发生了异常。其实用debug好使,后悔没早用,最后发现我的Page对象(用来分页显示的),在计算页数总页数this.totalpage = (this.totalcount+this.pagesize-1)/this.pagesize;中,pagesize竟然为“0“,也不知道为什么控制台没有报错。正常来说这是RuntimeException应该会自动终止程序报错才对啊。
血的教训,一定要养成良好的编程习惯,在可能出错的地方一定要抛异常,其次是我引发上述算术异常是因为int类型和integer类型混用,没有统一,导致前面的if(pagesiez==null)这个地方没有进去,因为int类型初始值为0,integer类型初始值为null,0当然不等于null,所以导致后面出现了除数为0的错误!
以上为个人遇到的情况,可能不符合其他人报出这个错误的原因,不过检查方法应该通用:
1.按照上面方法检查一下配置,确定无误,那么问题发生在运行中
2.可使用debug模式测试,检查出变量异常的地方,然后修改即可