ASP.NET页面传值不使用QueryString

Asp.net中的页面传值方法:

1         Url传值

特点:主要优点是实现起来非常简单,然而它的缺点是传递的值是会显示在浏览器的地址栏上的(不安全),同时又不能传递对象,

使用场景:传递的值少而安全性要求不高的情况下

传递:url="WebForm2.aspx?name=" + TextBox1.Text + "&email=" + TextBox2.Text;
接收:name=   Request.QueryString["name"];
        email=Request.QueryString["email"];

2         Session

特点:Session变量存放在服务器端,存储过多的数据会消耗比较多的服务器资源,可是使用清理动作来去除一些不需要的session,Session容易过期

使用场景:三个以上页面需要共用的变量

传递:Session["name"]=TextBox1.Text;

接收:  name=Session["email"].ToString();
清除: Session.Remove("name");
3         Cookie

特点:Cookie是存放在客户端的,需要要配合ASP.NET内置对象Request来使用

传递:HttpCookie cookie_name = new HttpCookie("name");
    cookie_name.Value = Label1.Text;
    Reponse.AppendCookie(cookie_name);
接收:name = Request.Cookie["name"].Value.ToString();

4         Application

特点:Application对象的作用范围是整个全局,对所有用户都有效。其常用的方法用Lock和UnLock

传递:Application["name"] = Label1.Text;
接收:    Application.Lock();
            name = Application["name"].ToString();
            Application.UnLock();

5         Response.Redirect()

传递:Response.Redirect( "target.aspx?param1=1111&param2=2222 ")
接收:   string   str   =   Request[ "param1 "]

6       Server.Transfer(子页面特点:地址栏中没有地址,鼠标右键属性中显示父页面的路径,保护子页面Url安全)

传递:Server.Transfer( "target.aspx?param1=1111&param2=2222 ")
接收:string   str   =   Request[ "param1 "]
接收:

a.aspx的C#代码

ContractedBlock.gif ExpandedBlockStart.gif Parent Page
public string Name
{
get{ return Label1.Text;}
}
private void Button1_Click(object sender, System.EventArgs e)
{
Server.Transfer(
"b.aspx");
}

b.aspx中C#代码

ContractedBlock.gif ExpandedBlockStart.gif Children Page
private void Page_Load(object sender, EventArgs e)
{
a newWeb
= (a)Context.Handler;
string name;
name
= newWeb.Name;
}

7 表单提交(可隐藏Url中的参数)

<form   action=   "target.aspx "   method   =   "post "   name   =   "form1 ">
  <input   name   =   "param1 "   value   =   "1111 "/>
  <input   name   =   "param2 "   value   =   "2222 "/>  
      </form>
      ....
      form1.submit();
      ....
      此种方在ASP。NET中无效,因为ASP。NET的表单总是提交到自身页面,如果要提交到别一页面,需要特殊处理。

8  @PreviousPageType (可隐藏Url中的参数)

这个指令是.net 2.0中的一个新指令,用于处理ASP.NET 2.0提供的跨页面传送新功能.用于批定跨页面的传送过程起始于哪个页面.包含两个属性:

TypeName:设置回送时的派生类名

VirtualPath:设置回送时所传送页面的地址.

如下示例:

源页面WebForm1.aspx中有一个TextBox,ID为txtName.在WebForm1.aspx.cs中设置一个属性:

public TextBox Name

{

    get{return this.txtName;}//返回一个控件对象

}

在目标页面的设计文件中(WebForm2.aspx)的最上方加上:

 <%@ PreviousPageType VirtualPath="~/Page1.aspx"%>,

然后就能引用WebForm1.aspx中定义的属性了.

在WebForm2.aspx.cs中可以有如下引用形式(假设WebForm2.aspx中有一个ID为lblName的Label):

lblName.Text="Hello"+PreviousPage.Name.Text+"<br />";

9     postbackUrl (可隐藏Url中的参数)

首先在asp.net中只有Button linkButton imgButton有postbackUrl属性可以用来跨页传递控件的值

<asp:Button ID="Button1" runat="server" Text="Button" PostBackUrl="index.aspx" />

Index.aspx:

  if(Page.PreviousPage!=null)

     {

        if(Page.PreviousPage.IsCrossPagePostBack)

        {

            TextBox textControl=this.PreviousPage.FindControl("TextBox1") as TextBox;

 

            if(textControl.Text!=null)

             {

                 this.Label1.Text = textControl.Text;

             }

         }

    }

   PreviousPage:代表传递值的页面

IsCrossPagePostBack:判断页面是不是跨页传值

FindControl:获得控件的值

 

再加两个:利用隐藏域和使用Cache

转载于:https://www.cnblogs.com/fighting-from-now/archive/2011/08/19/querystring.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值