工程结构

image.png

检查webui模块

image.png
注意红框部分,正常的web项目,文件夹样式应该如下图所示:
image.png
注意,webapp文件夹是有一个蓝色的小圆点,只有这样才说明此模块可以被idea认为是一个web模块,那么既然我们的工程都不是web项目,那还启动个毛线,所以我们要先将蓝色的小圆点搞出来。

将模块变成web工程

选中webui模块按F4,弹出设置对话框,选择Modules。
image.png
点击image.png(一定是选中webui模块,然后点击加号),选择Web
image.png
设置下图中,红色字体标注的路径,先设置1,再设置2
image.png
点击image.png,注意观察弹出窗口的路径
image.png
webui\web\WEB-INF\web.xml webui模块中根本就不存在此路径,所以此时要修改路径,让其指向正确的位置,还要选择正确的Deployment descriptor version,这里使用2.5。
点击image.png在弹出的窗口中设置路径。
image.png
找到webui模块所在文件夹,然后找到webapp文件夹,找到web.xml(一定要找到web.xml)将其选中,点击OK,设置完毕后如图所示
image.png
设置红色2标注的路径,操作方式与1是一样的,注意点是选中的路径是到webapp文件夹,设置完毕如下图所示
image.png
此时再看webapp文件夹,就出现了小蓝点
image.png

设置Artifacts

小蓝点已经有了,但此时项目依旧不能运行在tomcat中,还得需要配置Artifacts,将其放到tomcat中(这么说或许不标准,其实idea使用的是虚拟tmocat,并没有将war包真正放到配置为tomcat的webapp文件夹里),才能运行。选中webui模块按F4,选择Artifacts
image.png,点击image.png,然后如图操作
image.png,点击 From Modules...
image.png点击OK
image.png调整红框部门路径,使其指向webui模块里的输出路径,我们这里使用xxx\webui\target\,此路径为webui模块的输出路径,也可以指定模块名,比如xxx\webui\target\modulesName,一般不需要指定,因为会默认按照上面的Name,即xxx:war exploded。image.png,点击OK

配置Tomcat Artifact

关于idea如何配置tomcat这里就不演示了,默认为tomcat已经配置完成。打开配置好的tomcat,点击image.png选择Artifact
image.png点击OK
image.png点击OK

启动tomcat

在启动过程中会报错,异常为 java.lang.ClassNotFoundException: Cannot find class:com.xxx.xxx.A。由于webui最终是被发布的war包,那么此war包中会依赖其他模块,所以要在Artifacts配置中设置依赖的模块。
image.png
注意classes,要将其他模块的依赖加入到classes下。
将右侧模块展开
image.png
双击各个模块 compile output 部分,也就是将各个模块的编译输出路径加入到webui模块的classes里
image.png,点击OK,再尝试启动tomcat,正常情况下应该启动成功了。如果还启动不成功,就clean项目,然后在启动。


blob
45 声望2 粉丝

A man who concentrates on coding.


« 上一篇
Function
下一篇 »
代理模式