最近写ssh项目时开始没注意,后来发现每次提交表单后控制台都会打印这个错误信息:
23:53:18.619 ERROR com.opensymphony.xwork2.interceptor.ParametersInterceptor 231 notifyDeveloperParameterException - Developer Notification (set struts.devMode to false to disable this message):
Unexpected Exception caught setting 'x' on 'class cn.cdut.oa.view.action.RoleAction: Error setting expression 'x' with value ['16', ]
23:53:18.621 ERROR com.opensymphony.xwork2.interceptor.ParametersInterceptor 231 notifyDeveloperParameterException - Developer Notification (set struts.devMode to false to disable this message):
Unexpected Exception caught setting 'y' on 'class cn.cdut.oa.view.action.RoleAction: Error setting expression 'y' with value ['2', ]
但是它并不影响程序的运行,但是看着心里不爽,不知道哪里出现了问题!
后来经过一番的搜索,很多网上说的是Action不能设置表单中相应参数值给Action类中的属性,可能是出现了Action中没有相应属性的getter和setter方法、或是表单中的name属性的值和Action的属性名不一致。
例:当你的form中比如有个输入框<input type="text" name="loginName"/>,当提交到Action时不能正确的将此loginName参数的值赋给Action中的loginName属性。此时就有可能是以上错误。
但我在我的表单页面中找发现我并没有传name为 'x' 或 'y' 的参数,所以我的错误并不在此。后来终于找到一位大神发生同样的问题。
原因是当表单中含有这样的input输入框(提交按钮):
<input type="image" src="${pageContext.request.contextPath}/style/images/save.png"/>
或者这样的:
<input type="image" name="save" src="${pageContext.request.contextPath}/style/images/save.png"/>
这种type为image的输入框会传鼠标点击图片的x坐标和y坐标的参数给请求地址(第二个有name属性的传递的参数则是save.x和save.y),我的Action中没有接受该参数的属性,所以报错。我用这种类型的输入框是为了方便显示提交按钮图片。
解决办法:(我觉得其实这个错误对程序的影响不大)
第一种方法是换掉这种类型的提交按钮;
第二种方法是把struts2的开发模式关闭,因为只有在开发模式下才会提示你这个错误。
<constant name="struts.devMode" value="false"/>