蝙蝠岛资源网 Design By www.hbtsch.com

idea将web项目打包成war最重要的是配置atrificats。

首先打开file -》 project structure

idea打包成war包部署到tomcat及访问路径问题(图文详解)

创建之后,output directory即为输出war包的路径。Name可以随意,之后点击绿色+,打开directory content

idea打包成war包部署到tomcat及访问路径问题(图文详解)

选择webapp目录,记得勾选include in project build

idea打包成war包部署到tomcat及访问路径问题(图文详解)

idea打包成war包部署到tomcat及访问路径问题(图文详解)

点击ok后,新建一个配置

idea打包成war包部署到tomcat及访问路径问题(图文详解)

选择artificats

idea打包成war包部署到tomcat及访问路径问题(图文详解)

idea打包成war包部署到tomcat及访问路径问题(图文详解)

这样就算配置完成,点击run执行之后,就到前面的output directory设置的文件夹里找到war包就行了。war包放到tomcat的webapp目录下,再启动tomcat就能访问项目了。

项目的访问地址是localhost:8080/你的war包名称/index

在这里想说一下的是由于war包的名称决定了访问地址,所以当采用纯html+css+js写页面时,在页面的资源引用地址最好加上你的项目名称(即你的最终war包命名),例如引用js文件:

<link rel="stylesheet" href="/layui/css/layui.css" media="all" />

idea打包成war包部署到tomcat及访问路径问题(图文详解)

此时idea按住ctrl键加鼠标停留在文件路径上,会有可点击的提示。

但是在项目部署到tomcat上时,war包相当于增加了一个文件夹,文件夹名为你的war包名称,这时按原来的引用是会提示找不到这个文件的,这时候,我们应该这么引用:

<link rel="stylesheet" href="/war包名称/layui/css/layui.css" media="all" />

当你的引用地址含有..时,比如:

<script type="text/javascript" src="/UploadFiles/2021-04-10/editUser.js">

应该这样修改:

<script type="text/javascript" src="/UploadFiles/2021-04-10/editUser.js">

但是问题来了,这样配置的时候,部署到tomcat上能找到文件,但是本地idea开发启动tomcat调试之后,会找不到文件。这时候应该配置application context,启动之后就可以了。并且做到与部署到tomcat时的文件路径一致,不用在部署到tomcat上时,还要再修改前端页面的地址。(jsp可以不用考虑这个问题,因为jsp能获取根路径)。

idea打包成war包部署到tomcat及访问路径问题(图文详解)

如果application context只是“/”的话,那么就相当于所有的文件放在tomcat的webapp下面,直接通过localhost:8080/文件就能访问。

标签:
idea,war包部署tomcat,idea,war包

蝙蝠岛资源网 Design By www.hbtsch.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
蝙蝠岛资源网 Design By www.hbtsch.com

评论“idea打包成war包部署到tomcat及访问路径问题(图文详解)”

暂无idea打包成war包部署到tomcat及访问路径问题(图文详解)的评论...

RTX 5090要首发 性能要翻倍!三星展示GDDR7显存

三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。

首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。

据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。