首页 > 其他分享 >WebService入门教程_HTTP协议学习

WebService入门教程_HTTP协议学习

时间:2023-03-24 18:02:47浏览次数:28  
标签:WEB HTTP 浏览器 WebService 入门教程 响应 服务器 请求



实现

HTTP简介

WEB浏览器与WEB服务器之间的一问一答的交互过程必须遵循一定的规则,这个规则就是HTTP协议。
HTTP是 hypertext transfer protocol(超文本传输协议)的简写,它是 TCP/IP 协议集中的一个应用层协议,用于定义WEB浏览器与WEB服务器之间交换数据的过程以及数据本身的格式。
HTTP协议的版本 HTTP/1.0、HTTP/1.1、HTTP-NG

HTTP的会话方式

WebService入门教程_HTTP协议学习_HTTP

浏览器与WEB服务器的连接过程是短暂的,每次连接只处理一个请求和响应。对每一个页面的访问,浏览器与WEB服务器都要建立一次单独的连接。 
浏览器到WEB服务器之间的所有通讯都是完全独立分开的请求和响应对。

HTTP1.0与HTTP1.1

WebService入门教程_HTTP协议学习_数据_02

HTTP请求概述

客户端连上服务器后,向服务器请求某个web资源,称之为客户端向
服务器发送了一个HTTP请求。

一个完整的HTTP请求包括如下内容:
 1.请求行
2. 若干消息头
 3.实体内容(可能没有),如下所示 :

WebService入门教程_HTTP协议学习_服务器_03

请求行

请求行中的GET称之为请求方式,请求方式有:
POST、GET、HEAD、OPTIONS、DELETE、TRACE、PUT
常用的有: GET、 POST
用户如没有设置,默认情况下浏览器向服务器发送的都是get请求,例如在浏览器直接输地址访问,点超链接访问等都是get,用户如想把请求方式改为post,可通过更改表单的提交方式实现。
不管POST或GET,都用于向服务器请求某个WEB资源,这两种方式的区别主要表现在数据传递上:
如请求方式为GET方式,则可以在请求的URL地址后以?的形式带上交给服务器的数据,多个数据之间以&进行分隔,例如:
GET/mail/1.html?name=abc&password=xyz HTTP/1.1
GET方式的特点:在URL地址后附带的参数是有限制的,其数据容量通常不能超过1K。
如请求方式为POST方式,则可以在请求的实体内容中向服务器发送数据,Post方式的特点:传送的数据量无限制。

请求头

常用请求头(浏览器发送给服务器的数据,为了告诉服务器一些情况)

Accept: text/html,image/*    我支持的数据类型
 Accept-Charset: utf-8  支持的数据的编码字符集
 Accept-Encoding: gzip 支持的压缩方式
 Accept-Language: en-us,zh-cn 支持的语言
 Host: localhost:8888 请求的主机名
 Referer: http://www.badao.com/index.jsp 发送请求的界面对应的url 防盗链
 User-Agent: Mozilla/4.0 浏览器的相关信息
 Connection: keep-Alive   请求完成后,到是断开呢还是连接着
 Date: Tue, 11 Jul 2019 18:23:51 GMT 发送请求的时间
 Cookie: tt=123

请求体

  GET请求:没有请求体
  POST请求:如果form表单提交的方式为post,则表单项的数据以请求体的形式发送给服务器,没有大小限制

HTTP响应概述

一个HTTP响应代表服务器向客户端回送的数据,它包括: 一个状态行 若干消息头(响应头) 实体内容 (响应体)

WebService入门教程_HTTP协议学习_数据_04

响应状态行

状态行
 格式: HTTP版本号 状态码 原因叙述
 举例:HTTP/1.1 200 OK

WebService入门教程_HTTP协议学习_服务器_05

响应头

响应头(浏览器发送给服务器的数据,为了告诉服务器一些情况):

Location: /test/index.jsp  告诉浏览器重新定向到指定的路径
 Server:apache tomcat 使用的什么web服务器
 Content-Encoding: gzip  告诉浏览器我传给你的数据用的压缩方式
 Content-Length: 80 响应体的字节数
 Content-Language: zh-cn 响应体数据的语言
 content-type: text/html; charset=GB2312 响应体内容的类型 html/ css / image
 Last-Modified: Tue, 11 Jul 2019 18:23:51 GMT 资源最后被修改的时间
 Refresh: 1定时刷新
 Content-Disposition: attachment; filename=aaa.zip 提示用户下载
 Set-Cookie:SS=Q0=5Lb_nQ; path=/search 将cookie数据回送给ie
 Expires: -1  告诉浏览器不要缓存起来 
 Cache-Control: no-cache 
 Pragma: no-cache  
 Connection: close/Keep-Alive   是否保持连接
 Date: Tue, 11 Jul 2019 18:23:51 GMT 响应的时间

响应体

浏览器真正显示的数据,一般情况下为一个html格式的文本,也可以是其它类型的数据

标签:WEB,HTTP,浏览器,WebService,入门教程,响应,服务器,请求
From: https://blog.51cto.com/BADAOLIUMANGQZ/6147628

相关文章