不得不解释得几个概念
JavaEE
SUN公司提出来的企业版Java开发中间件,主要用于企业级互联网系统的框架搭建,同时因为Java语言优质的平台无关性、可移植性、健壮性、支持多线程和安全性等优势,其迅速成为构建企业互联网平台的主流技术;其本质是一种容器加组件技术,容器是用来管理组件行为的集合工具,它规范了组件的运转,例如组件的行为外部环境的交互、组建的生命周期、组件之间的合作依赖关系及运行等等,而组件是开发者编写或者引入的第三方程序代码,只需要按照容器所定义的规范开发组件,组件便可在容器中运行;JavaEE的主要组件包括JSP、Servlet、EJB(Enterprise Java Bean)
JavaEE容器
Web容器:Web容器是JavaEE容器之一,它包含一个Servlet容器,而Servlet容器可以运行JavaEE的核心组件Servlet,实际上JSP最终也是被Web容器翻译为Servlet,再通过Servlet容器运行;在Web容器中,除了Servlet容器运行Servlet组件外,Web容器还可以运行HTML等文件;实现Web容器规范的服务器有很多,诸如Tomcat、Jetty、Wildfly(以前的JBoss)和GlassFish等等,他们都遵循JavaEE规范
Web服务器:Web服务器的作用说穿了就是,将某个主机上的资源映射为一个URL供外界访问,任何一个应用程序都包含3个步骤,接受请求、处理请求、响应请求,而其中请求和响应是共性的,且没有差异性,通过浏览器链接访问京东或者淘宝,传递给浏览器的都是JSON数据,于是就把接收和响应两个步骤抽取成Web服务器
Servlet容器:存放着Servlet对象,我们为什么能通过Web服务器映射的URL访问资源?就要Servlet容器里的对象完成Web服务器不能完成的任务就是处理请求的逻辑,而这部分通常都是差异性的,抽取出来做成Servlet,由工程师自己编写;之后随着互联网的发展,出现了更细化的分层,又将逻辑从Servlet中抽取出来,形成Service和Dao;然而Servlet并不擅长像浏览器输出HTML页面,因此出现了JSP(Java Server Page),它存在的意义全在于方便编写动态页面,是Java和HTML更好的结合;而当Spring家族出现后,Servlet将退居幕后,取而代之的是更方便的SpringMVC,SpringMVC的核心组件DispatcherServlet其本质就是一个Servlet,看起来似乎没有半毛钱关系
EJB容器:EJB容器是JavaEE的一个企业级Java Bean规范,其运行的组件是EJB,在默认情况下,Tomcat只提供Web容器不提供EJB容器,在没有引入EJB插件的情况下,Tomcat无法运行EJB;Wildfly和GlassFish等服务器则提供了EJB容器;目前EJB容器已经被大多数企业抛弃存在诸多问题
其他应用容器:还有一些厂商提供了特别的容器,用于解决特殊的问题,例如Java NIO,它是一种支持字节组件的容器
JavaEE组件
JavaEE组件是运行在JavaEE容器中的程序片段,该组件可以和Java的其他技术融合;在不同的容器中存在不同的组件,在Web容器中主要的组件是Servlet和JSP,而当前的Java应用更流行的是前后端分离,因此JSP技术也走向了淘汰,但本质上说JSP也是一种Servlet技术,Web容器会先将JSP翻译为Servlet再执行,而EJB中主要的组件是Java Bean,可以细分为会话Bean、实体Bean和消息驱动Bean,也属于淘汰的技术;其他的组件则需要根据实际需要自行引入
JavaEE Web项目构建
Web服务器:Tomcat9.0.87 & 编译器:IntelliJ IDEA &项目管理和自动化构建工具:Maven & Java版本:java version “1.8.0_311”
Java面向对象系列[v1.0.0][JDK安装与配置]
Java面向对象系列[v1.0.0][集成开发环境搭建]
Java面向对象系列[v1.0.0][Maven开发环境]
Tomcat支持HTTP,并且支持Web容器的规范,同时支持JSP和Servlet等JavaEE技术,Tomcat就是Web服务器和Servlet容器的结合体可以通过官方网站下载需要的的版本,注意版本的匹配,避免无意的异常
下载完成后,在bin目录下找到startup.bat文件,执行即可启动Tomcat,启动时会弹出命令行窗口,如图所示
打开浏览器,访问http://localhost:8080
则可以访问该Tomcat的控制台页面
在启动startup.bat的时候,命令行窗口如果出现中文的乱码,其实不影响,但如果想要正常显示中文,在tomcat的目录下,找到conf文件夹,文件中有个logging.properties文件,修改文件中的配置项java.util.logging.ConsoleHandler.encoding = GBK
的值为GBK,然后重启tomcat即可
在Tomcat的控台页面,如果需要进行管理等相关动作,是需要登录的,在tomcat目录下的conf文件夹内有配置用户的文件tomcat-users.xml
文件夹 | 说明 |
bin | 放置操作Tomcat 服务器的命令,通常以在Windows系统下可执行批处理文件或在Linux下执行的Shell文件为主 |
conf | 放置Tomcat的配置文件 |
lib | 存放启动的包,例如如果Tomcat需要连接数据源,则需要将对应的数据库连接包放在该目录下 |
logs | 放置Tomcat的日志文件 |
temp | 缓存目录,放置Tomcat缓存的内容 |
webapps | Web项目部署目录,将JavaEE的Web项目放在这里,会被自动发布 |
work | Tomcat的工作目录,在Tomcat运行时,JSP会被翻译为Servlet,而编译Servlet后生成的class文件,则自动存在这里,后续运行的速度则会运行编译后的文件 |
启动IDEA
创建Maven项目
Archetype选择org.apache.maven.archetypes:maven-archetype-webapp
创建完成后如果遇到异常No archetype found in remote catalog. Defaulting to internal catalog
实际上这个异常没影响,但会比较烦人
解决方法一:
添加配置,在Settings窗口搜索Runner,在配置里添加VM Options ——> -DarchetypeCatalog=internal
解决方法二:
在创建项目的时候,添加配置项
再次创建就不会再报类似的异常,创建成功后默认的目录如下图所示
不同的编译器创建完的项目结构有所不同,如果是Eclipse,则创建完会在main路径下有个java文件夹,用于存放程序员编写的java文件,resources文件夹通常放置各种配置文件,webapp文件夹主要放置Web项目所需的各类文件如HTML、JSP、JavaScript文件等等,IDEA缺少了java文件夹,可以手动添加上;如果是Eclipse会在src路径下与main文件夹同级创建一个test文件夹,test文件夹内也会有个java文件夹,用于放置测试类,同时也会有一个和该java路径同级的resources文件夹,用于存放测试类所需要的各种配置文件,如果是IDEA的话手动添加上即可
- 需要特殊说明的是在webapp/WEB-INF下有一个web.xml文件,这是一个JavaEE Web项目的配置文件,但在Servlet3.0后的容器规范下,它不是必须的
- webapp路径下的index.jsp是IDE创建的一个JSP样例,可在浏览器页面输出Hello World
IDEA配置Tomcat
确保之前手动启动的Tomcat服务是关闭的,否则会报端口冲突
只配置了Tomcat Server 执行之后,浏览器弹出来如下图所示
配置Deployment,指向目标War包,再次执行
打包选项在Project Structure中,默认第一个即可
编译器会自动生成新的目录,并生成war包
如果不实用编译器,也可以直接将这个war包复制到Tomcat的webapps路径下,然后执行Tomcat的startup.bat,启动tomcat,然后通过Manager App查看
实际上在IDEA配置好Tomcat之后,在编译器里执行,编译器就会重新打包,并向Tomcat的webapps的路径下放一份war文件,命名通常是
项目名_war
的形式, 而自行复制过来的war文件是项目名