JavaWeb学习笔记(一)------基本概念,Tomcat
基本概念
架构
- B/S:浏览器和服务器
- C/S:客户端和服务器
web开发
-
web,网页的意思,www.baidu.com
-
静态web
- html,css
- 提供给所有人看的数据始终不会发生变化
-
动态web
- 每个人在不同时间,不同地点,看到的信息各不相同!
- 例如:淘宝。几乎所有的网站都是动态的
- 技术栈:Servlet/JSP,ASP,PHP
-
在Java中,动态web资源开发的技术,统称为JavaWeb
web应用程序
web应用程序:可以提供浏览器访问的程序;
-
例如:a.html、b.html…多个web资源,这些web资源可以被外界访问,对外界提供服务
-
可以访问到的任何一个页面或者资源,都存在于这个世界某一个角落的计算机上。
-
URL
-
这些统一的web资源会被放在同一个文件夹下,就是一个web应用程序—>依赖于Tomcat:服务器
-
一个web应用由多部分组成(静态web,动态web)
- html,css,js
- jsp,servlet
- java程序
- jar包
- 配置文件(properties)
web应用程序编写完毕后,若想提供给外界访问:需要一个服务器来统一管理
静态web
- 例如:*.htm, *.html,这些都是网页的后缀,如果服务器上一直存在这些东西,我们就可以直接进行读取。通过网络
静态web存在的缺点
- Web页面无法动态更新,所有用户看到的都是同一个页面。
- 轮播图,点击特效:伪动态
- 让静态页面能动起来的两种技术:JavaScript【用的较多】,VBScript
- 无法和数据库交互(数据无法持久化,用户无法交互)
动态web
- 页面会动态展示:Web页面的展示效果因人而异
动态web存在的缺点
- 假如服务器的动态web资源出现了错误,我们需要重新编写我们的后台程序。例如:停机维护
动态web存在的优点
- Web可以动态更新,所有用户看到的都不是同一个页面
- 可以与数据库交互(数据持久化:注册,商品信息,用户信息…)
web服务器
技术讲解
ASP
-
微软:国内最早流行的就是ASP;
-
在HTML中嵌入了VB的脚本,ASP+COM;
-
在ASP开发中,基本一个页面都有几千行的业务逻辑代码,页面及其混乱
-
维护成本高
-
主要使用C#
-
IIS开发
PHP
- PHP开发速度很快,功能很强大,而且跨平台,代码很简单(70%的平台都是中小型,WP)
- 无法承载大访问量的情况(局限性)
- 停留在中小型开发
JSP/Servlet
- SUN公司主推的B/S架构
- 基于Java语言的(所有的大公司或一些开源组件,都是用Java写)
- 可以承载高并发,高可用,高性能带来的影响
- 语法和ASP非常相似,加强市场强度
Web服务器
- 服务器是一种被动的操作,用来处理用户的一些请求和给用户一些相应信息
IIS
- 用于运行微软的一些东西,ASP…Windows中自带的
Tomcat
- 面向百度编程
- Tomcat是Apache软件基金会 (Apache Software Foundation)的Jakarta项目中的一个核心项目,最新的
Servlet和SP规范总是能在Tomcat中得到体现,因为Tomcat技术先进、性能稳定,而且免费,因而深受Java爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。
Tomcat服务器是一个免费的开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试ISP程序的首选。对于一个ava初学web的人来说,它是最佳的选择
Tomcat实际上运行ISP页面和Servlet。Tomcat最新版本为9.0。 - 工作3-5年后,可以尝试手写Tomcat服务器
下载Tomcat
- 安装or解压
- 了解配置文件及目录结构
- 了解这个东西的作用
Tomcat
安装Tomcat
- Tomcat官网
- 解压下载后得到的安装包
Tomcat启动和配置
-
文件夹信息
-
启动,关闭Tomcat
-
启动成功(Java环境配置好,不需要单独配置Tomcat文件)
可能遇到的问题
-
Java环境变量没有配置(会闪退)
-
闪退问题:需要配置兼容性
-
乱码问题:配置文件中的设置(一般情况下不去改bat文件),可以把编码方式改成BAT
配置文件中可以配置启动的端口号
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
- tomcat的默认端口号为:8080
- mysql默认端口号:3306
- http默认端口号:80
- https默认端口号:443
配置文件中可以配置主机的名称
<Host name="localhost" appBase="webapps"
unpackWARs="true" autoDeploy="true">
- 默认的主机名为:localhost = 127.0.0.1
- 默认的网站应用存放的位置为:webapps
高难度面试题
- 请你谈谈网站是如何进行访问的?(三次握手)
- 第一步:输入域名,点击回车
- 第二步:检查本机的配置文件下{C:\Windows\System32\drivers\etc\hosts},有没有这个域名的映射;
- 如果有:直接返回对应ip地址,这个地址中,有我们需要访问的web程序,可以直接访问
- 如果没有:去DNS服务器找,找到就返回,找不到就返回网页走丢了
- DNS:全世界的域名都在这里管理
发布一个web网站
-
可以访问localhost:8080\examples,仿照其中的例子进行学习
-
将自己写的网站,放到服务器(Tomcat)中指定的文件夹(webapps),就可以访问了
-
网站应该有的结构
--webapps:Tomcat服务器的web目录
-ROOT
-网站目录名
- WEB-INF
- classes:java程序
- lib:web应用所依赖的jar包
- web.xml:网站配置文件
- index.html:默认的首页
- static
- css
-style.css
- js
- img
HTTP协议
什么是HTTP
HTTP(超文本传输协议)是一个简单的请求-相应协议,它通常运行在TCP之上。
- 文本:html,字符串,…
- 超文本:图片,音乐,视频,定位,地图,…
Https:安全的
两个时代
http1.0
- HTTP/1.0:客户端可以与web服务器连接后,只能获得一个web资源,之后就断开连接
http2.0
- HTTP/1.1:客户端可以与web服务器连接后,可以获得多个web资源。
Http请求
- 客户端-----发请求(Request)-----服务器
- 百度的请求
请求 URL: https://www.baidu.com/
请求方法: GET (get/post)
状态代码: 200 OK
远程地址: 112.80.248.75:443
- 请求标头(request heading)
Accept: text/html
Accept-Encoding: gzip, deflate, br 类型编码
Accept-Language: zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6 语言
Cache-Control: max-age=0
Connection: keep-alive
请求行
- 请求行中的请求方式:GET
- 请求方式:GET/POST,HEAD,DELETE,PUT,TRACT…
- GET:一次请求能够携带的参数比较少,大小有限制,会在浏览器的URL地址栏显示数据内容,不安全但更高效
- POST:一次请求能够携带的参数没有限制,大小没有限制,不会再浏览器的URL地址栏显示数据内容,安全但不高效
消息标头
Accept:告诉浏览器,它所支持的数据类型
Accept-Encoding:支持哪种编码格式 GBK UTF-8 GB2312 ISO8859-1
Accept-Language:告诉浏览器,它的语言环境
Cache-Control:缓存控制
Connection:告诉浏览器,请求完成是断开还是保持连接
HOST:主机
Http响应
-
服务器-----响应-----客户端
-
百度的响应
Cache-Control: private 缓存控制
Connection: keep-alive 连接:保持连接
Content-Encoding: gzip 编码
Content-Type: text/html;charset=utf-8 类型
响应体
Accept:告诉浏览器,它所支持的数据类型
Accept-Encoding:支持哪种编码格式 GBK UTF-8 GB2312 ISO8859-1
Accept-Language:告诉浏览器,它的语言环境
Cache-Control:缓存控制
Connection:告诉浏览器,请求完成是断开还是保持连接
HOST:主机
Refresh:告诉客户端,多久刷新一次
Location:让网页重新定位
响应状态码(重点)
-
200:请求响应成功
-
3xx:请求重定向
- 重定向:重新到给定的新位置去
-
4xx:找不到资源 404
- 资源不存在
-
5xx:服务器代码错误 500
- 502:网关错误
常见面试题
- 当你的浏览器中地址栏输入地址并回车的一瞬间,到页面能够展示回来,经历了什么?
-
- 域名解析
- 发起TCP的三次握手
- 建立起TCP连接后发起http请求
- 服务器响应http请求,浏览器得到html代码
- 浏览器解析html代码,并请求html代码中的资源(css JavaScript 图片)
- 浏览器对页面进行渲染呈现