asp.net 页面之间的传值方式

ASP.NET提供了卓越的事件驱动编程模型,让开发者简化了应用程序的总体设计,但是这个也造成了它固有的一些问题,例如,使用传统的ASP里, 我们可以通过使用POST方法很容易地实现页面间传递值,同样的事情,在使用事件驱动编程模型的ASP.NET就不是那么容易了,当然了,我们仍然有一些 方法可以实现同样的功能。本文将试着使用不同的可能的方法来解决这个问题,但可以预见是,本文将包含使用querystring,session变量,Cookie对象以及server.Transfer方法来实现页面间的值传递。

使用QueryString


使用QuerySting在页面间传递值已经是一种很老的机制了,这种方法的主要优点是实现起来非常简单,然而它的缺点是传递的值是会显示 在浏览器的地址栏上的(不安全),同时又不能传递对象,但是在传递的值少而安全性要求不高的情况下,这个方法还是一个不错的方案。使用这种方法的步骤如 下:
1,使用控件创建web表单(form)
2,创建可以返回表单的按钮和链接按钮
3,在按钮或链接按钮的单击事件里创建一个保存URL的字符变量
4,在保存的URL里添加QueryString参数
5,使用Response.Redirect重定向到上面保存的URL
下面的代码片断演示了如何实现这个方法:
源页面代码:
private void Button1_Click
(object sender, System.EventArgs e)
{
string url;
url="anotherwebform.aspx?name=" + TextBox1.Text + "&email=" + TextBox2.Text;
Response.Redirect(url);
}
目标页面代码:
private void Page_Load
(object sender, System.EventArgs e)
{
Label1.Text=Request.QueryString["name"];
Label2.Text=Request.QueryString["email"];
}

使用Session变量


使用Session变量是可以在页面间传递值的的另一种方式,在本例中我们把控件中的值存在Session变量中,然后在另一个页面中使用 它,以不同页面间实现值传递的目的。但是,需要注意的是在Session变量存储过多的数据会消耗比较多的服务器资源,在使用session时应该慎重, 当然了,我们也应该使用一些清理动作来去除一些不需要的session来降低资源的无谓消耗。使用Session变量传递值的一般步骤如下:
1,在页面里添加必要的控件
2,创建可以返回表单的按钮和链接按钮
3,在按钮或链接按钮的单击事件里,把控件的值添加到session变量里
4,使用Response.Redirect方法重定向到另一个页面
5,在另一个页面提取session的值,在确定不需要使用该session时,要显式清除它
下面的代码片断演示了如何实现这个方法:
源页面代码:
private void Button1_Click
(object sender, System.EventArgs e)
{
//textbox1 and textbox2 are webform
//controls
Session["name"]=TextBox1.Text;
Session["email"]=TextBox2.Text;
Server.Transfer("anotherwebform.aspx");
}
目标页面代码:
private void Page_Load
(object sender, System.EventArgs e)
{
Label1.Text=Session["name"].ToString();
Label2.Text=Session["email"].ToString();
Session.Remove("name");
Session.Remove("email");

}

 

使用Cookie对象

使用Cookie对象是在页面间传递值的第三种方式。Cookie用于在用户浏览器上存储小块的信息,保存用户的相关信息,比如用户访问某网站时用 户的ID,用户的偏好等,用户下次访问就可以通过检索获得以前的信息。所以Cookie也可以在页面间传递值。Cookie通过HTTP头在浏览器和服务 器之间来回传递的。Cookie只能包含字符串的值,如果想在Cookie存储整数值,那么需要先转换为字符串的形式。 可以通过遍历Request对象的Cookie集合可以获得所有的浏览器所有的Cookie。
方法如下:
foreach (string strKey in Request.Cookies)
{
lblCookies.Text += strKey + "=" + Request.Cookies[ strKey ].Value;
}
(1)优点和缺点
优点: 1.使用简单,是保持用户状态的一种非常常用的方法。比如在购物网站中用户跨多个页面表单时可以用它   来保持用户状态。
缺点: 1.常常被人认为用来收集用户隐私而遭到批评。
(2)使用方法
1.在源页面的代码中创建你需要传递的名称和值构造Cookie对象:
HttpCookie objCookie = new HttpCookie("myCookie","Hello,Cookie!");
Response.Cookies.Add(cookie);
2.在目的页面的代码使用Cookie对象取出传递的值:
Result = Request.Cookies[ "myCookie" ].Value;
(3)应用举例
1.源页面 *.aspx的代码:
private void Button1_Click(object sender, System.EventArgs e)
{
HttpCookie objCookie = new HttpCookie("myCookie","Hello,Cookie!");

Response.Cookies.Add(objCookie);
}
2.目的页面 *.aspx的代码:
private void Page_Load(object sender, System.EventArgs e)
{
string myName1Value = Request.Cookies[ "myCookie" ].Value;
}


使用Server.Transfer


使用Server.Transfer 使用Server.Transfer变量是在页面间传递值的第四种方式。上面的四个方法我们在ASP中常常使用,但是这个方法是在ASP.NET中新出现 的。Server.Transfer是从当前的ASPX页面转到新的ASPX页面,服务器端执行新页并输出,在新页面中通过 Context.Handler来获得前一个页面传递的各种数据类型的值、表单数据、QueryString.由于重定向完全在服务器端完成,所以客户端 浏览器中的URL地址是不会改变的。 调用Server.Transfer时,当前的ASPX页面终止执行,执行流程转入另一个ASPX页面,但新的ASPX页面仍使用前一ASPX页面创建的 应答流。
[2] 在这里比较一下Server.Transfer和在“一”中使用的Response.Redirect的区别。
(1)Server.Transfer在服务器端完成,所以客户端浏览器中的URL地址是 不会改变的;Response.Redirect是客户端完成,向服务器端提出新的页面处理请求,所以客户端浏览器中的URL地址是 改变的。
(2)Server.Transfer在服务器端完成, 不需要客户端提出请求, 减少了客户端对服务器端提出请求。
(3)Server.Transfer 只能够转跳到本地虚拟目录指定的页面,也就是工程项目中的页面,而Response.Redirect则十分灵活,可以跳转到 任何URL地址
(4)Server.Transfer可以将前一个页面的 各种类型的值传到新的页面;Response.Redirect则只能借助URL中带 参数或是结合上面四种办法把各种类型的值传到新的页面。
继续我们的Server.Transfer用法。
(1)优点和缺点
优点: 1.直接在服务器端重定向,使用简单方便,减少了客户端对服务器端提出请求。
2.可以传递各种数据类型的值和控件的值。
缺点: 1.客户端浏览器中的URL地址是不改变,会导致在新的页面可能出现一些意想不到的问题。比如如果源页面和目的页面不在同一个虚拟目录或其子目录下,那么使用相对路径的图片、超链接都会导致错误的指向。
(2)使用方法
1.在源页面的代码中,使用Page类的Server.Transfer跳到另一个页面传递页面数据:

Server.Transfer("destinationWebForm.aspx","false")。
2.在目的页面中,使用Context.Handler来接收数据:
FormerPage formerPage = (FormerPage)Context.Handler;
然后用formerPage的属性和方法来获取前一个页面的值,或者直接用 Context.Items["myParameter "] 来获取前一个页面的值。
需 要注意的是获取这些值必须在新的页面首次加载时,才能正确获取上一页面的各种数据类型或是控件的值。在以后的postback时,就无法获取上一页面的各 种数据类型或是控件的值了,因为此时得到的当前页面的实例. 所以需要在新页面(destinationWebForm.aspx)的Page_Load()事件中使用if(!IsPostBack)把获取前一个页 面的值的代码包含起来,才能获得前一个页面传递的各种数据类型的值、表单数据、QueryString。
(3)应用举例
1.源页面 FormerPage.aspx的代码:

public string HelloContextAttribute 
{
get
{
return "Use Attribute: Hello,Context";
}
}
public string HelloContextMethod()
{
return "Call Method: Hello,Context!";
}
public string TextBoxValue
{
get
{
return TextBox1.Text;
}
}
private void Button1_Click(object sender, System.EventArgs e)
{
string Name1Value = "Hello, Name1!";
TextBox1.Text
="Hello,TextBox1!";
ArrayList myList
= new ArrayList(3);
//创建动态数组
myList.Add("Hello,Array1! ");
//向动态数组中添加新的值
myList.Add("Hello,Array2!");
myList.Add(
"Hello,Array3!");
//Context可保存任意数据类型,Context字典特定于某个Http请求。
//对于不同客户端,值是不一样的。
Context.Items["destinationList"] = myList;
//在Context.Items中保存动态数组 

Context.Items.Add(
"newContext","Hello,NewContext");
 //在Context.Items中保存一组名称-值的数据 
//Server.Transfer第二参数如果为true,表示本页面的Form和QuerryString的值在新页面继续有效。
//否则在新页面无法获得TextBox1的值。
Server.Transfer("destinationWebForm.aspx?Name1="+ Name1Value,true);
}

 


2.目的页面 destinationWebForm.aspx的代码:

private void Page_Load(object sender, System.EventArgs e)
{
if(!IsPostBack)
{
try
{
string helloContextAttribute;
string helloContextMethod;
string textBoxValue;
string contextItemsValue;
string queryString;
ArrayList listResult;
FormerPage formerPage
= (FormerPage)Context.Handler;
    helloContextAttribute = formerPage.HelloContextAttribute;
//通过FormerPage中定义的属性来获取值
helloContextMethod = formerPage.HelloContextMethod();
//通过FormerPage中定义的方法来获取值
textBoxValue = formerPage.TextBoxValue;
//通过FormerPage中返回文本控件的值

textBoxValue = Request.Form["TextBox1"];
  //这个方法多用于用户在控件中输入值后才能获取,但是在程序中给直接TextBox1.Text赋值, 
//那么这个方法将获得空值,在这种情况下需要使用上面的获取方法
contextItemsValue
= Context.Items["newContext"].ToString();
//通过FormerPage中Context的Items获取值
listResult = (ArrayList)Context.Items["destinationList"];
 //通过FormerPage中Context的Items获取对象,强制转换类型: 
queryString = Request.QueryString["Name1"];
//通过FormerPage的URL中的QueryString获取值
}
catch
{
Response.Write(
"Error!");
}
}
}
原文地址:
http://www.cnblogs.com/wennxxin/archive/2008/10/19/1314451.html

转载于:https://www.cnblogs.com/jeriffe/articles/2100991.html

深度学习是机器学习的一个子领域,它基于人工神经网络的研究,特别是利用多层次的神经网络来进行学习和模式识别。深度学习模型能够学习数据的高层次特征,这些特征对于图像和语音识别、自然语言处理、医学图像分析等应用至关重要。以下是深度学习的一些关键概念和组成部分: 1. **神经网络(Neural Networks)**:深度学习的基础是人工神经网络,它是由多个层组成的网络结构,包括输入层、隐藏层和输出层。每个层由多个神经元组成,神经元之间通过权重连接。 2. **前馈神经网络(Feedforward Neural Networks)**:这是最常见的神经网络类型,信息从输入层流向隐藏层,最终到达输出层。 3. **卷积神经网络(Convolutional Neural Networks, CNNs)**:这种网络特别适合处理具有网格结构的数据,如图像。它们使用卷积层来提取图像的特征。 4. **循环神经网络(Recurrent Neural Networks, RNNs)**:这种网络能够处理序列数据,如时间序列或自然语言,因为它们具有记忆功能,能够捕捉数据中的时间依赖性。 5. **长短期记忆网络(Long Short-Term Memory, LSTM)**:LSTM 是一种特殊的 RNN,它能够学习长期依赖关系,非常适合复杂的序列预测任务。 6. **生成对抗网络(Generative Adversarial Networks, GANs)**:由两个网络组成,一个生成器和一个判别器,它们相互竞争,生成器生成数据,判别器评估数据的真实性。 7. **深度学习框架**:如 TensorFlow、Keras、PyTorch 等,这些框架提供了构建、训练和部署深度学习模型的工具和库。 8. **激活函数(Activation Functions)**:如 ReLU、Sigmoid、Tanh 等,它们在神经网络中用于添加非线性,使得网络能够学习复杂的函数。 9. **损失函数(Loss Functions)**:用于评估模型的预测与真实值之间的差异,常见的损失函数包括均方误差(MSE)、交叉熵(Cross-Entropy)等。 10. **优化算法(Optimization Algorithms)**:如梯度下降(Gradient Descent)、随机梯度下降(SGD)、Adam 等,用于更新网络权重,以最小化损失函数。 11. **正则化(Regularization)**:技术如 Dropout、L1/L2 正则化等,用于防止模型过拟合。 12. **迁移学习(Transfer Learning)**:利用在一个任务上训练好的模型来提高另一个相关任务的性能。 深度学习在许多领域都取得了显著的成就,但它也面临着一些挑战,如对大量数据的依赖、模型的解释性差、计算资源消耗大等。研究人员正在不断探索新的方法来解决这些问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值