WebService入门教程_HTTP协议学习

场景

项目专栏:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/column/info/37726

实现

HTTP简介

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

HTTP的会话方式

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

HTTP1.0与HTTP1.1

HTTP请求概述

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

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

请求行

请求行中的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响应代表服务器向客户端回送的数据,它包括: 一个状态行 若干消息头(响应头) 实体内容 (响应体)

响应状态行

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

响应头

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

 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格式的文本,也可以是其它类型的数据


 


 


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

霸道流氓气质

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值