HTTP协议

HTTP协议

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

HTTP简单介绍

client连上webserver后,若想获得webserver中的某个web资源,需遵守一定的通讯格式,HTTP协议用于定义client与webserver通迅的格式。
WEB浏览器与WEBserver之间的一问一答的交互过程必须遵循一定的规则,这个规则就是HTTP协议。
HTTP是hypertext transfer protocol(超文本传输协议)的简写,它是TCP/IP协议集中的一个应用层协议,用于定义WEB浏览器与WEBserver之间交换数据的过程以及数据本身的格式。 
HTTP协议的版本号 
HTTP/1.0、HTTP/1.1
HTTP协议是学习JavaWEB开发的基石,不深入了解HTTP协议,就不能说掌握了WEB开发,更无法管理和维护一些复杂的WEB网站。深入理解HTTP协议,对管理和维护复杂的WEB网站、开发具有特殊用途的WEBserver程序具有直接影响。 

HTTP 1.0的会话方式 

四个步骤:

HTTP协议

浏览器与WEBserver的连接过程是短暂的,每次连接仅仅处理一个请求和响应。对每个页面的訪问,浏览器与WEBserver都要建立一次单独的连接。 

浏览器到WEBserver之间的全部通讯都是全然独立分开的请求和响应对。 

支持代理:

HTTP协议

HTTP 1.1与HTTP 1.0的比較 

HTTP 1.1的特点 

        在一个TCP连接上能够传送多个HTTP请求和响应  


多个请求和响应过程能够重叠进行


添加�了很多其它的请求头和响应头 

HTTP协议

在HTTP1.0协议中,client与webserver建立连接后,仅仅能获得一个web资源。

HTTP1.1协议,同意client与webserver建立连接后,在一个连接上获取多个web资源。

使用telnet举例说明。

安装IE浏览器插件HttpWatch,查看IE浏览器通过HTTP协议获取某个页面。

HttpWatch工具的使用

功能:监听和截获本地机器每次向server发送的http请求数据和server向本地机器返回的http响应数据。

下载:http://www.httpwatch.com/

下载后,直接双击下载文件安装就可以。之后打开IE浏览器,选择“工具”→“浏览器栏”→“HttpWatch Professional”。

这样操作之后,就能够打开HttpWatch工具了。

HTTP协议

HTTP协议

浏览器訪问多图网页的过程

HTTP协议

一个web页面中,使用img标签引用了三幅图片,当client訪问server中的这个web页面时,client总共会訪问几次server,即向server发送了几次HTTP请求。

HTTP请求消息

client连上server后,向server请求某个web资源,称之为client向server发送了一个HTTP请求。一个完整的HTTP请求包含例如以下内容:

一个请求行、若干消息头、以及实体内容,例如以下所看到的 :

HTTP协议

请求消息的结构:

一个请求行、若干消息头、以及实体内容,当中的一些消息头和实体内容都是可选的,消息头和实体内容之间要用空行隔开。 

HTTP协议

HTTP请求的细节——请求行

请求行中的GET称之为请求方式,请求方式有:

POST、GET、HEAD、OPTIONS、DELETE、TRACE、PUT

经常使用的有: GET、 POST

用户如没有设置,默认情况下浏览器向server发送的都是get请求,比如在浏览器直接输地址訪问,点超链接訪问等都是get,用户如想把请求方式改为post,可通过更改表单的提交方式实现。

无论POST或GET,都用于向server请求某个WEB资源,这两种方式的差别主要表如今数据传递上:

如请求方式为GET方式,则能够在请求的URL地址后以?的形式带上交给server的数据,多个数据之间以&进行分隔,比如:

GET /mail/1.html?name=abc&password=xyz HTTP/1.1

GET方式的特点:在URL地址后附带的參数是有限制的,其数据容量通常不能超过1K。

如请求方式为POST方式,则能够在请求的实体内容中向server发送数据,Post方式的特点:传送的数据量无限制。

HTTP请求的细节——消息头

用于HTTP请求中的经常使用头

Accept: text/html,image/*    

Accept-Charset: ISO-8859-1

Accept-Encoding: gzip,compress

Accept-Language: en-us,zh-cn 

Host: www.it315.org:80

If-Modified-Since: Tue, 11 Jul 2000 18:23:51 GMT

Referer: http://www.it315.org/index.jsp

User-Agent: Mozilla/4.0 (compatible; MSIE 5.5; Windows NT 5.0)

Cookie

Connection: close/Keep-Alive   

Date: Tue, 11 Jul 2000 18:23:51 GMT

HTTP响应

一个HTTP响应代表server向client回送的数据,它包含:


一个状态行、若干消息头、以及实体内容 。

HTTP协议

HTTP协议

HTTP响应的细节——状态行

状态行


格式: HTTP版本 状态码 原因叙述<CRLF>


举例:HTTP/1.1 200 OK

状态码用于表示server对请求的处理结果,它是一个三位的十进制数。响应状态码分为5类,例如以下所看到的:

HTTP协议

响应状态码典型情况

200(正常) 

表示一切正常,返回的是正常请求结果。

302/307(暂时重定向)

指出被请求的文档已被暂时移动到别处,此文档的新的URL在Location响应头中给出。

304(未改动)

表示客户机缓存的版本号是最新的,客户机应该继续使用它。

403(禁止) 

server理解client请求,但拒绝处理它。通常因为server上文件或文件夹的权限设置所致。 

404(找不到) 

server上不存在客户机所请求的资源。

500(内部server错误) 

server端的CGI、ASP、JSP等程序错误发生。 

HTTP响应细节——经常使用响应头

Location: http://www.it315.org/index.jsp 

Server:apache tomcat

Content-Encoding: gzip 

Content-Length: 80 

Content-Language: zh-cn 

Content-Type: text/html; charset=GB2312 

Last-Modified: Tue, 11 Jul 2000 18:23:51 GMT

Refresh: 1;url=http://www.it315.org

Content-Disposition: attachment; filename=aaa.zip

Transfer-Encoding: chunked  

Set-Cookie:SS=Q0=5Lb_nQ; path=/search

ETag: W/”7777-1242234904000″

Expires: -1

Cache-Control: no-cache  

Pragma: no-cache   

Connection: close/Keep-Alive   

Date: Tue, 11 Jul 2000 18:23:51 GMT

扩展头 

在HTTP消息中,也能够使用一些在HTTP 1.1正式规范里未定义的头字段,这些头字段统称为自己定义的HTTP头或扩展头,它们通常被当作是一种实体头处理。

如今流行的浏览器实际上都支持Cookie、Set-Cookie、Refresh和Content-Disposition等几个经常使用的扩展头字段。

Refresh头字段

Refresh: 1 

Refresh: 1;url=http://www.it315.org

Content-Disposition头字段   


Content-Type: application/octet-stream


Content-Disposition: attachment; filename=aaa.zip


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118794.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • sql prompt linux,SQL PROMPT的设置[通俗易懂]

    sql prompt linux,SQL PROMPT的设置[通俗易懂]–10g中一般的SQLPROMPT都是’>’,为了让我们的提示符显示的更有意义,以便我们在做一些操作时可以明确我们所处的位置,采用以下方法,更改我们的SQLPROMPT。SQL>DEFINEDEFINE_DATE=”12-3月-09″(CHAR)DEFINE_CONNECT_IDENTIFIER=”orcl”(CHAR)DEFINE_USE…

    2022年7月26日
    7
  • html限制输入文本长度_get请求url长度限制多少位

    html限制输入文本长度_get请求url长度限制多少位http响应报文,如果响应的内容比较大,客户端怎么样判断接收完了呢?1.http协议有正文大小说明的content-length2.或者分块传输chunked的话读到0\r\n\r\n就是读完了http响应内容比较大的话,会分成多个tcpsegment发送,不是最后一个segment的话,tcp的payload不会有httpheader字段,如果是最后一个tcpse…

    2022年8月24日
    6
  • 【毕业项目】基于VUE开发的电商后台管理系统

    【毕业项目】基于VUE开发的电商后台管理系统摘要随着我国互联网普及率的提高,电子商务发展插上了腾飞的翅膀,一路高歌猛进。本后台系统旨在借助先进的计算机、快捷的网络以及庞大的云数据存储来帮助电商更加方便的统计电商数据。本系统以html、css、javascript作为开发语言。采用前后端分离思想,PC端使用Vue.js框架,服务端采用node.js作为开发平台,Webpack为静态模块打包器,Element-ui为UI组件,less为CSS预处理语言,ES6作为规范。PC端包含用户管理模块、权限管理模块、角色管理模块、商品管理模块、分类参数管理

    2022年6月13日
    39
  • ASP开发中存储过程应用全接触

    ASP开发中存储过程应用全接触

    2021年7月25日
    53
  • ajax的跨域请求_js解决跨域问题

    ajax的跨域请求_js解决跨域问题什么是AJAX?AJAX是无需刷新页面就能够从服务器去的数据的一种方法,负责Ajax运作的核心对象是XMLHttpRequest(XHR)对象。同源策略是对XHR的一个主要约束,它为通信设置了“相同的域、相同的端口、相同的协议”这一限制。试图访问上述限制之外的资源都会引发安全错误,除非采用被认可的跨域解决方案。这个方案叫做CORS(Cross-OriginResourceSharing)跨源…

    2022年8月24日
    8
  • 限制允许某些IP访问服务器

    限制允许某些IP访问服务器

    2021年10月18日
    43

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号