一个关于多项目的文档管理系统做完了,是用grails框架做的。最近将它打成了war包,部署到正式环境的时候居然报了404的错误,然后仔细看看了源代码,终于找到原因,也请各位在开发的时候注意:规约大于配置!!!
我现在只讲系统中遇到的问题。
1、
render(view:"/oa/seeDocumentFlow", model:[documentFlowInstance:documentFlowInstance,startUser:startUser,documentFlowSteps:documentFlowSteps])
解释:返回到oa下面的seeDocumentFlow视图(非当前包的视图),但其实oa这个视图文件名为:OA。用grails自己的服务器启动,web容器会找到OA,即使这里返回的视图为小写的:oa。好了,现在如果将项目打成war包部署到tomcat下面,哈哈,问题就出来了,报错如图1,
The requested resource (/WEB-INF/grails-app/views/oa/OADocumentFlow.jsp) is not available.
。在tomcat下面提示的是找不到oa这个视图文件夹。情况说明到这里,归其原因是:我们在代码里写的是小写的oa,grails web容器会找oa这个视图,找不到,它会去找类似的,比如:OA,所以在grails web容器里会找到对应的资源,但是tomcat下面就找不到了。具体原因不清楚,应该是和grails的“规约大于配置”这一理念相关。
2、
<iframe src="${resource(dir:'taskManager',file:'taskManager1')}" />
对应的是taskManager视图文件夹下面的taskManager1视图。在我的项目中,别人做的是把taskManager1这个文件名改成了TaskManager1,在grails web容器里可以找到,controller类里也可以找到,但是打成war包后同样报404错误,图2:
/WEB-INF/grails-app/views/taskManager/taskManager1.jsp
。web容器找的是taskManager1这个action对应的taskManager1这个视图,但是实际存在的文件名是:TaskManager1,所以它报404错误,但grails web容器可以找到。
两者情况有点相反,请大家在做grails开发的时候注意下,不要到了部署的时候才发现这样的问题。