Asp.net知识初步小结

1Page_Load事件中的!Page.isPostBack:

    Page_Load子程序在每次页面加载的时候都会运行。如果只想在第一次加载此页面的时候执行Page_Load中的代码,可以使用Page.IsPostBack属性。如果Page.IsPostBack属性为false,页面是第一次被加载,如果为true,则页面是被“投递”(post)回服务器。


举例子:

protected void Page_Load(object sender, EventArgs e)        {
            if (!Page.IsPostBack)
            {
    //判断是否是第一次加载页面,如果是第一次加载页面则把文本框的内容清空
                this.txtUserName.Text = "";
                this.txtUserPwd.Text = "";
            }        
            
        }

说明:如果Page.IsPostBack==false则文本框内容清空,表示页面是第一次加载。


     Page.IsPostBack表示是不是回发动作.所谓的回发就是在页面加载以后,在本页有提交服务器的动作.Page.IsPostBack    ==    true表示是回发;为了响应客户端的请求,Page.IsPostBack==false,所以正确应用好Page.IsPostBack能大大的提高应用程序的性能。


总结:

1IsPostBack只有在第一次打开的时候是false,其它时候都是true


2)每次页面Load的时候,根据需要把每次都要加载的代码放在IsPostBack中,只需要加载一次的代码放在if(!IsPostBack)中。


3)每次用户回传服务器任何信息的时候,都会引发isPostBack属性用来判断此用户是否曾经做过登陆或者其他事件


4)Post方式如果Request中没有请求值,即Request.Form=null则IsPostBack=false;Get方式如果Request中没有请求值,即Request.QueryString=null则IsPostBack=false。


5一般情况判断Request中如果没有请求值则IsPostBack=false。如果有请求值但是不包括“__VIEWSTATE”等一些特殊的键或值,则IsPostBack=false(每次请求后.Net框架会将一些特殊的隐藏域“__VIEWSTATE”等返回给客户端)。还有一些特殊的情形是上面的规则不能正确判断的需要特殊处理的,这些情形包括Server.Transfer,Response.Redirect,CrossPagePostBack,Server.Execute,发生了页面元素变化及重新编译。


2、RequestResponse的区别

    Request是客户端向服务器发送请求;Response是服务器向客户端输出信息。

   (1) Request的对象的属性:

        Form:获得网页中定义的窗体变量的集合;

        QueryString获得以名/值对表示的HTTP查询字符串变量的集合。变量值会在地址栏显示,安全性不能保证。传递Form表单中的控件值用Request.Form获取值,地址栏中传递的参数用Request.QueryString获取。


    1>.getpost两种提交的区别:

    get是从服务器上获取数据,post是向服务器传送数据。

    get是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到;post是通过HTTPpost机制,将表单内各个字段与其内容放置在HTML HEADER内一起传送到ACTION属性所指的URL地址。用户看不到这个过程。

   对于get方式,服务器端用Request.QueryString获取变量的值,对于post方式,服务器端用Request.Form获取提交的数据.

  get传送的数据量较小,不能大于2KB。post传送的数据量较大,一般被默认为不受限制。

  get安全性非常低,post安全性较高,包含机密信息的话,建议用Post数据提交方式.但是执行效率却比Post方法好.

  在做数据查询时,建议用Get方式;而在做数据添加、修改或删除时,建议用Post方式。

 

2>拿登陆界面来做例子:


a.get方式

<form  method="get" action="WebForm2.aspx">
        <table border="0" style="width:100%;">
            <tr>
                <td> </td>
                <td>
                    <input id="Text1" name="txtUserName" type="text" /></td>
                <td> </td>
            </tr>
            <tr>
                <td class="auto-style1"></td>
                <td class="auto-style1">
                    <input id="Text2" name="txtUserPwd" type="text" /></td>
                <td class="auto-style1"></td>
            </tr>
            <tr>
                <td> </td>
                <td>
                    <input id="Submit1" type="submit" value="登录" /></td>
                <td> </td>
            </tr>
        </table>

    </form>


接收用get方法传输的数据写法:

  protected void Page_Load(object sender, EventArgs e)        {
            
            string userName =Request.QueryString["txtUserName"].ToString();
            string userPwd =Request.QueryString["txtUserPwd"].ToString();
            
            if (userName =="a"&&userPwd =="a")
            {
                Response .Redirect ("WebForm1.aspx?userName="+userName+"&userPwd="+userPwd);
            }
            else
            {
                Response.Redirect("login.html");
            }
        }


b.post方式

<form  method="post" action="WebForm2.aspx">
        <table border="0" style="width:100%;">
            <tr>
                <td> </td>
                <td>
                    <input id="Text1" name="txtUserName" type="text" /></td>
                <td> </td>
            </tr>
            <tr>
                <td class="auto-style1"></td>
                <td class="auto-style1">
                    <input id="Text2" name="txtUserPwd" type="text" /></td>
                <td class="auto-style1"></td>
            </tr>
            <tr>
                <td> </td>
                <td>
                    <input id="Submit1" type="submit" value="登录" /></td>
                <td> </td>
            </tr>
        </table>

    </form>


接收用Post方法传输的数据写法:

protected void Page_Load(object sender, EventArgs e)        {

            string userName = Request.Form.Get("txtUserName").ToString();
            string userPwd = Request.Form.Get("txtUserPwd").ToString();
           
            if (userName =="a"&&userPwd =="a")
            {
                Response .Redirect ("WebForm1.aspx?userName="+userName+"&userPwd="+userPwd);
            }
            else
            {
                Response.Redirect("login.html");
            }
        }


(2)Response常用方法:

       write:用于向当前HTTP响应流写入文本,使其成为返回页面的一部分;

       Redirect:将用户从请求页面重新定向或带到另一页面。


3、html,htm,xml区别

    htm也就是html.都是静态网页文件的扩展名。htm是DOS三字符文件扩展名时代而来;html是windows时代支持多字符扩展名。

    Xml是用来存储数据的,重在数据本身。而HTML是用来定义数据的,重在数据的显示模式。XML是结构化的信息中包含了一些内容(例如文字,图片等)和一些指示出内容的重现手段的标记(例如,在一个章节头部的信息和其脚注处的信息是有不同含义的。)所有的文档都有不同的结构。一种标记语言,是定义文档结构的机制。XML规范定义了一个对文档进行标记的标准。


总结:ASP.NET这只是一个开端,还有更多的知识等待我们去学习,更多的宝藏等待我们去挖掘。
  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 13
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值