公司有个项目,用了ssh框架,但是struts2的action,包括其他dao,service类等,用了xml的方式显式配置,文件多,而且繁琐,开发东西不停的拷贝复制,很麻烦。
于是修改整个框架,用Convention的方式,实现0配置,并且结合Spring的自动扫描,让dao,service类等都注解方式注入。
spring部分的修改略过不谈,比较简单。问题是struts2部分,我们知道,用了Convention后,它会自动扫描所有包名里,含有action名字的package下面的类,自动作为action类来处理,url地址等都会自动匹配好。但是这次碰到了奇怪的问题,在eclipse环境下,tomcat里发布测试,都ok,结果maven发布到我们的测试环境里后,却一直报错,错误信息:There is no Action mapped for namespace 。这个错误很明显,是说找不到这个action。但是class类都在,本地反复尝试都可以。
无奈baidu去找,结果原因五花八门,按照方法去改,就是无法解决问题,郁闷了,无意中想起来,我们的action类,是在jar包里的,难道struts2不会去扫描jar包里的class吗?继续baidu,果然很多人碰到这个问题,解决方法也简单,在struts.xml里,加上<constant name="struts.convention.action.includeJars" value=".*/app-*.*?jar(!/)?" />,它就会扫描app开头名称的jar了,重新发布后,正常运行。
此错误信息提示比较常见,很难一下子定位到问题,花费一下午才解决,主要也因为以前的项目里,action类都是放在各自的webapp工程里,不会碰到这个问题。
有类似问题的朋友,可以参考下解决问题。