zoukankan      html  css  js  c++  java
  • HTTP协议中GET、POST和HEAD的介绍

    HTTP协议中GET、POST和HEAD的介绍

    GET: 请求指定的页面信息,并返回实体主体。

    HEAD: 只请求页面的首部。

    POST: 请求服务器接受所指定的文档作为对所标识的URI的新的从属实体。       

    HTTP 定义了与服务器交互的不同方法,最基本的方法是 GET 和 POST。事实上 GET 适用于多数请求,而保留 POST 仅用于更新站点。根据 HTTP 规范,GET 用于信息获取,而且应该是 安全的和幂等的。所谓安全的意味着该操作用于获取信息而非修改信息。换句话说,GET 请求一般不应产生副作用。幂等的意味着对同一 URL 的多个请求应该返回同样的结果。完整的定义并不像看起来那样严格。从根本上讲,其目标是当用户打开一个链接时,她可以确信从自身的角度来看没有改变资源。 比如,新闻站点的头版不断更新。虽然第二次请求会返回不同的一批新闻,该操作仍然被认为是安全的和幂等的,因为它总是返回当前的新闻。反之亦然。

    POST 请求就不那么轻松了。POST 表示可能改变服务器上的资源的请求。仍然以新闻站点为例,读者对文章的注解应该通过 POST 请求实现,因为在注解提交之后站点已经不同了(比方说文章下面出现一条注解); 在FORM提交的时候,如果不指定Method,则默认为GET请 求,Form中提交的数据将会附加在url之后,以?分开与url分开。字母数字字符原样发送,但空格转换为“+“号, 其它符号转换为%XX,其中XX为 该符号以16进制表示的ASCII(或ISO Latin-1)值。GET请求请提交的数据放置在HTTP请求协议头中,而POST提交的数据则放在实体数据中; GET方式提交的数据最多只能有1024字节,而POST则没有此限制。  

    在表单里使用”post”和”get”有什么区别

    在Form里面,可以使用post也可以使用get。它们都是method的合法取值。但是,post和get方法在使用上至少有两点不同:

    1、Get方法通过URL请求来传递用户的输入。Post方法通过另外的形式。

    2、Get方式的提交你需要用Request.QueryString来取得变量的值,而Post方式提交时,你必须通过Request.Form来访问提交的内容。

    通过get方法提交数据,可能会带来安全性的问题。比如一个登陆页面。当通过get方法提交数据时,用户名和密码将出现在URL上。如果: 1、 登陆页面可以被浏览器缓存; 2、 其他人可以访问客户的这台机器。 那么,别人即可以从浏览器的历史记录中,读取到此客户的账号和密码。所以,在某些情况下,get方法会带来严重的安全性问题。 建议 在Form中,建议使用post方法。

    如果用HEAD方法请求的话,则服务器返回的只是响应标题,而不会返回被请求的文挡,HEAD方法通用于一些搜索引擎

     

    --------------------------------------------------------------------------------------------------------------------

    GET: 请求指定的页面信息,并返回实体主体。

    HEAD: 只请求页面的首部。

    POST: 请求服务器接受所指定的文档作为对所标识的URI的新的从属实体。

    PUT: 从客户端向服务器传送的数据取代指定的文档的内容。

    DELETE: 请求服务器删除指定的页面。

    OPTIONS: 允许客户端查看服务器的性能。

    TRACE: 请求服务器在响应中的实体主体部分返回所得到的内容。

    PATCH: 实体中包含一个表,表中说明与该URI所表示的原内容的区别。

    MOVE: 请求服务器将指定的页面移至另一个网络地址。

    COPY: 请求服务器将指定的页面拷贝至另一个网络地址。

    LINK: 请求服务器建立链接关系。 UNLINK: 断开链接关系。

    WRAPPED: 允许客户端发送经过封装的请求。

    Extension-mothed:在不改动协议的前提下,可增加另外的方法。 比如: GET /index.html HTTP/1.1 Accept: text/plain /*纯ASCII码文本文件*/ Accept: text/html /*HTML文本文件*/ User-Agent:Mozilla/4.5(WinNT) 说明浏览器使用Get方法请求文档/index.html。浏览器则只允许接收纯ASCII码文本文件和HTML文本文件,其使用的引擎是Mozilla/4.5(Netscape)。

     

    当服务器响应时,其状态行的信息为HTTP的版本号,状态码,及解释状态码的简单说明。

    现将5类状态码详细列出:

    ① 客户方错误

    100  继续

    101  交换协议

    ② 成功

    200  OK

    201  已创建

    202  接收

    203  非认证信息

    204  无内容

    205  重置内容

    206  部分内容

    ③ 重定向

    300  多路选择

    301  永久转移

    302  暂时转移

    303  参见其它

    304  未修改(Not Modified)

    305  使用代理

    ④ 客户方错误

    400  错误请求(Bad Request)

    401  未认证

    402  需要付费

    403  禁止(Forbidden)

    404  未找到(Not Found)

    405  方法不允许

    406  不接受

    407  需要代理认证

    408  请求超时

    409  冲突

    410  失败

    411  需要长度

    412  条件失败

    413  请求实体太大

    414  请求URI太长

    415  不支持媒体类型

    ⑤ 服务器错误

    500  服务器内部错误

    501  未实现(Not Implemented)

    502  网关失败

    504  网关超时

    505 HTTP版本不支持 

    本文转自http://linux.chinaunix.net/techdoc/net/2009/06/27/1120638.shtml

  • 相关阅读:
    链表补充及链表和数组的区别
    单链表(不带头结点)
    动态数组
    【笔记】SQL语言的设计与编写
    netty 学习笔记一:感受 IO编程 NIO编程 与 Netty 编程
    分享系列——Thread#join() 在 Java 源码中并没有 notify ,被阻塞线程是如何唤醒的?答案在 JVM
    RabbitMQ 安装 图笔记版
    RabbitMQ 安装——RPM 和 TAR 两种方式
    学原理脱坑 之 centos 6/7 更新 UTC 以及 设置系统时区
    数据结构和算法篇——散列表
  • 原文地址:https://www.cnblogs.com/huafeng/p/HTTP.html
Copyright © 2011-2022 走看看