IDEA配置java web
起因
在学习javaEE课程之处,需要安装搭建相关的javaEE环境,过程中遇到许多困难,本文记录一下正确安装并运行的过程。以及项目创建的过程,为java web入门环境安装提供思路。
Tomcat 安装
安装途径: 1. 钉钉群中的免安装版 2. 官网下载 Apache Tomcat® - Welcome!
无论是哪种方式下载,都需要检查环境配置,方法:资源管理器中右键 此电脑 —>属性 —> 高级环境配置—> 环境变量
data:image/s3,"s3://crabby-images/c8d75/c8d75127d63b9d973613328d273f153728ed33f7" alt="image-20240306205219023"
data:image/s3,"s3://crabby-images/db85f/db85fde57b8e63a44c1e8b3335491ce8a86c1343" alt="image-20240306205237923"
CATALINA_HOME
观察系统变量中是否存在CATALINA_HOME,若无请添加:新建->变量名->变量值
==此处的变量值为tomcat的根目录==
data:image/s3,"s3://crabby-images/867af/867af1baa923509c098bad22797688e1b425964d" alt="image-20240306205431742"
添加(此处需要设置自己的目录):
data:image/s3,"s3://crabby-images/5772c/5772c0da4667b531f11ae08004b8d73b89520c39" alt="image-20240306205458135"
bin&lib
随后进入path目录,观察是否有%CATALINA_HOME%\bin和\lib,无前者一般均无此处的path
data:image/s3,"s3://crabby-images/fd6f6/fd6f666a116d146d2f79d9cf175165f722cd0fcc" alt="image-20240306205718818"
若无,请添加,此处的变量和我一致
data:image/s3,"s3://crabby-images/cc6a0/cc6a03f8e24061e344e725b7222e8854d3ee808f" alt="image-20240306205840063"
配置完成
win+r 打开cmd,在终端中输入startup,出现
data:image/s3,"s3://crabby-images/88ed5/88ed523a5293e8b2d9d258fc4ad8e7d5a5d43616" alt="image-20240306205941462"
并开始执行程序说明配置完成了,可以在浏览器中输入localhost:8080 或 127.0.0.1:8080 进行查看(默认8080端口)。
data:image/s3,"s3://crabby-images/6d9ce/6d9ce6fa5e9102f2e71a285ca78ed36e0e3152db" alt="image-20240306210121460"
IDEA创建web项目
一、新建项目
由于idea自带maven,我们可以在创建的时候直接选择maven项目
data:image/s3,"s3://crabby-images/2e71c/2e71c0b712ffaccbd71e94ad22a6fce356a8094c" alt="image-20240306210242783"
二、创建web模块
我们需要创建一个web模块,右键项目,打开模块配置
data:image/s3,"s3://crabby-images/c6503/c650370e5b6c398ceaea8adc917d60c0f659e582" alt="image-20240306210456779"
我们需要在新建的项目中添加web模块
data:image/s3,"s3://crabby-images/cc231/cc231fb4f45d8b28b38a2cab7606f1a4e8ffe537" alt="image-20240306210620800"
**注意: 为了接下来项目结构不至于混乱,使用默认的路径即可 ** 个人认为直接放置于项目下即可,浏览前端代码也方便,若是前端使用框架开发,如vue则无需新增web模块。
data:image/s3,"s3://crabby-images/279c6/279c6eaf921f5f19d430c4f0296c5637cafb1948" alt="image-20240519234756649"
三、创建工件
然后我们需要在工件中,创建一个web应用程序:展开型工件,用于在idea中运行时生成war包
data:image/s3,"s3://crabby-images/cb279/cb279c26cbe5c1b88161d0503d558393cc74a2cf" alt="image-20240306211002519"
四、观察项目结构
若项目结构实在混乱,可参考我的项目结构
data:image/s3,"s3://crabby-images/d92a7/d92a76b819ef172bb7539df6d183b6efbaeee64f" alt="image-20240519234952023"
配置编译环境
运行tomcat,我们需要配置tomcat的编译环境
data:image/s3,"s3://crabby-images/a1549/a154925da7cf8447d622be9ed9cee17f37a04447" alt="image-20240306211845399"
data:image/s3,"s3://crabby-images/eda8c/eda8cd7c4195a6da0562069fb0afa23617e7c37f" alt="image-20240306211909873"
基本上都会自动查询到应用程序服务器,若无,请单机配置idea会根据环境变量查找到tomcat的位置
data:image/s3,"s3://crabby-images/8e920/8e92057414e8f947d33252055d9532fdc889aa74" alt="image-20240306211938005"
在部署中添加刚刚创建的工件
data:image/s3,"s3://crabby-images/d4944/d4944acae0797310561c0455258d886ba4ddddda" alt="image-20240306212105265"
配置完成
我们在web下创建一个index.html做测试(war包会自动访问到内部的index文件,即首页,这里使用index.html是为了方便观察)
data:image/s3,"s3://crabby-images/e66d8/e66d8e264fd4b268c31fc0fefc111aadfaebdd85" alt="image-20240519235102763"
单机运行,会自动弹出页面
data:image/s3,"s3://crabby-images/e1833/e18339bd7c8b31aab631d08bde6fdc02eaa43d74" alt="image-20240306212520196"
MAVEN打包
在pom.xml中添加
1 | <packaging>war</packaging> |
注意需要放在项目前面,推荐下图的位置。
注:每次操作完maven记得更新配置(即下图另一红框)
data:image/s3,"s3://crabby-images/d2e89/d2e89903158458b392000efcf261274f93d6f1e3" alt="image-20240306212623324"
在整个idea的右边选择这个”m”,clean是清除之前生成的文件,在打包前可以清理一下。
data:image/s3,"s3://crabby-images/e47c1/e47c1cc35c48fbf7703a79bfd8511e74f4ab90e3" alt="image-20240306212938565"
选择打包则可以生成一个target目录,内含一个本项目的war包
此处的clean和package均双击就可运行
data:image/s3,"s3://crabby-images/c67a3/c67a35402be844b2c693ebb472ad40e13d0be4c9" alt="image-20240306213204455"
TOMCAT下运行war
以刚刚打包的war为例,将war移动到tomcat的webapps下
data:image/s3,"s3://crabby-images/0a05c/0a05c416a272037edf8798129d0b55eeb8eb3dcb" alt="image-20240306213329725"
我们将war包的名称修改,方便等一下浏览。
data:image/s3,"s3://crabby-images/899a8/899a8a8de9938c3870a4b91e39e3de1bf6b2fc92" alt="image-20240306213415135"
启动tomcat
data:image/s3,"s3://crabby-images/c4691/c46915bc076839bb1ae5e7f26ba169d3121237cc" alt="image-20240306213523983"
在浏览器中输入localhost:8080/项目名称(即刚刚重命名的web,注意这里的.war省略)
data:image/s3,"s3://crabby-images/32f9e/32f9e3dd92eada7fe6b4fd0033f72fb07c6ad1d8" alt="image-20240306213553467"
.war省略的原因为:tomcat在运行后会自动解压war包,生成一个web目录,实质上访问的是该目录。
值得注意的是:在tomcat运行的时候千万不要去删除war包,会使的解压的目录一并被清除
如果你的项目中未设定index,按照上文进行会出现404的情况,千万不要着急,在$localhost:8080/项目名称$ 后跟上$/你的文件名$即可
例:
1 | localhost:8080/web/test.html |
MAVEN项目添加依赖
工具网站:Maven Repository: Search/Browse/Explore (mvnrepository.com)
此网站用于添加依赖,请各位添加到收藏夹中
我们首先需要在pom.xml中添加条目,用于存放依赖
data:image/s3,"s3://crabby-images/a8b1e/a8b1e11c8eaa57ad24d78fbc30a8f41e6fccb534" alt="image-20240306214458708"
JUNIT
JUnit 是一个编写可重复测试的简单框架。它是单元测试框架的 xUnit 架构的一个实例。
相关的详细介绍:详解介绍JUnit单元测试框架(完整版)_junit整体框架详细介绍-CSDN博客
data:image/s3,"s3://crabby-images/1bafe/1bafe75fa4da9907672dab6dd98ee1d0c631a2c1" alt="image-20240306214323641"
单机需要的版本
data:image/s3,"s3://crabby-images/8136f/8136fd456a3df07f6014002898a52dc841ee1676" alt="image-20240306214350386"
将代码复制到pom.xml中
data:image/s3,"s3://crabby-images/c305a/c305ad43df24ee73dcd6815974747cad77ec4003" alt="image-20240306214535051"
这边给出5.10.2的依赖
1 | <!-- https://mvnrepository.com/artifact/org.junit.jupiter/junit-jupiter-api --> |
SERVLET
Java Servlet 是运行在 Web 服务器或应用服务器上的程序,它是作为来自 Web 浏览器或其他 HTTP 客户端的请求和 HTTP 服务器上的数据库或应用程序之间的中间层。
相关介绍:Servlet 简介 | 菜鸟教程 (runoob.com)
servlet需要和tomcat的版本匹配,可以在tomcat的lib中的jar中看到对应的版本匹配。也可以在官方对应的表格中看到需要添加的servlet依赖。
data:image/s3,"s3://crabby-images/69e83/69e83e6927537f8934e8224a66e6a92498df1ef8" alt="image-20240306214647469"
同样在Maven Repository中搜素servlet,并将代码添加到依赖中
data:image/s3,"s3://crabby-images/1234e/1234e0591b287e559d4cb6a1d4c47a759e1a76bf" alt="image-20240306214953812"
这边给出tomcat9对应的servlet的引用代码
1 | <!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api --> |