JavaEE(Java Enterprise Edition),Java企业版,是一个用于企业级web开发(不需要使用控制台)平台。最早由Sun公司定制并发布,后由Oracle负责维护。
JavaEE平台规范了在开发企业级web应用中的技术标准。
在JavaEE平台共包含了13个技术规范(随着JavaEE版本的变化所包含的技术点的数量会有增多)。它们分别是:JDBC、JNDI、EJB、RMI、Servlet、JSP、XML、JMS、Java IDL、JPA、JTA、JavaMail和JAF。
JavaEE案例要使用到浏览器、服务器(Tomcat)、数据库。
JavaEE案例程序不是通过main方法来运行,而是要放在服务器(Tomcat)来运行。
JavaEE案例要使用到Servlet和jsp两个技术,而且多了一个web.xml文件做配置。
JavaEE案例是将结果给打印到了浏览器上,而不是控制台上!
JavaEE案例可以让更多的人去访问它、使用它!
浏览器与服务器之间发送数据的时候,是要有格式的,是双方约定好的格式。这样双方才能认识对方发送的数据!这个格式我们称之为协议(在互联网中主机与主机之间进行访问沟通都需要使用特定的协议)
超文本(Hypertext)是一种通过链接和交互式方式来组织和呈现信息的文本形式。在超文本中,文本可以包含链接和标签,使得用户可以在不同的信息之间进行跳转和交互。超文本技术是现代互联网和万维网的重要基础,为用户提供了更加便捷和自由的信息浏览方式。
HTTP协议是Hyper Text Transfer Protocol(超文本传输协议)的缩写, HTTP是万维网(WWW:World Wide Web)的数据通信的基础。
HTTP是一个简单的请求-响应协议,它通常运行在TCP之上。它指定了客户端可能发送给服务器什么样的消息以及得到什么样的响应。
HTTP是一个基于TCP/IP通信协议来传递数据
网络分层模型各个层的作用:
层 | 作用 | 举例说明 |
---|---|---|
物理层 | 负责光电信号的传输 | 以太网线、同轴电缆 |
数据链路层 | 负责设备之间数据帧的传送和识别 | 网卡设备驱动、帧同步、冲突检测、CRC |
网络层 | 负责地址管理和路由选择 | IP标识主机、路由表规划传输路线 |
传输层 | 负责两台主机之间的数据传输 | 传输控制协议(TCP) |
应用层 | 负责应用程序间沟通 | Http、SMTP、FTP、Telnet、网络编程主要针对应用层 |
TCP与UDP的区别?
TCP协议 | UDP协议 |
---|---|
面向连接 | 非面向连接 |
点到点的通信 | 可以广播发送 |
高可靠性:三次握手、四次挥手 | 传输不可靠、可能丢失 |
占用系统资源多、效率低 | 非常简单的协议、开销小 |
生活案例:打电话 | 生活案例:发送短信 |
支持客户端/服务器模式
简单快速
灵活(传输的数据类型多样)
短连接 短链接是指每次请求响应完成后,连接会自动断开。从http1.1开始,我们使用的是长连接,长连接是每次请求响应完成后,连接会保持一小段的存活时间,供之后的请求使用。长连接要比短连接的效率高!
单向性 服务端永远是被动的等待客户端(浏览器)的请求。
无状态 无状态是指协议对于事务处理没有记忆能力。缺少状态意味着如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传送的数据量增大,用户体验度也不好。为了解决HTTP协议无状态,于是,两种用于保持HTTP连接状态的技术就应运而生了,一个是Cookie,而另一个则是Session。
URL(Uniform Resource Location统一资源定位符),可以帮助我们唯一定位互联网上的某一个资源。URL由五个元素组成:
举例:http://localhost:8080/demo1/HelloServlet?name=小蛮蛮&birthday=1990-10-10
传送协议 : http://
域名或者IP地址 : 127.0.0.1,也可以是域名
端口号(以数字方式表示,tomcat配置文件中的默认端口号若修改为80,则可以省略): 8080
请求资源路径 /demo1/HelloServlet (URI)
传递数据(在URL中传递数据是以key=value的结构进行数据绑定,以“?”字符为起点,每个参数以“&”隔开通常以UTF8的URL编码,避开字符冲突的问题)小蛮蛮&birthday=1900-05-09
URI:(Uniform Resource Identifier),统一资源标识符,是一个用于标识某一互联网资源名称的字符串。
URL包含了URI。
在Java中,当获取请求URI时,常是/demo1/HelloServlet。
http协议就是用来规范请求与响应的数据格式的。 Request 消息分为3部分:
第一部分叫Request line 请求
第二部分叫Request header 请求
第三部分是Request body 请求体
get请求没有请求体,将数据通过url直接传递
post有请求体,将数据通过请求体传递
Request header和Request body之间有个空行。
get方式没有请求体
post这里也是请求行和请求头
请求行
中含有:请求的方式、URI、协议/版本。
请求头
中信息的格式为key:value。
Host 客户端指定自己想访问的WEB服务器的域名/IP 地址和端口号。
Connection 连接方式。如果值是close则表示基于短连接方式,如果该值是keep-alive,网络连接就是持久的,在一定时间范围内不会关闭,使得对同一个服务器的请求可继续在该连接上完成。
Upgrade-Insecure-Requests 服务端是否支持https加密协议。
Cache-Control 指定请求和响应遵循的缓存机制。
User-Agent 浏览器表明自己的身份(是哪种浏览器)。例如Chrome浏览器:Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.129 Safari/537.36。
Accept 告诉WEB服务器自己接受什么介质类型,/ 表示任何类型,type/* 表示该类型下的所有子类型。
Accept-Encoding 浏览器申明自己接收的编码方法,通常指定压缩方法,是否支持压缩,支持什么压缩方法(gzip,deflate)。
Accept-Language 浏览器申明自己接收的语言。语言跟字符集的区别:中文是语言,中文有多种字符集,比如big5,gb2312,gbk等。
Accept-Charset 浏览器告诉服务器自己能接收的字符集。
Referer 浏览器向WEB 服务器表明自己是从哪个网页URL获得点击当前请求中的网址/URL。
Refresh 表示浏览器应该在多少时间之后刷新文档,以秒计时。
Cookie 可向服务端传递数据一种模型。
客户端传递给服务器的数据。比如:表单使用post方式提交的数据、上传文件数据等。
GET 向指定的资源发出“显示”请求。 GET请求中会将请求中传递的数据包含在URL中并在浏览器的地址栏中显示。 GET请求传递数据时要求数据必须是ASCII字符。 GET请求可以被浏览器缓存。
POST 向指定资源提交数据,请求服务器进行处理(例如提交表单或者上传文件)。 数据被包含在请求体中。 POST请求传递数据时,数据可以是ASCII字符也可以是字节型数据,默认为字节型。 POST请求默认情况下不会被浏览器所缓存。
HEAD 向服务器索要与GET请求相一致的响应,只不过响应体将不会被返回。这一方法可以在不必传输整个响应内容的情况下,就可以获取包含在响应消息头度中的元信息。
PUT 向指定资源位置上传其最新内容。
DELETE 请求服务器删除Request-URI所标识的资源。
TRACE 回显服务器收到的请求,主要用于测试或诊断。
OPTIONS 这个方法可使服务器传回该资源所支持的所有HTTP请求方法。用'*'来代替资源名称,向Web服务器发送OPTIONS请求,可以测试服务器功能是否正常运作。
CONNECT HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器。通常用于SSL加密服务器的链接(经由非加密的HTTP代理服务器)。
GET请求会被浏览器主动cache,而POST不会,除非手动设置。
GET请求只能进行url编码,而POST支持多种编码方式。
GET请求参数会被完整保留在浏览器历史记录里,而POST中的参数不会被保留。
GET请求在URL中传送的参数是有长度限制的,而POST则没有。对参数的数据类型GET只接受ASCII字符,
POST既可是字符也可是字节。
GET相比POST来说不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息。
GET参数通过URL传递,POST放在Request body中。
Response消息也由三部分组成:
第一部分叫Response line
第二部分叫Response header
第三部分叫Response body。
HTTP状态码分类,共分为5种类型:
1xx:
2xx:
3xx:
4xx:
5xx:
常见状态码及含义
200 - 请求成功,已经正常处理完毕
301 - 请求永久重定向,转移到其它URL
302 - 请求临时重定向
304 - 请求被重定向到客户端本地缓存
400 - 客户端请求存在语法错误(客户端传递的数据类型不是后端想要的类型)
401 - 客户端请求没有经过授权
403 - 客户端的请求被服务器拒绝,一般为客户端没有访问权限
404 - 资源未找到,客户端请求的URL在服务端不存在
405 – 请求方式不支持
500 - 服务端出现异常
响应头用于告知浏览器当前响应中的详细信息,浏览器通过获取响应头中的信息可以知道应该如何处理响应结果。响应头中信息的格式为key:value。
Date 响应的Date使用的是GMT时间格式,表示响应消息送达时间。
Content-Encoding 文档的编码(Encode)方式。用gzip压缩文档能够显著地减少HTML文档的响应时间。
Content-Length 表示内容长度。只有当浏览器使用持久HTTP连接时才需要这个数据。
Content-Type 表示响应的文档属于什么MIME类型。
MIME(Multipurpose Internet Mail Extensions)多用途互联网邮件扩展类型。是设定某种扩展名的文件用一种应用程序来打开的方式类型,当该扩展名文件被访问的时候,浏览器会自动使用指定应用程序来打开。多用于指定一些客户端自定义的文件名,以及一些媒体文件打开方式。 MIME作用:HTTP协议所产生的响应中正文部分可以是任意格式的数据,那么如何保证接收方能看得懂发送方发送的正文数据呢?HTTP协议采用MIME协议来规范正文的数据格式。 在服务端我们可以设置响应头中Content-Type的值来指定响应类型。
MIME类型对应列表
Type | Meaning |
---|---|
application/postscript | PostScript file |
application/vnd.lotus-notes | Lotus Notes file |
application/vnd.ms-excel | Excel spreadsheet |
application/vnd.ms-powerpoint | PowerPoint presentation |
application/x-gzip | Gzip archive |
application/x-java-archive | JAR file |
application/x-java-serialized-object | Serialized Java object |
application/x-java-vm | Java bytecode (.class) file |
application/zip | Zip archive |
audio/basic | Sound file in .au or .snd format |
audio/midi | MIDI sound file |
audio/x-aiff | AIFF sound file |
audio/x-wav | Microsoft Windows sound file |
image/gif | GIF image |
image/jpeg | JPEG image |
image/png | PNG image |
image/tiff | TIFF image |
image/x-xbitmap | X Windows bitmap image |
text/css | HTML cascading style sheet |
text/html | HTML document |
text/plain | Plain text |
text/xml | XML |
video/mpeg | MPEG video clip |
video/quicktime | QuickTime video clip |
application/msword | Microsoft Word document |
application/octet-stream | Unrecognized or binary data |
application/pdf | Acrobat (.pdf) file |
application/json | json |
响应体就是响应的消息体,如果是纯数据就是返回纯数据,如果请求的是HTML页面,那么返回的就是HTML代码,如果是JS就是JS代码。
硬件服务器的构成与一般的PC比较相似,但是服务器在稳定性、安全性、性能等方面都要求更高,因为CPU、芯片组、内存、磁盘系统、网络等硬件和普通PC有所不同。
软件服务器(英文名称Server),也称伺服器。指一个管理资源并为用户提供服务的计算机软件,通常分为文件服务器、数据库服务器和应用程序服务器。运行以上软件的计算机或计算机系统也被称为服务器。
应用服务器是Java EE规范的具体实现, 可以执行/驱动基于JavaEE平台开发的web项目。绝大部分的应用服务器都是付费产品。 常见的应用服务器:
1. Weblogic(BEA Oracle 收费)
2. Webshpere(IBM 收费)
3. JBoss(RedHad 收费)
4. Resin(Caucho 收费)
5. JRun(Macromedia 收费)
6. Geronimo(Apache 免费)
只实现了JavaEE平台下部分技术标准,如Servlet,Jsp,JNDI,JavaMail。Web容器是开源免费的。
Tomcat(Apache 开源免费)
Jetty(Jetty 开源免费)
下载地址:Apache Tomcat® - Welcome!
Tomcat是一款绿色软件,我们下载压缩包,解压即可使用!
注意:一定要配置正确JDK(JAVA_HOME、path),否则Tomcat服务器是不能正常使用!!!
原因:tomcat底层也是java实现的
Tomcat的启动与关闭需要执行bin目录中的命令脚本。 注意: 如果启动时闪退,是因为JDK的环境变量配置不规范,需要重新配置。
Tomcat 的配置文件由4个xml组成,分别是 context.xml、web.xml、server.xml、tomcat-users.xml。每个文件都有自己的功能与配置方法。
context.xml context.xml 是 Tomcat 公用的环境配置。 Tomcat 服务器会定时去扫描这个文件。一旦发现文件被修改(时间戳改变了),就会自动重新加载这个文件,而不需要重启服务器 。
web.xml Web应用程序描述文件,都是关于是Web应用程序的配置文件。所有Web应用的 web.xml 文件的父文件。
server.xml 是 tomcat 服务器的核心配置文件,server.xml的每一个元素都对应了 tomcat中的一个组件(pojo对象),通过对xml中元素的配置,实现对 tomcat中的各个组件和端口的配置。
tomcat-users.xml 配置访问Tomcat的用户以及角色的配置文件。
控制台产生乱码的原因是在Tomcat在输出日志中使用的是UTF-8编码,而我们中文的Windows操作系统使用的是GBK编码。由于编码格式不统一,所以出现了乱码。
解决方式:修改conf目录中的logging.properties文件重新指定的编码方式。直接注释上,让其采用默认的编码GBK与命令行保持一致(或者把UTF-8改为GBK)
Tomcat默认监听端口为8080。可通过修改server.xml文件来改变Tomcat监听端口。
Tomcat的最大并发数是可以配置的,实际运用中,最大并发数与硬件性能和CPU数量都有很大关系的。更好的硬件,更多的处理器都会使Tomcat支持更多的并发。
这个并发能力还与应用的逻辑密切相关,如果逻辑很复杂需要大量的计算,那并发能力势必会下降。如果每个请求都含有很多的数据库操作,那么对于数据库的性能也是非常高的。 对于单台数据库服务器来说,允许客户端的连接数量是有限制的。并发能力问题涉及整个系统架构和业务逻辑、系统环境不同、Tomcat版本不同、JDK版本不同、以及修改的设定参数不同。并发量的差异还是满大的。并发数设置参数有如下几个:
最大并发数: maxThreads="1000"
初始化时创建的线程数: minSpareThreads="100"
一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程:maxSpareThreads="500"
指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理: acceptCount="700"
Tomcat版本 | JDK版本 | Servlet版本 | JSP版本 | EL版本 |
---|---|---|---|---|
9.0.x | 8 and later | 4 | 2.3 | 3 |
8.5.x | 7 and later | 3.1 | 2.3 | 3 |
8.0.x | 7 and later | 3.1 | 2.3 | 3 |
7.0.x | 6 and later | 3 | 2.2 | 2.2 |
6.0.x | 5 and later | 2.5 | 2.1 | 2.1 |
还是在server.xml下的Host
虚拟主机(英语:virtual hosting),又称虚拟服务器, Host组件位于Engine(执行引擎)中用于接收请求并进行相应处理的虚拟主机。这里是tomcat中默认的虚拟主机,以及相关属性
name:虚拟主机的名称,Tomcat通过在请求URL中的域名与name中的值匹配,用于查找能够处理该请求的虚拟主机。如果未找到则交给在Engine中defaultHost指定的主机处理;
appBase:此Host的webapps目录,即指定存放web应用程序的目录的路径;
unpackWARs:在启用此webapps时是否对WAR格式的归档文件先进行展开;默认为true,
可以简单理解是帮你解压了war的程序进行执行;
autoDeploy:在Tomcat处于运行状态时放置于appBase目录中的应用程序文件是否自动进行deploy(部署);默认为true;
创建项目名为test, 在项目中创建index.html页面。
将index.html资源部署到D盘的bjsxt目录中。
通过www.bjsxt.com:8080/test/index.html访问虚拟主机,并访问index.html。
创建index.html页面。
修改Windows系统中的Host文件做域名与IP的绑定。
Host文件位置 C:\Windows\System32\drivers\etc
注意:如果不能修改或不能保存该文件,请设置一下权限。右击该文件,点击属性,设置非只读
Context是Host的子组件,代表指定一个Web应用,它运行在某个指定的虚拟主机(Host)上;每个Web应用都是一个WAR文件,或文件的目录。
tomcat设置
部署工程
启动tomcat
启动之后,点击重新启动按钮
1.update resources: 当修改了静态资源(html,css等)之后,idea自动同步静态资源
2.update classes and resources:对类的修改使用它不生效,所以不建议使用。
3.Redeploy:重部署,这个适合于你修改了代码,可以重新部署项目到服务器,修改了web.xml重部署不生效。
4.restart server:重启服务器,修改了代码,web.xml时使用,因为web.xml是在服务器启动时才解析。
自定义一个类,继承HttpServlet
重写service方法(写的就是业务处理的代码)
在web.xml中对Servlet进行配置
1.导入tomcat依赖
前面的设置只是执行的设置,tomcat的依赖还没有导入,它的导入方法与jar包不太一样
2.创建类继承HttpServlet并重写service方法
public class FirstServlet extends HttpServlet {
@Override
public void service(ServletRequest req, ServletResponse res) throws ServletException, IOException {
System.out.println("servlet执行了");
}
}
3.编写web.xml文件,添加servlet的执行路径
first
com.sh.servlet.FirstServlet
first
/first
4.启动tomcat
1.进入默认的界面
暂时还没有响应代码
控制台输出了
用户访问localhost:8080/test/helloword,请求被发送到Tomcat,被监听8080端口并处理 HTTP/1.1 协议的Connector获得。
Connector把该请求交给它所在的Service的Engine来处理,并等待Engine的回应。
Engine获得请求localhost/test/helloword,匹配所有的虚拟主机Host。
Engine匹配到名为localhost的Host虚拟主机来处理/test/helloword请求(即使匹配不到会请求交给默认Host处理)。
匹配到的Context获得请求/helloword。
构造HttpServletRequest对象和HttpServletResponse对象.执行业务逻辑、数据存储等程序。
Context把执行完之后的结果通过HttpServletResponse对象返回给Host。
Host把HttpServletResponse返回给Engine。
Engine把HttpServletResponse对象返回Connector。
Connector把HttpServletResponse对象返回给客户Browser。