ASP.NET内置对象二

时间:2023-03-09 22:21:05
ASP.NET内置对象二

(1)Respose对象

  利用Response对象输出文字信息:

protected void Page_Load(object sender, EventArgs e)
{
  string message = "您好,欢迎光临本网站!";
  Response.Write(message);
}

  

  利用Response对象实现网页跳转:

protected void Page_Load(object sender, EventArgs e)
{
Response.Redirect("http://www.easou.com");
}

  

  利用response对象像浏览器输出字符串:

protected void Page_Load(object sender, EventArgs e)
{
Response.Write(@"C:\Users\light\Desktop\Sample\Sample\Default.aspx");
}

  利用response对象停止输出:

protected void Page_Load(object sender, EventArgs e)
{
for(int ss=1;ss<30;ss++)
{
Response.Writer(i);
if(i==8)
Response.End();
}
}

  利用Response对象传递参数:

Response.Resirect("page.aspx?Num=4");

(2)Request对象

  QueryString的使用。使用QueryString来获取从上一个页面传递来的字符串参数。

    在Default.aspx中:

<div>
  <a href="page1.aspx?Num=1&Name=Liu">页面跳转</a>
</div>

    

    在page1.aspx.cs中:

protected void Page_Load(object sender, EventArgs e)
{
Response.Write("传递来的变量值:");
Response.Write("Num的值:" + Request.QueryString["Num"] + "Name的值" + Request.QueryString["Name"]);
}

  

  用类似的方法也可以获取Form、Cookies、SeverVaiables的值。调用方法是:Request.Collection["variable"](variable是要查询的关键字)。Collection包括QueryString、Form、Cookies、SeverVaiables四种集合。使用方式也可以是Request["variable"],与Request.Collection["variable"]的效果一样。省略了Collection,Request对象就会依照QueryString,Form,Cookies,SeverVaiables的顺序查找,直到发现了variable所指的关键字并返回其值,否则方法返回空值。

  Form集合:

    Request.Form["Name"].ToString();

  ServerVariable集合:

    Request.ServerVariable[参数类型];

  Cookies集合:

    写入数据:

      Response.Cookies[Cookie名称].Value=数据;

      Response.Cookies[Cookie索引号]=数据;

    读取数据:

      CookiesValue=Request.Cookies[Cookie名称].Value;

      CookiesValue=Request.Cookies[Cookie索引号].Value;

  移出某项数据:

    Response.Cookies.Remove("Cookie名称");

  移出所有数据:

    Response.Cookies.Clear();

  Saves的使用(将HTTP请求保存到磁盘):

protected void Page_Load(object sender, EventArgs e)
{
Request.SaveAs("G:/sample.txt", true);
}

 (3)Server对象

  MachineName的使用。获取本地服务器计算机名称。

protected void Page_Load(object sender, EventArgs e)
{
string machineName;
machineName = Server.MachineName.ToString();
Response.Write(machineName);
}

  HtmlEncode、HtmlDecode的使用。将<h1>HTML内容</h1>编码后输出到浏览器中,再利用HtmlDecode方法将编码后的结果还原。

protected void Page_Load(object sender, EventArgs e)
{
string str1;
str1 = Server.HtmlEncode("<h1>HTML编码</h1>");//编码
Response.Write(str1 + "<br/>" + "<br/>");
str1 = Server.HtmlDecode(str1);
Response.Write(str1);
}

  URLEncode、UrlDecode的使用。Server对象的URLEncode方法根据URL规则对字符串进行编码。Server对象的UrlDecode方法根据URL规则对字符串进行解码。URL规则是当字符串数据以URL的形式传递到服务器时,在字符串中不允许出现空格,也不允许出现特殊字符。

protected void Page_Load(object sender, EventArgs e)
{
string str2;
str2 = Server.UrlEncode("http://www.easou.com");
Response.Write(str2+"<br/>"+"<br/>");
str2 = Server.UrlDecode(str2);
Response.Write(str2);
}

(4)ViewState对象

  使用ViewState对象计数。

    在Default.aspx中:

<div>
<a href="page1.aspx?Num=1&Name=Liu">页面跳转</a>
<asp:Button ID="Button1" runat="server" OnClick="Button1_Click"/>
</div>

    在Default.aspx.cs中:

protected void Button1_Click(object sender, EventArgs e)
{
int count ;
if (ViewState["count"] == null)
count = 1;
else
count = (int)ViewState["count"] + 1;
ViewState["count"] = count;
Response.Write("你单间按钮的次数为:" + ViewState["count"].ToString());
}

  ViewState对象安全机制:

    1.哈希编码技术。哈希编码技术被称为是一种强大的编码技术。它的算法思想是让ASP.NET检 查ViewState中的所有数据,然后通过散列算法把这些数据编码。该散列算法产生一段很短的数据 信息,即哈希代码。然后把这段代码加在ViewState信息后面。

    哈希代码的的功能实际上是默认的,如果程序员希望有这样的功能,不需要采用额外的步骤, 但有时开发商选择禁用此项功能。以防止出现在一个网站系统中不同的服务器有不同的密钥。为了 禁用哈希代码,可以在Web.config文件中的<Pages>元素的enableViewStateMac属性。

      <pages enableViewStateMac="false"/>

    2.ViewState加密。尽管程序员使用了哈希代码,ViewState信息依然能够被用户阅读到,很多 情况下这是完全可以接受的。但如果ViewState里包含了需要保密的信息,就需要使用ViewState 加密。

      设置单独某一页面使用ViewState加密:

        <%Page ViewStateEncryptionMode="Always"%>

      设置整个网站使用ViewState加密:

        <pages viewStateEncryptionMode="Always"/>

  使用ViewState对象保留成员变量。基本原理:在Page.PreRender事件发生时把成员变量保存在ViewState中,在Page.Load事件发生时取回成员变量。

    在Default.aspx中:

<table>
  <tr>
    <td colspan="2">
      <asp:TextBox ID="TextBox1" runat="server" Width="100px" BackColor="Beige" />
    </td>
  </tr>
  <tr>
    <td>
      <asp:Button ID="Button1" runat="server" Width="50px" Text="保存信息" OnClick="Button1_Click"/>
    </td>
    <td>
      <asp:Button ID="Button2" runat="server" Width="50px" Text="读取信息" OnClick="Button2_Click"/>
    </td>
  </tr>
</table>

    在Default.aspx.cs中:

protected string TextBoxContent = "";
protected void Page_Load(object sender, EventArgs e)
{
if (this.IsPostBack)//回送
{
TextBoxContent = ViewState["TextBoxContent"].ToString();
}
} protected void Page_PreRender(object sender, EventArgs e)
{
ViewState["TextBoxContent"] = TextBoxContent;
} protected void Button1_Click(object sender, EventArgs e)
{
TextBoxContent = this.TextBox1.Text.ToString();//存储文本信息
this.TextBox1.Text = "";//清除信息
} protected void Button2_Click(object sender, EventArgs e)
{
this.TextBox1.Text = TextBoxContent;//读取TextBoxContent信息
}

  页面间信息传递:

    1)跨页传递。

      在Default.aspx中:

<div>
asp:TextBox ID="TextBox1" runat="server" Width="100px" BackColor="Beige" />
<br/>
<asp:Button ID="Button3" runat="server" Text="跨页传递" PostBackUrl="~/page1.aspx"/>
</div>

      在Default.aspx.cs中:

public string FullContent
{
get
{
return this.Title.ToString() + " " + this.TextBox1.Text.ToString();
}
}

      在page1.aspx.cs中:

protected void Page_Load(object sender, EventArgs e)
{
if (Page.PreviousPage != null)
Response.Write(Page.PreviousPage.Title.ToString());
Default default1=PreviousPage as Default ;
if (default1 != null)
Response.Write("<br/>" + default1.FullContent);//读取Default属性值
}

    2)使用QueryString

      在Default.aspx中:

<div>
<asp:Button ID="Button1" runat="server" Text="QueryString" OnClick="Button1_Click"/>
</div>

      在Default.aspx.cs中:

protected void Button1_Click(object sender, EventArgs e)
{
Response.Redirect("page1.aspx?name=light&age=22");
}

      在page1.aspx.cs中:

protected void Page_Load(object sender, EventArgs e)
{
Response.Write("传递过来的信息为:" + "<br>");
Response.Write("name:" + Request.QueryString["name"].ToString() + "<br>");
Response.Write("age:" + Request.QueryString["age"].ToString());
}

(5)Cookies对象

  Cookie对象默认有效时间为20分钟,超过20分钟Cookie便会被清除。

  写入数据:

    Response.Cookies[Cookie名称].Value=数据;

    Response.Cookies[Cookie索引号]=数据;

  读取数据:

    CookiesValue=Request.Cookies[Cookie名称].Value;

    CookiesValue=Request.Cookies[Cookie索引号].Value;

  移出某项数据:

    Response.Cookies.Remove("Cookie名称");

  移出所有数据:

    Response.Cookies.Clear();

  创建一个cookie实例:

HttpCookie cookie = new HttpCookie("test");//创建一个cookie实例
cookie.Values.Add("Name", "周周");//添加要存储的信息,采用键/值结合的方式
cookie.Expires = DateTime.Now.AddYears(1);
Response.Cookies.Add(cookie);//把cookie加入当前的页面的Respose对象里

  获取cookie信息:

HttpCookie cookie2 = Request.Cookies["test"];
string name1;//声明一个变量用于存储cookie信息
if (cookie2 != null)//判断cookie是否为空
{
name1 = cookie2.Values["Name"];
Response.Write("<br><br>保存的用户名:" + name1);
}

  修改cookie值:

    int counter = 0;
if (Request.Cookies["counter"] == null)
{
counter = 0;
}
else
{
counter = counter + 1;
}
Response.Cookies["counter"].Value = counter.ToString();
Response.Cookies["counter"].Expires = System.DateTime.Now.AddDays(1);

  删除一个cookie:

            HttpCookie cookie3 = new HttpCookie("test");
cookie3.Expires = DateTime.Now.AddYears(-1);
Response.Cookies.Add(cookie3);

  删除当前域中的所有cookie:

            HttpCookie cookie4;
int limit = Response.Cookies.Count;
for (int i = 0; i < limit; i++)
{
cookie4= Request.Cookies[i];
cookie4.Expires = DateTime.Now.AddYears(-1);//设置过期
    Response.Cookies.Add(cookie4);//覆盖
   }
for (int i = 0; i < limit; i++)//判断cookie是否为空
   {
cookie4 = Request.Cookies[i];
name = cookie4.Values["Name"];
Response.Write("<br><br>保存的用户名:" + name);
}

(6)Session对象

  读取数据:

    数据=Session[变量名]或数据=Session[索引号]。

  写入数据:

    Session[变量名]=数据或Session[索引号]=数据。

  移出Session对象中某项数据:

    Session.Remove("命名对象");

    Session.RemoveAt("命名对象索引");

  移出Session对象中的所有数据:

    Session.RemoveAll();

    Session.Clear();

  应用举例:

    在Default.aspx中:

    <div>
<table>
<tr>
<td colspan="2" style="height:80px">
<asp:Label ID="Label1" runat="server"/>
</td>
</tr>
<tr>
<td colspan="2">
<asp:label ID="Label2" runat="server" Text="请选择要查看的学生姓名:"/>
</td>
</tr>
<tr>
<td rowspan="2" style="width:200px">
<asp:ListBox ID="ListBox1" runat="server" Width="100px" Height="100px"/>
</td>
<td style="width:120px;height:20px">
<asp:Button ID="Button1" runat="server" Text="详细信息:" OnClick="Button1_Click"/>
</td>
</tr>
<tr>
<td style="width:120px;height:100px">
<asp:Label ID="Label3" runat="server"/>
</td>
</tr>
</table>
</div>

    在Default.aspx.cs中:

        public class Student
{
public string StuName;
public string StuAge;
public string StuScore;
public Student(string stuName, string stuAge, string stuScore)
{
StuName = stuName;
StuAge = stuAge;
StuScore = stuScore;
}
} protected void Page_Load(object sender, EventArgs e)
{
if (!this.IsPostBack)
{
//定义Student对象
Student student1 = new Student("李米", "24", "89");
Student student2 = new Student("刘宇", "22", "95");
Student student3 = new Student("吴雅", "23", "86");
//Session存储studnet信息
Session["student1"] = student1;
Session["student2"] = student2;
Session["student3"] = student3;
//绑定数据到ListBox
this.ListBox1.Items.Clear();
this.ListBox1.Items.Add(student1.StuName);
this.ListBox1.Items.Add(student2.StuName);
this.ListBox1.Items.Add(student3.StuName);
}
//显示Session信息
this.Label1.Text = "SessionId:" + Session.SessionID.ToString() + "<br>";
this.Label1.Text += "Session数量:" + Session.Count.ToString() + "<br>";
this.Label1.Text += "Session模式:" + Session.Mode.ToString() + "<br>";
this.Label1.Text += "Session有效期:" + Session.Timeout.ToString();
} protected void Button1_Click(object sender, EventArgs e)
{
if (this.ListBox1.SelectedIndex == -1)
this.Label1.Text = "";
else
{
//获取Session键值
string key = "student" + (this.ListBox1.SelectedIndex + 1).ToString();
//获取student对象
Student student = (Student)Session[key];
//显示学生信息
this.Label3.Text += "学生姓名:" + student.StuName + "<br>";
this.Label3.Text += "学生年龄:" + student.StuAge + "<br>";
this.Label3.Text += "学生成绩:" + student.StuScore;
}
}

  Session存储。

    1.在客户端存储。默认状态下在客户端使用Cookie存储Session信息。有时为了防止用户禁用Cookie造成程序混乱,不使用Cookie存储Session信息。

    2.在服务器端存储。包括存储在进程内、存储在进程外、存储在SQL Server中。

(7)Application对象

  Application对象写入数据格式:

    Application[变量名]=数据;

    Application[索引号]=数据。

  Application对象读取数据格式:

    数据=Application[变量名];

    数据=Application[索引号]。

  删除Application对象中的某项数据:

    Application.Remove("命名对象");

    Application.RemoveAt("命名对象的索引");

  移出Application对象中的所有数据:

    Application.RemoveAll();

    Application.Clear();

  加锁:Application.Lock();解锁:Application.UnLock();使用时必须成对出现。

  使用实例:

    在Global.asax.cs中:

        protected void Application_Start(object sender, EventArgs e)
{
//应用程序启动时运行的代码
Application["count"] = 0;
} protected void Session_Start(object sender, EventArgs e)
{
//新会话启动时运行的代码
Application.Lock();
int count = Convert.ToInt32(Application["count"]);
Application["count"] = count + 1;
Application.UnLock();
}

    在Default.aspx.cs中:

        protected void Page_Load(object sender, EventArgs e)
{
//第一次加载页面
if (!IsPostBack)
{
string Count = Application["count"].ToString();
Response.Write("访问次数为:" + Count + "次");
}
}