2.Http基础
HTTP协议
概念
HTTP(HyperText Transfer Protocol):超文本传输协议是互联网上应用最为广泛的一种网络协议,所有WWW文件都必须遵守这个协议,从而约束请求与响应。
Http请求
请求方式
8种请求方式
- OPTIONS:返回服务器针对特定资源所支持的HTTP请求方法,也可以利用向web服务器发送‘*’的请求来测试服务器的功能性
- HEAD: 请求指定的页面信息,并返回头部信息
- GET: 请求指定的页面信息,并返回实体主体
- POST:向指定资源提交数据进行处理请求
- PUT:向指定资源位置上传其最新内容
- DELETE:请求服务器删除Request-URL所标识的资源
- TRACE:回显服务器收到的请求,主要用于测试或诊断
- CONNECT:HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器。
常用请求方式说明:
GET:
- GET 方法向页面请求发送参数
- 地址和参数信息中间用 ? 字符分隔,例如:http://www.taobao.com/hello?key1=value1&key2=value2
- 查询字符串会显示在地址栏的URL中,不安全,请不要使用GET请求提交敏感数据
- GET请求能够被缓存
- 只允许ASCII字符类型,不能用二进制流
- GET 方法有大小限制:请求字符串中最多只能有 1024 个字符
- 点击刷新时,不会有反应
- GET请求主要用以获取数据
POST:
- POST 方法向页面请求发送参数
- 使用POST方法时,查询字符串在POST信息中单独存在,和HTTP请求一起发送到服务器
- 没有历史记录
- 参数类型没有限制,可以是字符串也可以是二进制流
- 数据不会显示在地址栏中,也不会缓存下来或保存在浏览记录中,所以看POST求情比GET请求安全,但也不是最安全的方式。如需要传送敏感数据,请使用加密方式传输
- 查询字符串不会显示在地址栏中
- Post就是为了将数据传送到服务器段,Get就是为了从服务器段取得数据
- Post传输的数据量大,可以达到2M,而Get方法由于受到URL长度限制,只能传递大约1024字节.
请求行
请求行包括协议版本,请求方式及资源
请求头
请求头是客户端自动发给服务器的一些信息,用键值对来表示。
常见请求头 | 说明 |
---|---|
Refer | 浏览器通知服务器当前请求来自何处,如果直接访问则不会有这个头 |
Cookie | 用于浏览器存放Cookie信息 |
Host | 请求的服务器的主机名 |
Accept | 浏览器支持的MIME类型 |
ps:MIME为文件的一种描述方式
请求体
- 当请求方式是post时,请求体会有请求的参数
- 当请求方式时get时,请求参数不会出现在请求体中,而是拼接在URL地址后面
请求发送方式
- 通过浏览器的地址栏
- 通过html当中的form表单
- 通过a链接的href
- src属性
Http响应
状态码
常用
- 200 :请求成功
- 302 :请求重定向
- 304 :请求资源没有改变,访问本地缓存。
- 404 :请求资源不存在。通常是用户路径编写错误,也可能是服务器资源已删除。
- 500 :服务器内部错误。通常程序抛异常。
其他
- 请求成功以2开头 201 已创建
- 重定向以3开头 301 永久转移
- 客户端错误以4开头 408 请求超时
- 服务器端错误以5开头 501 未实现(Not Implemented)
响应行
协议+状态码
响应头
服务器端将信息以键值对的形式自动返回给客户端
常见响应头
- Location:指定响应的路径,需要与状态码302配合使用,完成跳转
- Content-Type:响应正文的类型(MIME类型)
- Content-Disposition:通过浏览器以下载方式解析正文
- Set-Cookie:服务器向浏览器写入cookie
- Refresh:定时刷新
- Server:服务器名称,默认值:Apache-Coyote/1.1。可以通过conf/server.xml配置进行修改
- Content-Encoding:服务器使用的压缩格式
响应体
响应体是服务器回写给客户端的页面正文,浏览器将正文加载到内存,然后解析渲染显示页面内容
通过conf/server.xml配置进行修改
- Content-Encoding:服务器使用的压缩格式
响应体
响应体是服务器回写给客户端的页面正文,浏览器将正文加载到内存,然后解析渲染显示页面内容