`
endual
  • 浏览: 3567253 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

HTTP协议及GET、POST的差异

    博客分类:
  • java
 
阅读更多

HTTP协议及GET、POST的差异

153人阅读 评论 (0) 收藏 举报

目录(?) [+]

摘选自吴秦:http://www.cnblogs.com/skynet/archive/2010/05/18/1738301.html

1、HTTP概述

为了唤醒你对HTTP协议的记忆或使你能够对HTTP协议有所了解,首先简单一下HTTP协议。超文本传输协议HTTPHyperText Transfer Protocol )是互联网 上应用最为广泛的一种网络协议 。所有的WWW 文件都必须遵守这个标准。设计HTTP最初的目的是为了提供一种发布和接收HTML 页面的方法。

HTTP的发展是万维网协会(World Wide Web Consortium )和Internet工作小组(Internet Engineering Task Force )合作的结果,(他们)最终发布了一系列的RFC ,其中最著名的就是RFC 2616RFC 2616 定义了HTTP协议中一个现今被广泛使用的版本——HTTP 1.1。

1.1、HTTP协议的客户端与服务器的交互

HTTP是一个客户端和服务器端请求和应答的标准(TCP )。客户端是终端用户服务器端是网站 。通过使用Web浏览器、网络爬虫或者其它的工具,客户端发起一个到服务器上指定端口(默认端口 为 80)的HTTP请求。(我们称这个客户端)调用户代理(user agent)。应答的服务器上存储着(一些)资源,比如HTML文件和图像。(我们称)这个应答服务器为源服务器(origin server)。在用户代理和源服务器中间可能存在多个中间层,比如代理,网关,或者隧道(tunnel)。尽管TCP/IP 协议是互联网上最流行的应用,HTTP协议并没有规定必须使用它和(基于)它支持的层。事实上,HTTP可以在任何其他互联网协议上,或者在其他网络上实现。HTTP只假定(其下层协议提供)可靠的传输,任何能够提供这种保证的协议都可以被其使用。

通 常,由HTTP客户端发起一个请求,建立一个到服务器指定端口(默认是80端口)的TCP连接。HTTP服务器则在那个端口监听客户端发送过来的请求。一 旦收到请求,服务器(向客户端)发回一个状态行,比如"HTTP/1.1 200 OK",和(响应的)消息,消息的消息体可能是请求的文件、错误消息、或者其它一些信息。

HTTP使用TCP而不是UDP的原因在于(打开一个)一个网页必须传送很多数据,而TCP 协议提供传输控制,按顺序组织数据,和错误纠正。通过HTTP或者HTTPS协议请求的资源由统一资源标识符 (Uniform Resource Identifiers,或者,更准确一些,URI)来标识。

客户端与服务器端的结构与交互过程可以表示为下面2张图:

图1、Web客户端-服务器端结构(其中web服务器的超文本链接,即通过网站上的一个链接跳转到了其他服务器上)

 

                     图2、Web客户端与服务器端的交互

 

1.2、HTTP消息

客户端与服务器之间的交互用到了两种类型的消息:请求(Request)响应(Response)

HTTP请求的格式为:

                                             图3、HTTP请求的格式

 

HTTP响应的格式为:

                                        图4、HTTP响应的格式

 

从上面可以看出HTTP的请求和响应消息的首部均包含可变数量的字段,用一个空行(blank line )将所有首部字段 (header)与消息主体 (body)分隔开来。一个首部字段由字段名和随后的冒号、一个空格和字段值组成,字段名不区分大小写

报文头可分为三类:一类应用于请求,一类应用于响应,还有一类描述主体。有一些报文头(例如:Date)既可用于请求又可用于响应。描述主体的报文头可以出现在POST请求和所有响应报文中。HTTP的首部字段如下图所示:

                                       图5、HTTP首部字段

 

1.3、HTTP请求的方法

HTTP/1.1协议中共定义了八种方法(有时也叫“动作”)来表明Request-URI 指定的资源的不同操作方式:

  • OPTIONS
    返回服务器针对特定资源所支持的HTTP请求方法。也可以利用向Web服务器发送'*'的请求来测试服务器的功能性。
  • HEAD
    向服务器索要与GET请求相一致的响应,只不过响应体将不会被返回。这一方法可以在不必传输整个响应内容的情况下,就可以获取包含在响应消息头中的元信息。
  • GET
    向特定的资源发出请求。注意:GET方法不应当被用于产生“副作用”的操作中,例如在Web Application 中。其中一个原因是GET可能会被网络蜘蛛 等随意访问。
  • POST
    向指定资源提交数据进行处理请求(例如提交表单或者上传文件)。数据被包含在请求体中。POST请求可能会导致新的资源的建立和/或已有资源的修改。
  • PUT
    向指定资源位置上传其最新内容。
  • DELETE
    请求服务器删除Request-URI 所标识的资源。
  • TRACE
    回显服务器收到的请求,主要用于测试或诊断。
  • CONNECT
    HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器。

方法名称是区分大小写的。当某个请求所针对的资源不支持对应的请求方法的时候,服务器应当返回状态码405(Method Not Allowed);当服务器不认识或者不支持对应的请求方法的时候,应当返回状态码501(Not Implemented)。

HTTP服务器至少应该实现GET和HEAD方法,其他方法都是可选的。此外,除了上述方法,特定的HTTP服务器还能够扩展自定义的方法。

 

1.4、HTTP响应的代码

 服务器程序响应的第一行叫状态行。状态行以HTTP版本号开始,后面跟着3位数字表示响应代码,最后是易读的响应短语。根据第一位可以把响应分成5类:

                                 图6、HTTP响应代码

2、GET与POST的差异

 

1.3中介绍了8种方法,其中GET与POST最基本和常用了。表单提交中get和post方式的区别归纳如下几点:

  • GET是从服务器上获取数据,POST是向服务器传送数据。
  • GET 是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到。POST是通过HTTP POST机制,将表单内各个字段与其内容放置在BODY内一起传送到ACTION属性所指的URL地址。用户看不到这个过程。
  • 对于GET方式,服务器端用Request.QueryString获取变量的值,对于POST方式,服务器端用Request.Form获取提交的数据。
  • GET传送的数据量较小,不能大于2KB(这主要是因为受URL长度限制)。POST传送的数据量较大,一般被默认为不受限制。但理论上,限制取决于服务器的处理能力。
  • GET 安全性较低,POST安全性较高。因为GET在传输过程,数据被放在请求的URL中,而如今现有的很多服务器、代理服务器或者用户代理都会将请求URL记 录到日志文件中,然后放在某个地方,这样就可能会有一些隐私的信息被第三方看到。另外,用户也可以在浏览器上直接看到提交的数据,一些系统内部消息将会一 同显示在用户面前。POST的所有操作对用户来说都是不可见的。

在FORM提交的时候,如果不指定Method,则默认为 GET请求(.net默认是POST),Form中提交的数据将会附加在url之后,以?分开与url分开。字母数字字符原样发送,但空格转换为“+” 号,其它符号转换为%XX,其中XX为该符号以16进制表示的ASCII(或ISO Latin-1)值。GET请求请提交的数据放置在HTTP请求协议头中,而POST提交的数据则放在实体数据中;GET方式提交的数据最多只能有2048字节,而POST则没有此限制 。POST传递的参数在doc里,也就http协议所传递的文本,接受时再解析参数部分。获得参数。一般用POST比较好。POST提交数据是隐式的,GET是通过在url里面传递的,用来传递一些不需要保密的数据,GET是通过在URL里传递参数,POST不是。

 

 

 

另他后面有http的一个深入keepalive模式:http://www.cnblogs.com/skynet/archive/2010/12/11/1903347.html

 

########################################################

########################################################

小记:

看HTTP相关内容一是因为对HTTP印象模糊,二是前段时间看struts被服务器具体如何响应请求这个问题卡住了。

HTTP协议可以看成是对请求和响应的数据格式都作了规定,(类似接口),具体不同的服务器可能有不同的实现,但响应的内容格式则必须符合协议规 定。Java中就是取得response的输出流,按照setContentType,write,flush,close流程把响应内容返回给客户端。

分享到:
评论

相关推荐

    Web应用安全:HTTP协议GET和POST的使用区别.pptx

    在Web应用安全中,了解HTTP协议的GET和POST方法的使用差异至关重要。GET和POST是HTTP协议中最基本的两种请求方法,它们各自有着特定的用途和限制。 1. GET方法: GET方法通常用于从服务器获取资源。在URL中,查询...

    Web应用安全:HTTP协议GET和POST的使用区别实验.docx

    ### Web应用安全:HTTP协议GET和POST的使用区别实验 #### 实验背景及目标 本实验旨在通过实际操作深入理解HTTP协议中POST方法的工作机制及其与GET方法的区别。实验将利用Firefox浏览器的Firebug插件以及Wireshark...

    Web应用安全:HTTP协议GET和POST的使用区别文本.docx

    GET和POST是HTTP协议中两种最常用的请求方法,它们各有特点,适用于不同的场景。 GET方法是HTTP中最常用的方法,主要用于获取资源信息。它是安全的,意味着执行GET请求不会改变服务器上的资源状态,只是单纯地获取...

    对Django 中request.get和request.post的区别详解

    POST和GET是HTTP协议定义的与服务器交互的方法。GET一般用于获取/查询资源信息,而POST一般用于更新资源信息。另外,还有PUT和DELETE方法。 POST和GET都可以与服务器完成查,改,增,删操作。 GET提交,请求的数据会...

    Http协议内容总结 http协议包含哪些内容 Http协议的请求方法 Http协议实现的原理机制 get与post请求的区别

    通过以上分析,我们不仅了解了HTTP协议的基本结构和工作原理,还深入探讨了各种请求方法的特点及适用场景,以及GET与POST请求的关键差异。此外,还介绍了常见的HTTP状态码,这对于理解服务器与客户端之间的交互至关...

    HttpTest: GET POST

    在实际开发中,理解GET和POST的差异及其适用场景至关重要,这有助于构建更加安全、高效和符合标准的Web应用程序。通过工具如HttpTest,我们可以方便地测试这两种请求方法,观察服务器的响应,从而调试和优化我们的...

    HttpClient发送http请求(post和get)需要的jar包+内符java代码案例+注解详解

    下面将详细介绍HttpClient库,HTTP请求的基本概念,以及GET和POST方法的差异。 HttpClient是Apache基金会开发的一个开源库,它提供了全面、强大的功能来处理HTTP协议。通过HttpClient,开发者可以方便地创建HTTP...

    深入理解get与post方法的差别

    而GET与POST正是HTTP协议中的两种请求方法,它们在数据传输方式、安全性、使用场景等方面存在显著差异。 ### GET方法的特点与应用场景 GET方法是一种用于请求访问已被URI(Uniform Resource Identifier)识别的...

    GET与POST请求DEMO

    GET请求是HTTP协议中最基本的一种请求方法,用于从服务器获取数据。它将请求参数附加到URL后面,以问号(?)分隔,多个参数之间用&符号分隔。例如,`http://example.com/?param1=value1&param2=value2`。GET请求的...

    GET请求和POST请求的区别(详细)

    HTTP协议定义了多种与服务器进行交互的方法,其中最基本的包括GET、POST、PUT和DELETE。这些方法分别对应于对网络资源的查询、更新、创建和删除操作。GET通常用于获取资源信息,而POST则常用于更新资源。 #### 二、...

    java_http_post.zip_java http post_java http协议post_java post

    Java HTTP POST方法是Java编程中用于向Web服务器发送数据的一种常见技术,主要涉及网络编程和HTTP协议。在本文中,我们将深入探讨Java中如何实现HTTP POST请求,理解HTTP POST的工作原理,以及它与GET方法的区别。 ...

    GET请求https,post请求https

    综上所述,GET和POST请求在HTTPS环境下的主要差异在于数据的提交方式和用途,而两者都得益于HTTPS提供的加密保护,提高了网络通信的安全性。在设计和实现Web服务时,应根据具体需求选择合适的请求方法,同时充分利用...

    Ajax Get、Post请求

    GET是HTTP协议中最常见的请求方法之一,主要用于获取服务器上的资源。在Ajax中,使用GET请求时,请求的数据会被附加到URL后面,以问号分隔,形成一个查询字符串。这种方式限制了请求的大小,因为URL长度有限。以下是...

    tomcat GET请求与POST请求

    在HTTP协议中,GET和POST请求是两种最基本的方法,它们用于客户端(通常是浏览器)向服务器发送数据。理解这两者之间的差异对于任何Web开发者来说都是至关重要的。 GET请求通常用于获取资源,它将请求参数附加到URL...

    HTTPGet与Post的区别[归类].pdf

    HTTP协议定义了多种方法,其中最常被提及的是GET和POST。这两种方法在处理数据和提交表单时有着显著的区别,以下是对这些差异的详细解释: 1. 数据传输方式: - GET:在使用GET方法时,表单数据会被添加到URL后面...

    get和post请求的区别.zip

    在Web开发中,HTTP协议是客户端(浏览器)与服务器之间通信的基础,而GET和POST是HTTP协议中最常见的两种请求方法。它们各自有特定的用途和限制,了解它们的区别对于优化网页性能、保证数据安全以及正确处理用户交互...

    (完整版)Java中http-get和post的区别.doc

    HTTP协议有两种主要的方法:GET和POST,它们各自有着不同的特性和用途。理解这两者之间的差异是成为一名专业的Java开发工程师的基础。 1. **功能差异** - GET方法主要用于从服务器获取资源。它通过URL传递参数,...

    关于get与post的理解.doc

    在Web开发中,GET和POST是HTTP协议中最常见的两种请求方法,它们用于向服务器发送数据。下面我们将深入探讨这两种方法的差异、应用场景以及如何在实际编程中使用它们。 首先,GET和POST的主要区别在于它们处理数据...

    程序员:我终于知道post和get的区别

    而GET和POST是HTTP协议中的两种主要请求方法,它们在数据传递、请求原理以及应用场景上有着显著的差异。这篇文章将深入探讨这两种方法,帮助程序员更好地理解和运用它们。 首先,GET方法是最常见的HTTP请求方式,它...

Global site tag (gtag.js) - Google Analytics