应用层
是七层OSI模型的第七层。应用层直接和应用程序接口并提供常见的网络应用服务。应用层也向表示层发出请求。应用层是开放系统的最高层,是直接为应用进程提供服务的。其作用是在实现多个系统应用进程相互通信的同时,完成一系列业务处理所需的服务。
HTTP协议
超文本传输协议,是一个属于应用层的面向对象的协议,由于其简捷、快速的方式,适用于分布式超媒体信息系统。
URL
我们平时看到的网址就是说的URL
urlencode和urldecode
像 / ? : 等这样的字符,已经被url当做特殊意义理解了。因此这些字符不能随意出现。
比如,某个参数中需要带有这些特殊字符,就必须先对特殊字符进行转义。
转义的规则如下:
将需要转码的字符转为16进制,然后从左右到左,取4位(不足4位直接处理),每2位做一位,前面加上%,编码成%XY格式
例如:
"++"就背转义为了"%2B%2B"
urldecode就是urlencode的逆过程
HTTP协议格式
HTTP请求报文
- HTTP请求由四部分构成,分别是:请求行,请求报头,空行,请求正文
- HTTP请求的属性(Header),是以冒号分割的键值对,每组属性之间使用\n分割;遇到空行标识Header部分结束
- 首行:[方法] + [url] + [版本]
- 空行后面的内容都是Body。Body允许为空字符串,如果Body存在,则在Header中会有一个Content-Length大户型来表示Body的长度。
HTTP响应报文
- 在接收和解释请求消息后,服务器返回一个HTTP响应消息。
- HTTP响应报文的组成:状态行,响应报头,空行,响应正文
- 首行:[版本号] + [状态码] + [状态码解释]
- Header:响应的属性,冒号分割的键值对,每组属性之间使用\n分割,遇到空行表示Header部分结束
- 空行后面的内容都是Body。Body允许为空字符串,如果Body存在,则在Header中会有一个Content-Length属性来表示Body的长度,如果服务器返回了一个html页面,那么html页面内容是在body中
请求方法 | 方法描述 |
GET | 请求获取Request-URI所标识的资源 |
POST | 从客户向服务器发送一些信息 |
HEAD | 请求获取资源的响应消息报头,请求的是关于文档的信息,而不是这个文档本身 |
DELETE | 请求服务器删除Request-URI所标识的资源 |
TRACE | 请求服务器回送收到的请求信息,主要用于测试或诊断 |
OPTIONS | 请求查询服务器的性能,或者查询与资源相关的选项和需求 |
PUT | 请求服务器存储一个资源,并用Request-URI作为其标识 |
LINK | 建立和资源之间的联系 |
UNLINE | 断开连接关系 |
- GET方法:在浏览器的地址栏中输入网址的方式访问页面时,浏览器采用GET方法向服务器获取资源。GET方法也可以向服务器传递参数,在wd后面的为传递的参数,常为搜索关键字等。
- POST方法:要求被请求的服务器接受附在请求后面的数据,常用于提交表单。
- HEAD方法:HEAD方法与GET方法几乎是一样的,对于HEAD请求的回应部分来说,它的HTTP头部中包含的信息与通过GET请求所得到的信息是相同的。利用这个方法,不必传输整个资源内容,就可以得到Request-URI所表示的资源的信息。该方法常用于测试超链接的有效性,是否可以访问,以及最近是否更新
HTTP的状态码
状态码由三位数字组成,第一个数字定义了响应的类别,他有五种可能取值:
- 1xx:指示信息-表示请求已接受,继续处理
- 2xx:成功-表示请求已被成功接受并处理
- 3xx:重定向-要完成请求必须进行更进一步的操作
- 4xx:客户端错误-请求有语法错误或请求无法实现
- 5xx:服务器端错误-服务器未能实现合法的请求
常见的状态码
- 200 OK:客户端请求成功
- 400 Bad Request:客户端请求有语法错误,不能被服务器所理解
- 401 Unauthorized:请求未经授权,这个状态码必须和WWW-Authenticate报头域一起使用
- 403 Forbidden:服务器收到请求,但是拒绝提供服务
- 404 Not Found:请求资源不存在,可能是输入了错误的URL
- 500 Internal Server Error:服务器发生不可预期的错误
- 503Server Unavailable:服务器当前不能处理客户端的请求,一段时间后可能恢复正常
HTTP常见Header
- Content-Type:数据类型(text/html等)
- Content-Length:Body的长度
- Host:客户端告知服务器,所请求的资源是在哪个主机的哪个端口上
- User-Agent:声明用户的操作系统和浏览器的版本信息
- referer:当前页面是从哪个页面跳转过来的
- location:搭配3xx状态码使用,告诉客户端接下来要去哪里访问
- Cookie:用于在客户端存储少量信息。通常用于实现会话(Session)的功能