HTTP协议基础总结

2018-08-01  本文已影响0人  宠辱不惊丶岁月静好

一、HTTP协议概述

1、B/S网络结构

B/S结构(Browser/Server,浏览器/服务器模式),是WEB兴起后的一种网络结构模式,WEB浏览器是客户端最主要的应用软件这种模式统一了客户端,将系统功能实现的核心部分集中到了服务器上,简化了系统的开发、维护和使用,同时也大大简化了客户端的电脑载荷,减轻了系统维护与升级的成本和工作量。

2、HTTP协议概述

3、HTTP协议的特点

二、HTTP协议—URL

1、什么是URL?

2、URL各部分含义

三、HTTP协议—请求

1、HTTP请求的构成

http请求由三部分组成,分别是:请求行请求头请求正文

2、HTTP请求行的格式

3、从HTTP角度看GET和POST的区别?

在http协议中,get仅代表向服务器获取数据,post为发送(提交)数据,两者仅仅是含义不同;但是,大部分情况下,浏览器等客户端在实现协议的基础上,为了符合协议中的定义,对get及post做了相应的限制;

数据传输方式及大小方面:
在发送 get 请求时,参数需要写在URL地址后面,并且参数的大小也做了相应限制,浏览器厂商不同,大小限制也不相同;
但POST请求中,一般会在HTML的表单中写入数据,由浏览器自行组织数据格式放入请求体发送,而在ajax技术的实现中,需要将数据放进send方法传递;如果非要说有区别,那也仅仅是大部分情况下,get的数据在请求头,post数据在请求体;

安全性方面:
目前网上流行一种说法是 post相对来说要比get安全一些,其实这是错误的,我们不能愚昧的将眼睛能看到的视为不安全而眼睛看不到的视为安全;
真实的情况是 http 协议中,所有的数据传输方式,不仅仅是get和post ,包括put、delete、push等等,都是明文传输的,也就是说,相对https,http本身就是不安全的;
而两种传输方式在安全性上是没有可比性的;

对于传输数据类型:
网上还有一种说法是post可以做文件上传而get不可以;
对于协议角度来说并不准确,只是浏览器及服务器在实现上没有为get方式实现相应的功能而已;

工具实现协议,工具不能代表协议;

实现可以不遵循协议,但是实现不能修改协议;

面试问题:
http://www.laruence.com/2012/01/10/2469.html

4、HTTP请求头含义

报头名称 含义
User-Agent 用户代理,允许客户端将它的操作系统、浏览器和其它属性告诉服务器
Host 用于指定被请求资源的主机和端口号,它通常从TYYP URL中提取出来
Accept 用于指定客户端接受哪些类型的信息。如:image/gif、text/html、*/*(所有类型)
Accept-Language 指定客户端可以接收的语言类型
Accept-Encoding 指定可接受的内容压缩编码类型
Accept-Charset 用于指定客户端接受的字符集
Cookie 写到服务器端的COOKIE数据
Connection 连接类型。keep-alive(保持激活,短时间不断开,一般为30s),Close(立即断开)
Cache-control 控制缓存。no-cache(不缓存)
Referer 可以记录访问的来源,拥挤访问量,可以用来作防盗链

5、HTTP请求正文

POST方式发送的数据,才会有请求正文。

6、哪些HTML标记会自动发送请求?

四、HTTP协议—响应

1、HTTP响应的构成

HTTP响应也是由三个部分组成,分别是:状态行响应头响应正文

2、HTTP响应行的格式

3、HTTP响应状态码

状态代码有三位数字组成,第一个数字定义了响应的类别,且有五种可能取值

常见HTTP响应状态码含义:

状态码 含义
200 OK。请求已成功
301 永久移动,请求的地址被永久改变。由旧域名重定向到新域名。在服务器实现
302 Move temporarily请求的资源临时从不同的URL响应请求。由于这样的重定向是临时的,客户端应当继续向原有地址发送以后的请求
304 Not Modified文档的内容(自上次访问以来或者根据请求的条件)并没有改变
400 Bad Request语义有误,当前请求无法被服务器理解
401 Unauthorized当前请求需要用户验证
403 Forbidden服务器收到请求,但是拒绝提供此服务
404 Not Found请求支援不存在
408 Request Timeou请求超时
500 Internal Server Error服务器发生不可预知的错误
503 Server Unavailable服务器当前不能处理客户端的请求,一段时间后可能恢复正常

4、302状态码演示

302状态码,主要涉及header()函数的refresh和location

//网页跳转
header("location:./abc.html");

5、304状态码演示

304状态码表示文件内容没有改变,不需要再次从服务器下载该数据,直接从缓存读取。例如:图片等。

6、403状态码演示

403状态码:没有给网站的虚拟目录指定访问权限时,将返回403状态码。

7、404状态码演示

404状态码:代表访问的文件没有找到。

8、HTTP响应头含义

一个HTTP响应代表服务器给浏览器回送的数据,同时告诉浏览器应当怎样处理数据。

响应报头名称 含义
Date 告诉浏览器,请求页面的时间
Server 服务器软件信息
Content-Length 回送数据的字节数
Content-Type 回送内容的类型
Expires 表示存在时间,允许客户端在这个时间之前不去检查(发请求),等同max-age的效果。但是如果同时存在,则被Cache-Control的max-age覆盖
Pragma 缓存控制
Cache-Control 缓存控制
X-Powered-By 版权信息(程序支持)
Keep-Alive 连接类型
Location 响应报头域用于重定向到一个新的位置
Refresh 页面刷新时间
Last-modified 指定服务器上保存内容的最后修订时间
上一篇 下一篇

猜你喜欢

热点阅读