get与post

来源:互联网 发布:最好的职业 知乎 编辑:程序博客网 时间:2024/05/18 08:32

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则没有此限制。

 

 

 

 

HTTP-GETHTTP-POST是使用HTTP的标准协议动词,用于编码和传送变量名/变量值对参数,并且使用相关的请求语义。每个HTTP-GETHTTP-POST都由一系列HTTP请求头组成,这些请求头定义了客户端从服务器请求了什么,而响应则是由一系列HTTP应答头和应答数据组成,如果请求成功则返回应答。

 

  HTTP-GET以使用MIME类型application/x-www-form-urlencodedurlencoded文本的格式传递参数。Urlencoding是一种字符编码,保证被传送的参数由遵循规范的文本组成,例如一个空格的编码是"%20"。附加参数还能被认为是一个查询字符串。

 

  与HTTP-GET类似,HTTP-POST参数也是被URL编码的。然而,变量名/变量值不作为URL的一部分被传送,而是放在实际的HTTP请求消息内部被传送。

 

Get Post的区别两点:

 

一、这两者传递参数时所用的编码不一定是一样的。在 Tomcat中似乎 Get的编码方式是根据页面中指定的编码方式,而 Post则是一直使用同一种编码方式,可在 Tomcat server.xml中配置。

 

二、使用 Get的时候,参数会显示在地址栏上,而 Post不会。

 

所以,如果这些数据是中文数据而且是非敏感数据,那么使用 get;如果用户输入的数据不是中文字符而且包含敏感数据,那么还是使用 post为好。

 

表单提交中getpost方式的区别归纳如下几点:

 

1. get是从服务器上获取数据,post是向服务器传送数据。

2. get是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到。post是通过HTTP post机制,将表单内各个字段与其内容放置在HTML HEADER内一起传送到ACTION属性所指的URL地址。用户看不到这个过程。

3.对于get方式,服务器端用Request.QueryString获取变量的值,对于post方式,服务器端用Request.Form获取提交的数据。

4. get传送的数据量较小,不能大于2KBpost传送的数据量较大,一般被默认为不受限制。但理论上,IIS4中最大量为80KBIIS5中为100KB

5. get安全性非常低,post安全性较高。

 

下面举一个简单的例子来说明它们的区别:

 

<!-分别通过getpost方式提交表单-->

<FORM ACTION="getpost.asp" METHOD="get">

<INPUT TYPE="text" NAME="Text" VALUE="http://bluesea.blogcup.com"></INPUT>

<INPUT TYPE="submit" VALUE="Get方式"></INPUT>

</FORM>

<BR>

<FORM ACTION="getpost.asp" METHOD="post">

<INPUT TYPE="text" NAME="Text" VALUE="http://bluesea.blogcup.com"></INPUT>

<INPUT TYPE="submit" VALUE="Post方式"></INPUT>

</FORM>

<BR>

 

<% If Request.QueryString("Text") <> "" Then %>

通过get方式传递的字符串是: "<B><%= Request.QueryString("Text") %></B>"<BR>

<% End If %>

 

<% If Request.Form("Text") <> "" Then %>

通过Post方式传递的字符串是: "<B><%= Request.Form("Text") %></B>"<BR>

<% End If %>

原创粉丝点击