代码改变世界

ASP.NET中Get和Post的用法 Request.QueryString,Request.Form,Request.Params的区别 [转]

2011-01-24 17:41  suzh  阅读(746)  评论(0编辑  收藏  举报
< form id="form1" method="get" runat="server">  
    
< div>  
        你的名字
< asp:TextBox ID="name" runat="server">< /asp:TextBox>< br />  
        
< br />  
        你的网站
< asp:TextBox ID="website" runat="server">< /asp:TextBox>< br />  
        
< br />  
        
< br />  
        
< asp:Button ID="Button1" runat="server" Text="send" />< br />  
        
< br />  
        
< br />  
        学习request 和 response的用法
< br />  
        
< br />  
        
< br />  
   
< /div>  
< /form>  
 
   
 
< form id="form2" method="post" runat="server">  
    
< div>  
        你的名字
< asp:TextBox ID="name2" runat="server">< /asp:TextBox>< br />  
        
< br />  
        你的网站
< asp:TextBox ID="website2" runat="server">< /asp:TextBox>< br />  
        
< br />  
        
< br />  
        
< asp:Button ID="Button2" runat="server" Text="send" />< br />  
        
< br />  
        
< br />  
        学习request 和 response的用法
< br />  
        
< br />  
        
< br />  
    
< /div>  
< /form>  
 

/*从URL中可看出ASP.NET Get和Post的区别.那么那如何编程实现数据的接收呢?
第1种,接收用get 方法传输的数据的写法:
*/

protected void Page_Load(object sender, EventArgs e)  
    {  
        
string id = Request.QueryString["name"];  
        
string website = Request.QueryString["website"];  
        Response.Write(id 
+ "< br>" + website);  
 
      Response.Write(
"你使用的是" + Request.RequestType + "方式传送数据");  
 
    }  

//第2种,接收用post 方法传输的数据的写法:

protected void Page_Load(object sender, EventArgs e)  
    {  
        
        
string id2 = Request.Form["name2"];  
        
string website2 = Request.Form["website2"];  
        Response.Write(id2 
+ "< br>" + website2);  
 
 
        Response.Write(
"你使用的是" + Request.RequestType + "方式传送数据");  
 
    }  
 
string id4 = Request["name4"];  
        
string website4 = Request["website4"];  
        Response.Write(id4 
+ "< br>" + website4);  
 

//第3种,同时接受get和post 方法传送数据的代码写法:
//A 写法

string id3 = Request.Params["name3"];  
        
string website3 = Request.Params["website3"];  
        Response.Write(id3 
+ "< br>" + website3);  
 
//B 写法

string id4 = Request["name4"];  
        
string website4 = Request["website4"];  
        Response.Write(id4 
+ "< br>" + website4);  


 

表单提交中,ASP.NET的Get和Post方式的区别归纳如下 几点:

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

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

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

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

5. get安全性非常低,post安全性较高。但是执行效率却比Post方法好。

建议:

1、get方式的安全性较Post方式要差些,包含机密信息的话, 建议用Post数据提交方式;

2、在做数据查询时,建议用Get方式;而在做数据添加、修改或删 除时,建议用Post方式。

 

params、Request、Request.querystring、Request.Form 具体区别! 
MSDN:Request ObjectRequest
Request.Form:获取以POST方式提交的数据(接收Form提交来的数 据);
Request.QueryString:获取地址栏参数(以GET方式提交的数据)
Request:包含以上两种方式(优先获取 GET方式提交的数据),它会在QueryString、Form、ServerVariable中都按先后顺序搜寻一遍。而且有时候也会得到不同的结 果。如果你仅仅是需要Form中的一个数据,但是你使用了Request而不是Request.Form,那么程序将在QueryString、 ServerVariable中也搜寻一遍。如果正好你的QueryString或者ServerVariable里面也有同名的项,你得到的就不是你原 本想要的值了。
Request.Params是所有post和get传过来的值的集合,request.params其实是一个集合,它依次包括 request.QueryString、request.Form、request.cookies和request.ServerVariable。
 
asp.net 默认虽然是POST Form,但是只是自己post自己,不能POST到其他页面
如果非要提交到另一个页面的 话 用HTML元素 把runat="server" 去掉 用submit提交
<from method="post" id="form1" action="http://www.baidu.com">
</from>
<script>
getElementByID("form1").submit();
</script>
用Request.Form["xxx"] 可以取值
 
GET访问 浏览器 认为 是等幂的
就是 一个相同的URL 只有一个结果[相同是指 整个URL字符串完全匹配]
所以 第二次访问的时候 如果 URL字符串没变化 浏览器是 直接拿出了第一次访问的结果

POST则 认为是一个 变动性 访问 (浏览器 认为 POST的提交 必定是 有改变的)

防止 GET 的 等幂 访问 就在URL后面加上 ?+new Date();,[总之就是使每次访问的URL字符串不一样的] 比如在生成验证码的时候

设计WEB页面的时候 也应该遵守这个原则
转自:http://blog.csdn.net/liaolian9948/archive/2010/04/01/5440416.aspx