Java web基本概念
1.Java web
1.1Java web基本概念:
静态web:html,css
- (提供给所有人看的数据,始终不会发生变化)
动态web:Servlet/JSP,ASP,PHP,
- 淘宝等几乎所有的网站(提供给所有人看的数据,始终会发生变化,每个人在不同时间,不同地方看到的都不同)
1.2web应用程序
web应用程序:可以提供浏览器访问的程序
- a.html、b.html等多个web资源,这些web资源可以被外界访问,对外界提供服务。
- 能访问到的任何一个页面或者资源,都存在于这个世界的某一个角落的计算机上。
- URL:统一资源定位符。
- 这个统一的web资源会被放在同一个文件夹下,web应用程序—>Tomcat:服务器。
- 一个web应用由多部分组成(静态web、动态web)
- html、css、js、
- jsp、servlet
- java程序
- jar包
- 配置文件(properties)
- web应用程序编写完毕后,若想提供给外界访问:需要一个服务器来统一管理。
1.3静态web
.htm,.html,这些都是网页的后缀,如果服务器上一直存在这些东西,我们就可以直接进行读取。

静态web存在的缺点
Web页面无法动态更新,所用用户看到的都是同一个页面
轮播图,伪动态
javaScript(实际开发中,用的最多)
它无法和数据库交互(数据无法持久化,用户无法交互)
1.4动态web
页面会动态展示:Web的页面展示的效果因人而异。(千人千面)

动态web存在的缺点
- 加入服务器的动态web资源出现了错误,我们需要重新编写我们的后台程序,重新发布。
- 停机维护
优点:
- web页面可以动态更新,所有用户看到都不是同一个页面
- 它可以与数据库交互(数据持久化:注册,商品信息。)
1.5web服务器
服务器是一种被动的操作,用来处理用户的一些请求和给用户一些响应信息。
Java编写的[服务器端程序:JSP/Servlet:
架构:B/S:浏览和服务器
C/S:客户端和服务器
- sun公司主推的B/S架构
- 基于Java语言的,大部分开源组件
- 可以承载三高问题带来的影响(高并发、高可用、高性能)
服务器:
IIS:Windows中自带
tomacat:Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,属于轻量级应用服务器。
2.tomacat详解
文件夹作用:

temp:临时变量
work:工作目录
2.1配置
可以配置启动的端口号
- tomacat的默认端口号:8080
- mysql:3306
- http:80
- https:443
在tomacat文件里,server.xml文件。
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
可以配置主机的名称

可以改但没必要
2.2面试题:请你谈谈网站是如何访问的?
输入一个域名,回车
检查本机的C:Windows\System32\drivers\etc\hosts配置文件下有没有这个域名映射
有:直接返回对应的ip地址,这个地址中,有我们需要访问的web程序,可以直接访问。没有:去DNS服务器找,找到的话就返回,找不到就返回找不到。

3.Http
3.1什么是Http
HTTP(超文本传输协议)是一个简单的请求-响应协议,它通常运行在TCP之上。
- TCP:传输控制协议(TCP,Transmission Control Protocol)是一种面向连接的、可靠的、基于字节流的传输层通信协议。
- 文本:html,字符串…
- 超文本:图片,音乐,视频,定位,地图…
- 默认端口:80
HTTPS:安全的协议 - 默认端口:443
3.2http的两个时代
- http1.0:客户端可以与web服务器连接后,只能获得一个web资源,断开连接。
- http2.0:客户端可以与web服务器连接后,可以获得多个web资源。
3.3http请求
客户端—->发请求(request)—->服务器(比如:访问百度)
百度F12查看(拿百度举例,其他网站也可以)
General
1 | 1. Request URL: https://www.baidu.com/` // 请求地址 |

3.3.1请求行
- 请求行中的请求方式:GET
- 请求方式:Get,Post,HEAD,DELETE,PUT…
GET:请求能够携带的参数比较少,大小有限制,会在浏览器的URL地址栏显示数据内容,不安全,但高效。
POST:请求能够携带的参数没有限制,大小没有限制,不会在浏览器的URL地址栏显示数据内容,安全,但不高效。 - 一般用到get和post比较多
3.3.2请求头(消息头)
1 | Accept: 告诉浏览器,它所支持的数据类型 |
3.4http响应
同是百度里找到:
// 缓存控制
Cache-Control: no-cache
// 保持连接(http1.1)
Connection: keep-alive
// 文本编码类型
Content-Encoding: gzip
// 响应类型
Content-Type: text/html;charset=utf-8
3.4.1响应体
1 | Accept: 告诉浏览器,它所支持的数据类型 |
3.4.2响应状态码(重点)
200:响应成功
3xx:请求重定向(304等等)
—–>>>重定向:你重新给我到你新位置去。
4xx:找不到资源(404等等)
—–>>>资源不存在
5xx:服务器代码错误(500代码错误,502网关错误)






