首先说一下在哪种情况下我遇到的这个问题。
当我在Eclipse中编写Struts2的项目时,我通过直接运行Eclipse中的Tomcat可以直接部署并访问我的项目,但是此时我想通过传统的Tomcat去部署并访问我的项目而不是通过Eclipse,我该如何做?当然首先是通过Tomcat去部署我的项目(Tomcat之Web部署 https://mp.csdn.net/console/editor/html/108360415),然后通过浏览器去访问,然后就遇到了本文章的问题。
图一:Eclipse中启动Tomcat访问此项目(正常访问)
图二:Tomcat部署项目,通过浏览器访问(报错)
问题产生原因的分析
我们通过图一可以看到web.xml对请求进行拦截后,要通过struts.xml去找到对应的loginForm.jsp文件,然后通过浏览器渲染出来,但是我们此时的struts.xml文件并不在WEB-INF文件夹中,也就是说Tomcat对路径进行拦截后,找不到对应loginForm的映射文件。此处提一点,有可能会有人问我在路径上面加.jsp,也就是直接访问这个页面能访问到吗?答案当然是不行的。Struts 2 推荐把所有的视图页面存放在 WEB-INF 目录下,这样可以保护视图页面,避免直接向视图页面发送请求,也就是说如果你把loginForm.jsp放到WebContent里面还能通过直接访问页面进行访问(不通过struts.xml进行映射),但是WEB-INF目录下的文件是无法通过浏览器访问的。
解决问题
由前面的分析可以知道在不改变loginForm.jsp文件位置的情况下,我们需要将struts.xml文件放到WEB-INF下,而是在Java Resources里面的src目录下编写的struts.xml文件,编译后会输出到build/classes文件中,而此目录不在WEB-INF中,也就是说我们需要更改Eclipse的配置让它编译后输出文件放到WEB-INF中,这样我们才能完美得通过自己去部署Tomcat后正常运行项目。以下是解决步骤。
然后你再次Tomcat去部署,则上面可以正常访问项目。
这时你可能会发现WEB-INF文件夹中有classes文件夹而Eclipse中的WEB-INF目录结构中没有显示。解决办法见(eclipse中WEB-INF不显示classes文件夹解决方法 https://mp.csdn.net/console/editor/html/108358715)