在开发ASP.NET 以及ASP.NET Core过程中主要使用的页面传值的方法有以下几种:
Request.QueryString[] Request.Form[] Session,
Cookie Cache Application, Server.Transfer
Database HttpContext的Item属性 Files DataBase等
1、Request.QueryString
代码如下:
protected void getQueryString_Click(object sender, EventArgs e)
{
string QueStr = Request.QueryString["name"];
Response.Write(QueStr);
}
分析:Request.QueryString 获取http查询字符床变量集合。有两重载即Request.QueryString[string name]和Request.QueryString[int index]两种
其中Request.QueryString主要获取url中的“?”之后的参数,例如url: a.aspx?name="nueq",则 Reuqest.QueryString["name"]的值为“neuq”。
2、Request.Form
代码如下:
protected void getQueryString_Click(object sender, EventArgs e)
{
string strQueForm = Request.Form["TextBox1"];
Response.Write(strQueForm);
}
分析:
Request.Form获取窗体变量集合有两重载(一般Form表单post提交至后台的数据)。即Request.Form[string name] 和Request.Form[int index],获取表单指定名称的参数值。
3、Session基本操作
a、创建session,代码如下:
public void createSession(string[] arrStr)
{
//创建数组
string[] str=new string[arrStr.Length];
for (int i = 0; i < arrStr.Length; i++)
{
str[i] = i.ToString();
Session[str[i]] = arrStr[i];
}
}
b、获取session中的数据,代码如下:
string getSessionValue=Session["name"].ToString();
c、遍历Session中的数据,代码如下:
public void getSession()
{
IEnumerator sessionEnum =Session.Keys.GetEnumerator();
While(sessionEnum.MoveNext)
{
Response.Write(Session[sessionEnum.Current.ToString()].ToString()+",");
}
}
d、清空Session数据但是不会结束会话。代码如下:
Session.Clear();
e、结束会话,代码如下:
Session.Abandon();
注:Session的数据存放形式及位置:
<system.web>
<sessionState mode="Off|InProc|StateServer|SQLServer" cookieless="true|false" timeout="number of minutes"
stateConnectionString="tcpip=server:port" sqlConnectionString="sql connection string" stateNetworkTimeout="number of seconds"/>
</system.web>
注解:
mode:表示设置存储Session形式和位置;
a、Off:禁用Session;
b、Inproc:In Process缩写,表示将Session存储在IIS进程内,但注意,该种方式虽然性能高,但IIS重启是,丢失Session信息;(默认值)
c、SateServer:将Session存储在ASP.NET状态服务进程中(重新启动Web运用程序时保留会话状态,并使会话状态可以用于网络中的多个Web服务器);
d、将Session存储在SQL Server中
cookieless:设置客户端存储Session形式和位置
a、true:使用cookieless模式,这时客户端的Session信息就不再使用Cookie存储了,而是将其通过URL存储;
b、false:使用kookie模式,默认值。
timeout 设置经过多少分钟后服务器自动放弃Session信息。默认为20分钟;
stateConnectionString 设置将Session信息存储在状态服务中时使用的服务器名称和端口号,例如:"tcpip=127.0.0.1:42424”。当mode的值是StateServer是,这个属性是必需的。(默认端口42424);
sqlConnectionString 设置与SQL Server连接时的连接字符串。例如"data source=localhost;Integrated Security=SSPI;Initial Catalog=joye"。当mode的值是SQLServer时,这个属性是必需的;
stateNetworkTimeout 设置当使用StateServer模式存储Session状态时,经过多少秒空闲后,断开Web服务器与存储状态信息的服务器的TCP/IP连接的。默认值是10秒钟;
4、Application
示例代码如下:
//a.aspx
////
private void Button1_Click(object sender, System.EventArgs e)
{
Application["name"] = Label1.Text;
}
////b.aspx
private void Page_Load(object sender, EventArgs e)
{
string name;
Application.Lock();
name = Application["name"].ToString();
Application.UnLock();
}
总结:
1、Application对象的作用范围是整个全局,也就是说对所有用户都有效。它在整个应用程序生命周期中都是有效的,类似于使用全局变量一样,所以可以在不同页面中
对它进行存取。它和Session变量的区别在于,前者是所有的用户共用的全局变量,后者是各个用户独有的全局变量。可能有人会问,既然所有用户都可以使用application
变量,那他可以用在什么场合呢?这里举个例子:网站访问数。多个请求访问时都可以对它进行操作。
2、优点:使用简单,消耗较少的服务器资源;不仅能传递简单数据,还能传递对象;数据量大小是不限制的。
3、缺点:作为全局变量容易被误操作。所以单个用户使用的变量一般不能用application。
4、在源页面的代码中创建你需要传递的名称和值构造Application变量:Application["name"]="Value(Or Object)";在目的页面的代码使用Application变量取出传递的值。Result = Application["name"]。
5、常用lock和unlock方法用来锁定和解锁,为了防止并发修改。
5、Cache
代码如下:
//Class1
Cache["id"] = TextBox1.Text;
Response.Redirect("~/WebForm1.aspx");
//Class2
if (Cache["id"]!=null)
{
Label1.Text = Cache["id"].ToString();
}
//移除缓存
Cache.Remove("id");
//如果 Cache["id"]为空,则传值失败。可使用如下方法实
//限期为10分钟
Cache.Insert("id",TextBox1.Text,null,Cache.NoAbsoluteExpiration,new TimeSpan(0,10,0));
总结如下:
1、应用程序中的缓存机制用于将需要大量服务器资源来创建的对象存储在内存中,以此大大改进应用程序的性能。这个机制同样可以用来传值。
2、与其他方法不同的是,该方法需要设置缓存项优先级和缓存时间。因为当系统内存缺乏时,缓存机制会自动移除很少使用或优先级较低的项,从而造成传值失败。
3、该方法的优点是传递数据的大小和数量无限制,速度快。缺点是缓存机制的操作相对比较复杂。
6、Cookie
//Class1
HttpCookie httpCookie = new HttpCookie("testCookie","Page transfers by Cookie");
Response.Redirect("~/Class2.aspx");
//Class2
Label1.Text = Request.Cookies["testCookie"].Value;
总结:
1、Cookie用于在用户浏览器上存储小块的信息,保存用户的相关信息,比如用户访问某网站时用户的ID,用户的偏好等,用户下次访问就可以通过检索
获得以前的信息。所以Cookie也可以在页面间传递值。
2、Cookie通过HTTP头在浏览器和服务器之间来回传递的。Cookie只能包含字符串的值,如果想在Cookie存储整数值,那么需要先转换为字符串的形式。
3、与Session一样,其是什对每一个用户而言的,但是有个本质的区别,即Cookie是存放在客户端的,而session是存放在服务器端的。而且Cookie的使
用要配合ASP.NET内置对象Request来使用。
4、使用简单,是保持用户状态的一种非常常用的方法。比如在购物网站中用户跨多个页面表单时可以用它来保持用户状态。
5、常常被人认为用来收集用户隐私而遭到批评。
6、安全性不高,容易伪造。
7、 Context.Items["id"]
Contextu对象包含与当前页面相关的信息,提供对整个上下文的访问、包括请求、响应、以及上下文中的信息;
可以使用此对象在网页之间共享信息,从而实现页面之间的传值;
与使用Form的方法类似,该方法也能保持大量的数据,缺点也相同,但是使用方法相对比较简单;
8、ViewState
示例代码:
ViewState["id"]="hello nueq" //数据保存
Label1.Text=ViewState["id"].ToString();//数据取出
ViewState.Remove("id");//删除数据
9、web.Config 和 machine.Config
核心代码:
//Class1
using System.Web.Configuration;
WebConfigurationManager.AppSettings.Set("userName",TextBox1.Text);
Response.Redirect("~/Class2.aspx");
//Class2
using System.Web.Configuration;
Label1.Text = WebConfigurationManager.AppSettings["userName"];
总结:
1、每个Web运用程序继承web.config文件和machine.config文件的设置。
2、web.config和machine.config这两种文件保存数据一般都很小,多为明文,特别适合保存一些字符串常量,如数据库连接信息。此外,web.config文件是可以
扩展的,因此,也可以用来传递变量。由于这两种文件会被自动缓存,所以不存在因磁盘IO产生的性能瓶颈等问题。要注意的是文件中某些设置会导致文件被修改后
Web运用程序的重启。
3、web.config:你可以向单个Web运用程序运用设置。例如,你可能会希望设置特定的验证方法、调试的类型、默认语言或自定义的错误页面。但如果你要使用这些
设置,必须把web.config文件放到web运用程序的根虚拟目录下。要想在Web运用程序中进一步配置自己的子目录,需要 在这些文件夹中放置附加的web.config。
(关于ASP.NET web.config文件详细介绍,可参考我另外一篇博客:ASP.NET web.config)
4、machine.config:从c:\Windows\Microsoft.NET\Framework\Framework\[Version]\Config目录中的一个叫macine.config的文件开始 配置。machine.config
文件定义支持的配置文件节,配置ASP.NET工作者进程,注册可用于高级特性(如配置文件、成员资格以及基于角色的安全等)提供程序。(关于ASP.NET machine.config