asp.net页面传值方法实例详解

发布时间:2020-11-26编辑:脚本学堂
有关asp.net页面间传值的方法,通过get或post方式实现页面传值的例子,需要的朋友参考下。

asp.net中页面之间传值多用get,post,其它如session,appliction,cookie等只是在特殊情况下再使用了。

1、Get(即使用QueryString显式传递)
方式:在url后面跟参数。
特点:简单、方便。
缺点:字符串长度最长为255个字符;数据泄漏在url中。
适用数据:简单、少量、关键的数据。
适用范围:传递给自己、传递给另一个目标页面;常用于2个页面间传递数据。
用法:例如:url后加?UserID=…,跳转到目标页面,目标页面在伺服端可用Request.QueryString["InputText"]获取其指定参数值。

例子:(1)a.aspx
 

复制代码 代码示例:
private void Button1_Click(object sender, System.EventArgs e)
{
  string s_url;
  s_url = "b.aspx?name=" + Label1.Text;
  Response.Redirect(s_url);
}

(2)b.aspx
 

复制代码 代码示例:
private void Page_Load(object sender, EventArgs e)
{
  Label2.Text = Request.QueryString["name"];
}

2、Post方式
方式:通用的方式。利用form提交。
特点:最常用的方法。常用技巧是把隐秘的数据存在隐藏域中由form提交。
适用数据:大量数据,包括文件上传
适用范围:同Get方法
用法:在客户端form指定action目标后submit、在asp.net的伺服端中使用server.Transfer(url)提交;
在伺服端中用Request.Form["FormFieldID"]获取。

例子:
 

复制代码 代码示例:
<form id="form1" action="GetUserInfo.aspx" method="post">
<table align="center" cellpadding="0" cellspacing="10px" border="0" style="width: 320px;border:1px solid gray;" >
<tr>
<td colspan="2" class="title" align="center">修改密码</td>
</tr>
<tr>
<td class="left">输入新密码:</td>
<td class="right">
<input type="password" id="userPwd" name="userPwd" style="width: 175px" />
</td>
</tr>
<tr>
<td class="left">&nbsp;&nbsp;确认密码:</td>
<td class="right">
<input type="password" id="verifyPwd" name="verifyPwd" style="width: 175px" />
</td>
</tr>
<tr>
<td colspan="2" style="text-align: center">
<hr />
(www.jb200.com) <input type="hidden" name="username" value="<%=后台定义的变量读数据库时赋值%>"/></td>
<input type="submit" value="修改" />
<input type="reset" value="重置" />
</td>
</tr>
</table>
</form>

有一个方法,根据POST和GET分别取值。
 

复制代码 代码示例:

public object string GetValueFromPage(string inputName,int type)
{
HttpContext rq = HttpContext.Current;
object TempValue = "";

if (type==1)
{
if (rq.Request.Form[inputName] != null)
{
TempValue = rq.Request.Form[inputName];
}

}
else if (type==0)
{
if (rq.Request.QueryString[inputName] != null)
{
TempValue = rq.Request.QueryString[inputName];
}
}
return TempValue;
}
 

那么当提交至GetUserInfo.aspx页面时,GetUserInfo.aspx.CS中可以这样获取值。

cookie
方式:将数据存在客户端的经典方法。
缺点:安全性低、受客户端设置限制、一个站点仅存20个cookie,每个容量4096字节。

Session
方式:将用户数据存储在伺服端。
特点:asp.net中可以设置session的存储方式、位置、SessionID的保存是否依赖cookie。
可以直接存储对象。
缺点:asp.net中有失效的隐患

Cache
方式:将用户数据存储在伺服端数据缓存中。
特点:可以大大提高效率。 可以直接存储对象。

Appliction
方式: 将数据存储于此,相当于全局变量
特点:可以直接存储对象。整个站点的共享数据

ViewState
方式:asp.net特有机制,用来恢复页面状态。
特点:将页面各控件及其所存数据序列化存在name为_ViewState的隐藏域中。
缺点:存在HTML中,安全性较低。可以设置加密和验证,但数据量会大增、效率有影响。
Static
方式: 将数据存于静态变量中。
特点:利于提高效率。
缺点:若用不好会致使用户或页面间数据紊乱,造成极大的隐患。建议只赋值一次,绝对禁止为单个用户而更改此值。