热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

页面间传值的五种方法

一、QueryString传值:1.这是最简单的传值方式,但缺点是传的值会显示在浏览器的地址栏中且不能传递对象,只适用于传递简单的且安全性要求不高的整数值,例如:

一、QueryString传值:
1. 这是最简单的传值方式,但缺点是传的值会显示在浏览器的地址栏中且不能传递对象,只适用于传递简单的且安全性要求不高的整数值,例如:



2. 新建一个WEB项目,添加一个页面命名为Test1,在页面中添加一个Button命名为btnLogin,再添加两个TextBox分别命名为txtUserName和txtPassWord,添加Button的Click()事件:

private void btnLogin_Click (object sender, System.EventArgs e)



{

string url=" Test1.aspx?UserName=" +txtUserName.Text + " Password= +txtPassWord.Text+

Response.Redirect(url);

}

3. 添加另一个页面命名为Test2,在页面添加两个Lable分别命名为lblUserName和lblPassWord,添加页面的Load()事件:

private void Page_Load (object sender, System.EventArgs e)

{

lblUserName.Text=Request.QueryString["UserName"];

lblPassWord.Text=Request.QueryString["Password"];

}

4. 把Test1设为起始页,运行项目在Test1页面的文本框中输入值后点击按钮,就可以在Test2页面中显Test1页面输入的结果。

二、Server.Transfer传值:
1. 这种方式避免了要传递的值显示在浏览器的地址栏中,但是比较麻烦,例如:

2. 新建一个WEB项目,添加两个页面分别命名为Test1和Test2,在Test1页面中添加一个Button命名为btnLogin,再添加两个TextBox分别命名为txtUserName和txtPassWord,在Test2页面添加两个Lable分别命名为lblUserName和lblPassWord,为Test1添加过程返回txtUserName和txtPassWord的值并添加btnLogin的Click()事件:

public string UserName

{

get

{

return txtUserName.Text;

}

}

public string Password

{

get

{

return txtPassWord.Text;

}

}

private void btnLogin_Click (object sender, System.EventArgs e)

{

Server.Transfer("Test2.aspx");

}

3. 添加Test2页面的Load()事件:

private void Page_Load (object sender, System.EventArgs e)

{

Test1 t1; //创建原始窗体的实例

t1=( Test1)Context.Handler; //获得实例化的句柄

lblUserName.Text= t1.UserName;

lblPassWord.Text= t1.Password;

}

4. 把Test1设为起始页,运行项目在Test1页面的文本框中输入值后点击按钮,就可以在Test2页面中显Test1页面输入的结果。

三、COOKIE对象变量:
1. COOKIE是针对每一个用户而言的,是存放在客户端的 ,COOKIE的使用要配合ASP.NET内置对象Request来使用,例如:

2. 新建一个WEB项目,添加两个页面分别命名为Test1和Test2,在Test1页面中添加一个Button命名为btnLogin,再添加两个TextBox分别命名为txtUserName和txtPassWord,在Test2页面添加两个Lable分别命名为lblUserName和lblPassWord,为Test1添加Button的Click()事件:

private void btnLogin_Click (object sender, System.EventArgs e)

{

HttpCOOKIE COOKIE_UserName = new HttpCOOKIE("UserName");

HttpCOOKIE COOKIE_PassWord = new HttpCOOKIE("PassWord ");

COOKIE_ UserName.Value = txtUserName.Text;

COOKIE_ PassWord.Value = txtPassWord.Text;

Response.AppendCOOKIE(COOKIE_ UserName);

Response.AppendCOOKIE(COOKIE_ PassWord);

Server.Transfer("Test2.aspx");

}

3. 添加Test2页面的Load()事件:

private void Page_Load (object sender, System.EventArgs e)

{

lblUserName.Text = Request.COOKIEs["UserName"].Value.ToString();

lblPassWord.Text = Request.COOKIEs["PassWord "].Value.ToString();

}

4. 把Test1设为起始页,运行项目在Test1页面的文本框中输入值后点击按钮,就可以在Test2页面中显Test1页面输入的结果。

四、Session对象变量:
1. Session也是针对每一个用户而言的,是存放在服务器端的 ,Session不仅可以把值传递到下一个页面,还可以交叉传递到多个页面,直至把Session变量的值removed 后,变量才会消失,例如:

2. 新建一个WEB项目,添加两个页面分别命名为Test1和Test2,在Test1页面中添加一个Button命名为btnLogin,再添加两个TextBox分别命名为txtUserName和txtPassWord,在Test2页面添加两个Lable分别命名为lblUserName和lblPassWord,为Test1添加Button的Click()事件:

private void btnLogin_Click (object sender, System.EventArgs e)

{

Session["UserName"]=txtUserName.Text;

Session["PassWord"]=txtPassWord.Text;

Response.Redirect("Test2.aspx");

}

3. 添加Test2页面的Load()事件:

private void Page_Load (object sender, System.EventArgs e)

{

lblUserName.Text=Session["UserName"].ToString();

lblPassWord.Text=Session["Password"].ToString();

Session.Remove("UserName"); //清除Session

Session.Remove("PassWord"); //清除Session

}

4. 把Test1设为起始页,运行项目在Test1页面的文本框中输入值后点击按钮,就可以在Test2页面中显Test1页面输入的结果。

五、Application对象变量:
1. Application对象的作用范围是整个全局,也就是说对所有用户都有效。其常用的方法用Lock和UnLock,例如:

2. 新建一个WEB项目,添加两个页面分别命名为Test1和Test2,在Test1页面中添加一个Button命名为btnLogin,再添加两个TextBox分别命名为txtUserName和txtPassWord,在Test2页面添加两个Lable分别命名为lblUserName和lblPassWord,为Test1添加Button的Click()事件:

private void btnLogin_Click (object sender, System.EventArgs e)

{

Application["UserName"] = txtUserName.Text;

Application["PassWord "] = txtPassWord.Text;

Server.Transfer("Test2.aspx");

}

3. 添加Test2页面的Load()事件:

private void Page_Load (object sender, System.EventArgs e)

{

Application.Lock();

lblUserName. Text = Application["UserName"].ToString();

lblPassWord. Text = Application["PassWord "].ToString();

Application.UnLock();

}

4. 把Test1设为起始页,运行项目在Test1页面的文本框中输入值后点击按钮,就可以在Test2页面中显Test1页面输入的结果。


   



推荐阅读
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 在重复造轮子的情况下用ProxyServlet反向代理来减少工作量
    像不少公司内部不同团队都会自己研发自己工具产品,当各个产品逐渐成熟,到达了一定的发展瓶颈,同时每个产品都有着自己的入口,用户 ... [详细]
  • ①页面初始化----------收到客户端的请求,产生相应页面的Page对象,通过Page_Init事件进行page对象及其控件的初始化.②加载视图状态-------ViewSta ... [详细]
  • adfs是什么_培训与开发的概念
    adfs是什么_培训与开发的概念(如您转载本文,必须标明本文作者及出处。如有任何疑问请与我联系me@nap7.com)ADFS相关开发技术的中文资料相对匮乏,之前在弄这个东西的时候 ... [详细]
  • XMLhttpREquest_Ajax技术总结之XmlHttpRequest
    Ajax1、 什么是ajax   ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • Webmin远程命令执行漏洞复现及防护方法
    本文介绍了Webmin远程命令执行漏洞CVE-2019-15107的漏洞详情和复现方法,同时提供了防护方法。漏洞存在于Webmin的找回密码页面中,攻击者无需权限即可注入命令并执行任意系统命令。文章还提供了相关参考链接和搭建靶场的步骤。此外,还指出了参考链接中的数据包不准确的问题,并解释了漏洞触发的条件。最后,给出了防护方法以避免受到该漏洞的攻击。 ... [详细]
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • springboot基于redis配置session共享项目环境配置pom.xml引入依赖application.properties配置Cookie序列化(高版本不需要)测试启 ... [详细]
  • ByteCTF 2019 WriteUp Kn0ck
    ByteCTF 2019 WriteUp Kn0ck ... [详细]
  • 跨站的艺术XSS Fuzzing 的技巧
    作者|张祖优(Fooying)腾讯云云鼎实验室对于XSS的漏洞挖掘过程,其实就是一个使用Payload不断测试和调整再测试的过程,这个过程我们把它叫做F ... [详细]
author-avatar
小辛牛牛123牛牛小辛321
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有