web基础与HTTP协议

目录

1.web基础与HTTP协议

2.域名的概念

3.早期使用Hosts文件解析域名

域名小结

4.域名注册

5.网页的概念

6.Web概述

7.Web1.0 vs Web2.0

8.静态页面 与动态页面

9.HTTP协议简介

10.cookie和session扩展

11.HTTP 请求格式( GET / POST 方式 )

12.GET 与POST 区别

13.HTTP状态码

14.HTTP协议请求流程分析【图2】


1.web基础与HTTP协议

web基础

HTTP协议

2.域名的概念

ip地址不容易记忆

3.早期使用Hosts文件解析域名

主机名称重复

主机维护困难

DNS(Domain Name System域名系统)

分布式

web基础与HTTP协议_第1张图片

 层次性

.根域

. 顶级域 

  .组织域

  .国家/地区域名

.二级域名

.FQDN=主机名.DNS后缀

web基础与HTTP协议_第2张图片

域名小结

1、网络上交互是基于TCP/IP协议的,每个主机在逻辑上有一个唯一位置标识(IP地址),物理地址为MAC地址 2、为了保证地址唯一性,用户协议向特地给机构申请注册,分配IP地址网络中的地址有两套方案: ① IP地址系统 ② 域名地址系统 而由于IP是由32位二进制数字标识,不方便记忆,所以 以IP地址为基础发展出了符号化地址来代替解决方案,也是是域名

4.域名注册

阿里云域名怎么申请 申请 查询重名 给钱20-60块 备案(阿里云)拍照(负责人拍照人) 10-20天 申请之后就可以解析和用 但是如果有问题 会被封

域名注册是Internet中用于解决地址对应问题的一种方法 遵循先申请先注册原则 域名注册步骤: 准备申请资料————》寻找域名注册网站————》查询域名————》正式申请————》申请成功

5.网页的概念

1.网页: 纯文本格式文件 编写语言为HTML 在用户的浏览器中被“翻译”成网页形式显示出来

2.网站:由一个一个页面构成的,是多个网页的结合体 主页 打开网站后出现的第一个网页称为网站主页(或首页)

3.域名 : 浏览网页时输入的网址

4.HTTP/HTTPS: 用来传输网页的通信协议(是否加密),是一种通讯/交互的标准/规范

5.URL : 是一种万维网寻址系统

6.HTML : 用来编写网页的超文本标记语言

7.超链接 : 超链接是将网站中不同网页链接起来的功能

8.发布: 将制作好的网页上传到服务器供用户访问的过程

6.Web概述

Web(World Wide Web)即全球广域网,也称为万维网 一种分布式图形信息系统 建立在Internet上的一种网络服务

万维网并非某种特殊的计算机网络,是一个大规模的、联机式的信息贮藏库,使用链接的方法能非常方便地从因特网上的一个站点访问另一个站点(超链技术),具有提 供分布式服务的特点。万维网是一个分布式的超媒体系统,是超文本系统的扩充,基于B/S架构实现

web基础与HTTP协议_第3张图片

URL:万维网使用统一资源定位符(Uniform Resource Locator)来标志万维网上的各种文档,并使每个文档在整个因特网的范围内具有唯一的标识符URL。

7.Web1.0 vs Web2.0

Web1.0 以编辑为特征,网站提供给用户的内容是编辑处理后的,然后用户阅读网站提供的内容 这个过程是网站到用户的单向行为

Web2.0

更注重用户的交互作用,用户既是网站内容的消费者(浏览者),也是网站内容的制造者 加强了网站与用户之间的互动,网站内容基于用户提供,网站的诸多功能也由用户参与建设,实现了网站与用户双向的交流与参与

Web2.0特征

用户分享、以兴趣

为聚合点的社群、开放的平台,活跃的用户

8.静态页面 与动态页面

1. 静态页面定义

① 静态网页是标准的HTML文件

② 扩展名是.htm、.html 例如文本、图像、声音、Flash动画、客户端脚本和ActiveX控件及Java小程序等

③ 是网站建设的基础,早期网站一般都由静态网页制作

④ 没有后台数据库、不含程序和不可交互的网页

⑤ 相对更新起来比较麻烦,适用于一般更新较少的展示型网站

 2.动态页面

① 网页 URL不固定,能通过后台与用户交互

② 在动态网页网址中有一个标志性的符号——“?” ③ 常用的语言有PHP、JSP、Python、Ruby等

3. 动态页面特点

① 交互性 网页会根据用户的要求和选择而动态改变和响应,将浏览器作为客户端界面,这将是今后WEB发展的大势所趋

② 自动更新 无须手动地更新HTML文档,便会自动生成新的页面,可以大大节省工作量

③ 因时因人而变 当不同的时间,不同的人访问同一网址时会产生不同的页面

总结:

静态页面由于很多内容都是固定的,在功能方面有很大的限制,所以交互性较差

动态网页则可以实现更多的功能,如用户的登录、注册、查询等

9.HTTP协议简介

HTTP(超文本传输协议HyperText Transfer Protocol)协议是互联网上应用最为广泛的一种网络协议,它是基于TCP协议的应用层传输协议,简单来说就是客户端和服务端进行数据传输的一种规则。

HTTP/HTTPS是应用层上的协议,建立在传输层TCP之上,客户端通过与服务端进行TCP连接(三次握手),之后发送HTTP请求与接收HTTP响应都是通过访问Socket接口来调用TCP协议实现。

HTTP 是一种无状态 (stateless) 协议, HTTP协议本身不会对发送过的请求和相应的通信状态进行持久化处理(存储,保存)。这样做的目的是为了保持HTTP协议的简单性,从而能够快速处理大量的事务, 提高效率。

无动态 :每天都干一件事就是无状态

有状态: 每天都把干的事干一遍 、再往干的事里加点东西 就是有状态

10.cookie和session扩展

然而,在许多应用场景中,我们需要保持用户登录的状态或记录用户购物车中的商品。由于HTTP是无状态协议,所以必须引入一些技术来记录管理状态,例如Cookie。

cookie和session都为了实现的是http的短期的持久化(内存/缓存方式,查询快、效率比较高)cookie 是缓存在用户端(client)浏览器中的(默认缓存一天),当下次客户端通过同一个浏览器访问客户端的时候,会优先读取cookie中的缓存信息,向服务端进行请求,同时服务端收到客户端请求的时候,读取到cookie文件,知道客户端之前找的是服务器A处理的任务,为了省事儿,省资源,干脆直接讲请求直接再交给服务器A处理 两者对比: cookie 省服务器性能 session 更安全

  1. 为后面服务、集群、功能优化做铺垫

  2. 具体解释了怎么解决HTTP无状态协议的持久化/存储。

扩展面试

HTTP1.0和HTTP1.l之间的区别 ① 缓存处理 在HTTP1.0中主要使用header里的If-Modified-Since,Expires来做为缓存判断的标准,HTTP1.1则引入了更多的缓存控制策略例如Entitytag,If-Unmodified-Since,If-Match,If-None-Match等更多可供选择的缓存头来控制缓存策略。

11.HTTP 请求格式( GET / POST 方式 )

GET 方式

① 请求行 请求的方式 请求的资源路径 请求的版本协议号

② 请求头(描述信息/标准化信息) Accept:客户端可以接受的数据类型 Accept-Language:客户端可以接受的语言类型 User-Agent:浏览器的信息 Accpect-Encoding:客户端可以接受的编码格式 Host:表示请求的ip和端口号 Connection:告诉服务器请求连接如何处理 Keep-Alive:通知服务器回传数据不要马上关闭,保持一小段的连接 Closed:马上关闭

 POST 请求方式

① 请求行 请求的方式 请求的资源路径 请求的协议的版本号

② 请求头

Accept:客户端可以接受的数据类型 Accept-Language:客户端可以接受的语言类型 Referer:表示请求发起时,浏览器地址栏中的地址 User-Agent:浏览器的信息 Content-Type:发送的数据类型 Content-Length:发送的数据长度

③ 请求体:就是发送给服务器的数据

web基础与HTTP协议_第4张图片

 web基础与HTTP协议_第5张图片

12.GET 与POST 区别

① 区别一:语义上的区别 Get向服务器请求数据,依照HTTP协议,get 是用来请求数据。 Post向服务器发数据,依照HTTP协议,Post的语义是向服务器添加数据,也就是说按照Post的语义,该操作是会修改服务器上的数据

② 区别二:服务器请求的区别 Get请求是可以被缓存,示例: 访问百度,访问的方式就是GET,此时访问后的内容会缓被存在浏览器中,短时间再次访问,其实是拿到的浏览器中的缓存内容 另外Get请求只能接收ASCII码的回复 Post请求是不可以被缓存的。对于Post方式提交表单,刷新页面浏览器会弹出提示框“是否重新提交表单”, Post可以接收二进制等各种数据形式,所以如果要上传文件一般用Post请求

③ 区别三:参数放请求头和请求体的差别 Get请求通常没有请求体(当然这也是可以由程序猿心情改变的),在TCP传输中只需传输一次(而不是一个包), 所以Get请求效率相对高。 Post请求将数据放在请求体中,而实际传输中,会先传输完请求头,再传输请求体,是分为两次传输的(而不是两个包)。 Post请求头会比Get更小(一般不带参数),请求头更容易在一个TCP包中完成传输,更何况请求头中有Content-Length的标识,可以更好地保证Http包的完整性。

简单的理解: ###GET方法: 从指定的服务器上获得数据 GET请求能被缓存 GET请求会保存在浏览器的浏览纪录里(cookit) GET请求有长度的限制 主要用于获取数据 查询的字符串会显示在URL中,不安全

###POST方法: 提交数据给指定服务器处理 POST请求不能被缓存 POST请求不会保存在浏览器的浏览纪录里 POST请求没有长度限制 查询的字符串不会显示在URL中,比较安全

HTTP状态码

当使用浏览器访问某一个URL,会根据处理情况返回相应的处理状态 通常正常的状态码为2xx,3xx(如200) 如果出现异常会返回4xx,5xx(如404)

状态码首位 已定义范围 分类 1xx 100-101 信息提示 2xx 200-206 成功 3xx 300-305 重定向 4xx 400-415 客户端错误 5xx 500-505 服务器错误

生产环境常见的HTTP状态码 消息 描述 200 OK 请求成功(其后是对GET和POST请求的应答文档) 301 Moved Permanently 请求的永久页面跳转 403 Forbidden 禁止访问该页面 404 Not Found 服务器无法找到被请求的页面 500 Internal Server Error 内部服务器错误 502 Bad Gateway 无效网关 503 Service Unavailable 当前服务不可用 504 Gateway Timeout 网关请求超时

状态码大全地址:https://product.pconline.com.cn/itbk/software/llq/1508/6862518.html

13.HTTP状态码

当使用浏览器访问某一个URL,会根据处理情况返回相应的处理状态

通常正常的状态码为2xx,3xx(如200)

如果出现异常会返回4xx,5xx(如404)

状态码首位    已定义范围     分类

1xx                 100-101         信息提示

2xx                  200-206         成功

3xx                   300-305        重定向

4xx                   400-415        客户端错误

5xx                   500-505         服务器错误

生产环境常见的HTTP状态码

消息     描述

200        OK                                  请求成功(其后是对GET和POST请求的应答文档)

301        Moved Permanently       请求的永久页面跳转

403         Forbidden                      禁止访问该页面

404         Not Found                      服务器无法找到被请求的页面

500         Internal Server Error       内部服务器错误

502         Bad Gateway                  无效网关

503         Service Unavailable       当前服务不可用

504         Gateway Timeout            网关请求超时

14.HTTP协议请求流程分析【图2】

web基础与HTTP协议_第6张图片

你可能感兴趣的:(http,网络,网络协议)