Session对象
运用于多个界面调用某一个特定的用户信息,也就是每个Session 对象是独立的,个不受影响。
Session对象的读取和存储
Session[name]=”chen”;
可以用来界面之间参数传递
webForm1.aspx:
Session["name"]="chen";
Response.Redirect("~/webForm2.aspx");
webForm2.aspx:
Response.Write("welcome" + Session["name"].ToString());
Cookie对象
主要运用于保存用户请求的客户端浏览器界面以及用户的一些私密性信息,还可以设置保存的时间等。
保存和读取客户端的内容信息
保存:
Response.Cookies[“name”].Value=”chen”;
读取:
string myname=Request.Cookies[“name”].Value;
一般运用于投票,防止一个人多次投票。
设定Cookie的生命周期
Response.Cookies[“name”].Expires=日期;
TimeSpan ts=new TimeSpan(0,0,20,0);
Response.Cookies[“name”].Expires=DateTime.Now.Add(ts);//20分钟后过期
Response.Cookies[“name”].Expires=DateTime.Now.AddMonth(1);//1个月后过期
Response.Cookies[“name”].Expires=DateTime.Parse(“10/20/2016”);//指定日期后过期
Response.Cookies[“name”].Expires=DateTime.MaxValue;//永不过期
Response.Cookies[“name”].Expires=DateTime.MinValue;//关闭浏览器后过期
例:
判断在一分钟之前,chen是否进入该网站,当未进入,显示“1分钟前chen未进入了该网站”将chen写入Cookie,否则显示“1分钟前chen进入了该网站”。
TimeSpan ts=new TimeSpan(0,0,1,0);
Response.Cookies["name"].Expires=DateTime.Now.Add(ts);//1分钟后过期
string myname=Request.Cookies["name"].Value;
if (myname == "chen")
{ Response.Write("1分钟前chen进入了该网站");}
else { Response.Write("1分钟前chen未进入了该网站");
Response.Cookies["name"].Value="chen";
}}
同样可以实现一个人投票功能。
Server对象
它定义了一个与web服务器相关的类,可以访问服务器的上的方法和属性,主要用于访问服务器上的资源信息。
重定向页面
Server.Execute 和 Server.Transfer 方法
两者之间差别:前者方法是将转移后的页面显示在当前页面,控制权在仍为当前页面;
后者方法是直接显示转移后的界面,控制权为转移后的界面。
WebForm1.aspx:
前台:
<div>
WebForm1.aspx
<asp:Button ID="Button1" runat="server" Text="Excute" onclick="Button1_Click" />
<asp:Button ID="Button2" runat="server" Text="Transfer"
onclick="Button2_Click" />
</div>
后台:
protected void Button1_Click(object sender, EventArgs e)
{ Server.Execute("WebForm2.aspx?message=Excute"); }
protected void Button2_Click(object sender, EventArgs e)
{ Server.Transfer("WebForm2.aspx?message=Tranfer"); }
运行结果
//执行事件前界面
//执行Server.Excute方法界面
//执行Server.Transfer方法界面
获取服务器物理地址
运用Server.MapPath方法获取
Server.MapPath(“WebForm1.aspx”);//获取WebForm1.aspx物理文件路径
Server.MapPath(“.”);//获取当前目录所在服务器的物理文件路径
对字符串进行编码和解码
使用UrlEncode和URLDecode方法对通过URL传递服务器的数据进行编码和解码
Server.UrlEncode("http://WebForm2.aspx");
//将http://WebForm2.aspx 编码为 http%3a%2f%2fWebForm2.aspx
Server.UrlDecode("http%3a%2f%2fWebForm2.aspx");
//将http%3a%2f%2fWebForm2.aspx 解码为 http://WebForm2.aspx
注意:有时候 Response.Redirect 传参数时会导致数据丢失几个字节,我们可以先将要传递的数据进行编码,传到另一个网页后,进行解码。
WebForm1:aspx:
string name=Server.UrlEncode("chen");
Response.Redirect("~/WebForm2.aspx?Name="+name)
WebForm2.aspx:
string myname=Server.UrlDecode(Request.QueryString[Name]);
另:Response.Redirect方法 与 Server.Transfer方法 区别
1、Response.Redirect可以切换到任何存在的网页。
2、Server.Transfer只能切换到同目录或者子目录的网页。
a、Response.Redirect后地址会变成跳转后的页面地址。
b、Server.Transfer后地址不变,隐藏了新网页的地址及附带在地址后边的参数值。具有数据保密功能。
I、Response.Redirect能够传递的数据以2KB为限。
II、传递的数据超过2KB时,务必使用Server.Transfer。