程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> ASP.NET基礎 >> 值得收藏的asp.net基礎學習筆記

值得收藏的asp.net基礎學習筆記

編輯:ASP.NET基礎

值得收藏的asp.net基礎學習筆記,分享給大家。

1.概論 浏覽器-服務器 B/S 浏覽的 

浏覽器和服務器之間的交互,形成上網B/S模式

對於HTML傳到服務器  交給服務器軟件(IIS)  服務器軟件直接讀取靜態頁面代碼,然後返回浏覽器

對於ASPX傳達服務器  交給服務器軟件(IIS)   IIS發現自己處理不了aspx的文件,就去映射表根據後綴名裡找到響應的處理程序(isapi,服務器擴展程序) 問題:IIS如何調用可擴展程序? 答:可擴展程序首先就是按照IIS提供的借口實現代碼,所以IIS就知道如何調用.


2.什麼是asp.net

!asp.net是一種動態網頁技術,在服務器端運行.net代碼,動態生成HTML,然後響應個浏覽器

*注意,主要的操作都是服務器進行操作,浏覽器只是傳輸指令 

!可以使用JavaScript, Dom在浏覽器端完成很多工作,但是有很多工作無法再浏覽端完成,比如存儲數據,訪問數據庫沒復雜的業務邏輯運算,安全性要求高的邏輯運算等.

!服務端控件和HTML控件生成關系: 在aspx頁面中可以使用服務端控件,簡化開放. 但浏覽器只認html, 因此在包含服務端控件的頁面被請求時,頁面中的服務器端控件會組裝成對應的HTML控件代碼字符串,比如 TextBox : <input type="text" />

!asp.net:ASHX(一般處理程序) (在服務器上運行最快的) ,WebForm,WVC3 (Model, View, Controler)

!服務器控件不是新的控件,在浏覽器端仍然是生成html標簽,服務端控件雖然好用,但是也有缺點,並不是什麼地方用服務器端控件都好,具體後面講. 

3.aspx.net裡的常用文件(重點)

第一個小例子: 動態登錄程序

  public void ProcessRequest (HttpContext context) {
  string modelPath = context.Server.MapPath("LoginModel.htm");
  string htmlSendBack = System.IO.File .ReadAllText(modelPath);
  context.Response.ContentType = "text/plain";
  context.Response.Write(htmlSendBack);
  if (!string .IsNullOrEmpty(context.Request.Form[ "txtName"]))
  {
   if (context.Request.Form["txtName" ] == "zhu" &&
    context.Request.Form[ "txtPassword"] == "123" )
   {
    context.Response.Write( "登錄成功!" );
   }
   else
    context.Response.Write( "登錄失敗!" );
  }
 }

4.一般處理程序(HttpHandler)

一.一般處理程序(HttpHandler):

是一個實現System.Web.IHttpHandler特殊接口的類.

任何一個實現了IHttpHandler接口的類都能作為一個外部請求的目標程序: (凡是沒有實現此接口的類,都不會被浏覽器請求)

二.它由支持asp.net的服務器調用和啟動運行.一個HttpHandler程序負責處理它對應的一個或一組URL地址的訪問請求,並接受客戶端發出的訪問信息和產生相應內容.

三.咱可以通過創建一個我們自己的HttpHandler程序來生成浏覽器代碼返回客戶端浏覽器

四.HttpHandler程序可以完成普通類程序能完成的大多數任務:

1.湖區客戶端通過HTML的Form表單提交的數據和URL參數

2.創建對客戶端的響應信息內容

3.訪問服務端的文件系統

4.連接數據庫並開發基於數據庫的應用

5.調用其他類 

5.請求相應的過程 

1.用戶在浏覽器地址欄輸入:http://localhost:80777/FirstShower.ashx
2.服務器接收到用戶的請求,發現是請求.ashx文件,便將請求交給framework執行,fw找到對應的文件first.ashx,執行後將生成的字符串(通常是html+css+javascript格式)返回浏覽器
3.浏覽器接收到服務器返回的數據,並按照http語法解釋執行,以界面的方式展示給用戶看到.(此時如果html等代碼中包含外部文件,則再次發送單獨請求服務器相應文件數據) 

 6.HTTP請求詳解圖 

7.ashx? -HttpHandler(一般處理程序)

 IHttpHandler  hander = new 頁面類();
 hander.ProcessRequest(); //調用的頁面類中的方法,這是接口的優點

ContentType  標記放回對象在網頁中的解釋語言   

text/html使用html語言翻譯

就是設置服務器發出的響應報文的ContentType屬性,浏覽器根據此屬性內容,使用不同的方法處理[響應報文]

8.編譯過程 

1.每一個請求都會要創建 一個HttpWorkerRequest和HttpApplication
2.HttpWorkerRequest 裡面 放的是 每一個請求報文裡的數據
3.HttpApplication對象裡面放的是  每一個請求要執行的代碼
4.為每個請求創建單獨的HttpApplication對象, 那麼針對此次請求的所有運行過程都在此對象中完成

Factory的理解:: HttpApplication池,每次HttpApplicationFectory都會在這個池裡找有沒有空閒的HttpApplication對象,如果有,就直接拿出來用,沒有就創建新的使用.

服務器做的事情:  接受浏覽器請求, 創建頁面類的對象, 實現接口, 調用裡面的方法, 返回相應的東東

HttpRuntime裡面,由此類,處理所有的請求,它的工作 

1.分析請求報文,並將報文數據封裝入一個叫做HttpWorkerRequest類對象
2.創建HttpContext對象, 次對象是當前請求的上下文環境,裡面包含處理請求的所有參數數據,其中最重要的就是HttpRequest和HttpResponse兩個類(方便取值)
3.HttpRequest主要包含了所有的請求信息,這些信息來源於HttpWorkRequest對象,對象包含屬性:Form(客戶連接數據)QueryString(客戶端url參數)
4.HttpResponse主要包含了一個FileStream對象, 用來保存頁面類執行過程中要輸出給浏覽器的數據
5.通過調用HttpApplicationFectory的類的一個靜態方法來創建HttpApplication類對象中對應屬性
6.因為在HttpApplication裡要運行被請求的頁面類對象裡的ProcessRequest方法,所以,需要將HttpContext對象傳入到HttpApplication中來   ( IHttpHandler hander = 通過反射方式創建被請求的頁面類對象    )?

執行HttpApplication的ProcessRequest方法 ( 可以將此方法的執行過程看成一個管道 ) 此方法中, 要先後按照順序執行19個委托事件 

•在其中第8個事件時,創建 被請求的頁面類的對象
•在11個和12個中間,執行了 被創建的頁面類的ProcessRequest方法 

9.服務器怎麼接受和發送數據?

HTTP Request Response

9.1 Request(HttpRequest) & Response(HttpResponse)

一, 浏覽器提交數據方式
1 表單 (數據藏在請求報文體中, 格式txtname=jamws&txtpwd=123)

<form action="login.ashx" method="post">
    <input type="text" name="txtname"/> 
    <input type="password" name="txtpwd"/>
 </form>

 2地址欄URL參數(和表單的Get方式一樣):鍵值對 浏覽器請求屬性 http://127.0.0.1/login.ashx?txtname 1=jordan&txtpwd 1=123

二,服務器如何獲取浏覽器提交的數據?
1獲取表單數據 context.Request.Form["txtname"] 
2獲取URL參數: context.Request.QueryString["txtname1"]

三,服務器如何向浏覽器輸出參數

context.Response.Write("我是從服務器輸出到浏覽器的數據!"); 

當用戶在浏覽器點擊提交按鈕時,浏覽器自動幫我們將表單中帶name的控件的值以賦值對字符串的方式,作為[http請求報文體]提交到服務器.

Request本身也可以看做一個客戶端提交過來的所有參數 
Request.Form 包含的只有客戶端通過post方式提交過來的數據
Reuqest.QueryString 包含的只有客戶端通過get方式提交過來的數據

get : 獲得,拿去--當浏覽器發送請求報文是為了從服務器獲得數據的時候,就用get
post : 傳遞,有地,發送過去. --當浏覽器發送請求報文傳遞參數過去,就用post 


public void ProcessRequest (HttpContext context) {
  context.Response.ContentType = "text/html";
  System.Text. StringBuilder sbHTML = new System.Text.StringBuilder();
  sbHTML.Append( "<html><head><title>登錄頁面</title></head><body><form action='03Login.ashx' method='post'>");
  sbHTML.Append( "用戶名:<input type='text' name='txtname' /> <br />" );
  sbHTML.Append( "密碼:<input type='password' name='txtpwd' /> <br/>" );
  sbHTML.Append( "<input type='submit' value='登錄'/><a href='04Reg.ashx?a=222'>注冊</a> <br/>");
  sbHTML.Append( "</form></body></html>" );
  context.Response.Write(sbHTML.ToString());
  //獲得浏覽器表單post方式傳遞來的值
  string strUserName = context.Request.Form["txtname"];
  if (!string .IsNullOrEmpty(strUserName))
  {
   context.Response.Write( "Form中的值:" + strUserName);
  }
  //獲得浏覽器表單get方式傳遞來的值
  string strUserNameGet = context.Request.QueryString["txtname"];
  if (!string .IsNullOrEmpty(strUserNameGet))
  {
   context.Response.Write( "Url中得到的值:" + strUserNameGet);
  }
 }

9.2 Request(HttpRequest) 重要成員

重定向原理圖如下: 

------------------模擬wubForm的用戶控件數據保持------------------

  public void ProcessRequest (HttpContext context) {
  context.Response.ContentType = "text/html";
  string strNum1 = context.Request.Form["txtNum1" ];
  string strNum2 = context.Request.Form["txtNum2" ];
  //判斷是否格式正確
  string result = "0" ;
  int num1 = 0, num2 = 0;
  if (!string .IsNullOrEmpty(strNum1) && ! string.IsNullOrEmpty(strNum2))
  {
   
   if (int .TryParse(strNum1, out num1) && int.TryParse(strNum2, out num2))
   {
    result = (num1+num2).ToString();
   }
   else
   {
    result = "輸入格式錯誤" ;
   }
  }
  System.Text. StringBuilder sbHTML = new System.Text.StringBuilder();
  sbHTML.Append( "<!DOCTYPE><html><head><title>計算器</title></head><body><form action='06Calculate.ashx' method='post'>");
  sbHTML.Append( "<input type='text' name='txtNum1' value='" +
   num1.ToString() + "' /> + <input type='text'name='txtNum2' value='" +
   num2.ToString() + "'/> = <input type='text' readonly='readonly' value='" +
   result.ToString() + "' <br/>");
  sbHTML.Append( "<input type='submit' value='計算'/><br />" );
  sbHTML.Append( "</form></body></html>" );
  
  context.Response.Write(sbHTML.ToString());
 }

------------------模擬WebForm回傳檢查機制------------------ 

  public void ProcessRequest (HttpContext context) {
  context.Response.ContentType = "text/html";
  string strNum1 = context.Request.Form["txtNum1" ];
  string strNum2 = context.Request.Form["txtNum2" ];
  //判斷是否格式正確
  string result = "0" ;
  int num1 = 0, num2 = 0;
  //如果包含隱藏域的話, 才執行相加操作
  if (!string .IsNullOrEmpty(context.Request.Form[ "hidIsPostBack"]))
  {
   if (!string .IsNullOrEmpty(strNum1) && ! string.IsNullOrEmpty(strNum2))
   {
    if (int .TryParse(strNum1, out num1) && int.TryParse(strNum2, out num2))
    {
     result = (num1 + num2).ToString();
    }
    else
    {
     result = "輸入格式錯誤" ;
    }
   }
  }
  System.Text. StringBuilder sbHTML = new System.Text.StringBuilder();
  sbHTML.Append( "<!DOCTYPE><html><head><title>計算器</title></head><body><form action='06Calculate.ashx' method='post'>");
  sbHTML.Append( "<input type='text' name='txtNum1' value='" +
   num1.ToString() + "' /> + <input type='text'name='txtNum2' value='" +
   num2.ToString() + "'/> = <input type='text' readonly='readonly' value='" +
   result.ToString() + "' <br/>");
  sbHTML.Append( "<input type='submit' value='計算'/><br />" );
  sbHTML.Append( "<input type='hidden' name='hidIsPostBack' value='1' /></form></body></html>" );
  
  context.Response.Write(sbHTML.ToString());
 }

----------------------------基於面向對象的計算器----------------------------

 //---------------------------------類定義--------------------------------------------
/// <summary>
///一個計算器類
/// </summary>
public class Class1
{
 //第一個操作數
 public int num1 { get; set; }
 //第二個操作數
 public int num2 { get; set; }
 //操作符
 public string calculateChar{ get; set; }
 //結果
 public string result { get; set; }
 public Class1()
 {
 }
 /// <summary>
 /// 計算結果
 /// </summary>
 /// <param name="a"> 第一個操作數 </param>
 /// <param name="b"> 第二個操作數 </param>
 /// <param name="oper"> 操作符</param>
     public void GetResult(int a, int b, string oper)
    {
  this.num1 = a;
  this.num2 = b;
  this.calculateChar = oper;
  switch (this .calculateChar)
  {
   case "+" :
    result = (num1 + num2).ToString();
    break;
   case "-" :
    result = (num1 - num2).ToString();
    break;
   case "*" :
    result = (num1 * num2).ToString();
    break;
   case "/" :
    result = (num1 / num2).ToString();
    break;
  }
    }
}
 
//------------------------------------------------------頁面類----------------------------------------------------------
public class _07CalculateFour : IHttpHandler {
 
 public void ProcessRequest (HttpContext context) {
  context.Response.ContentType = "text/html";
  //實例化一個計算器對象
  Class1 calcu = new Class1();
  string strNum1 = context.Request.Form["txtNum1" ];
  string strNum2 = context.Request.Form["txtNum2" ];
  string strOper = context.Request.Form["optionOper" ];
  int num1 = 0;
  int num2 = 0;
  if (!string .IsNullOrEmpty(context.Request.Form[ "hidIsPostBack"]))
  { //模擬回訪
   if (!string .IsNullOrEmpty(strNum1) && ! string.IsNullOrEmpty(strNum2))
   { //判斷為空
    if (int .TryParse(strNum1, out num1) && int.TryParse(strNum2, out num2))
    { //判斷格式
     calcu.GetResult(num1, num2, strOper);
    }
    else
    {
     calcu.result = "參數格式不正確" ;
    }
   }
  }
  System.Text. StringBuilder sbHTML = new System.Text.StringBuilder();
  sbHTML.Append( "<!DOCTYPE ><html><head></head><body><form action='07CalculateFour.ashx' method='post'>");
  sbHTML.Append( "<input type='text' name='txtNum1' value='" +calcu.num1.ToString()+"'/>");
  sbHTML.Append( "<select name='optionOper'><option value='"+calcu.calculateChar+ "'>"+calcu.calculateChar+"</option><option value='+'>+</option><option value='-'>-</option><option value='*'>*</option><option value='/'>/</option></select>" );
  sbHTML.Append( "<input type='text' name='txtNum2' value='" +calcu.num2.ToString()+"'/> = ");
  sbHTML.Append( "<input type='text' readonly='readonly' name='txtResult' value='" +calcu.result+"'/>");
  sbHTML.Append( "<input type='submit' value='計算'/>" );
  sbHTML.Append( "<input type='hidden' name='hidIsPostBack' value='1'/></form></body></html>" );
  context.Response.Write(sbHTML.ToString());
 }

 10.注意,關於提交表單的內容 

•只能為input, textarea, select三種類型的標簽, 只有input(文本框/CheckBox等)用戶才可以填寫值,<label>,<p>,<font>等標簽僅提供顯示用,沒有提交到服務器的必要.
•只有value屬性的值才會提交給服務器, 以input標簽為例, input標簽有title,type,disabled等屬性,但這些屬性都是供顯示用的,用戶不能修改,只有value屬性才是用戶輸入的屬性,因此只有value屬性的值才會被提交到服務器
•標簽必須設置name屬性. 學習Dom的時候我們知道,如果通過Javascript操作標簽,必須為標簽設定id屬性. 如果要將標簽的value屬性提交到服務器,則必須為標簽設定name屬性,提交到服務器會以"name=value"的鍵值對方式提交給服務器,用&隔開,除了單選按鈕等少數標簽,那麼可以重復,其他name都不能重復. name是給服務器用的,id是給dom用的,對於RadioButton,同name的為一組,選中的radiobutton的value被提交到服務器.
•如果設置了控件的disabled屬性的話,浏覽器不會把數據交給服務器
•放到form標簽內,只有放到form標簽才可能會被提交到服務器,form之外的input等標簽被忽略. 

11.使用模版來清晰代碼,利用虛擬模版網頁 

•使用隱藏字段, 模擬IsPostBack, <input type="hidden" name="hidIsPostBack" value="true" />
•在模版網頁中,涉及到修改值得時候, 可以使用占位符, 之後, 直接替換就可以了, 使用{name}的形式即可 

public class _08Cal : IHttpHandler {
 
 public void ProcessRequest (HttpContext context) {
  context.Response.ContentType = "text/html";
  //--------------------讀取html內容模版----------------------
  //根據虛擬路徑獲得物理路徑
  string path = context.Server.MapPath("CalculateModel.htm"); //這裡仔細記住
  string strHTML = System.IO.File.ReadAllText(path); //這裡也要好好記住
  //------------------獲得浏覽器提交的內容---------------------------
  string strNum1 = context.Request.Form["txtNum1"];
  string strNum2 = context.Request.Form["txtNum2"];
  int num1 = 0;
  int num2 = 0;
  string result = "";
  if (!string.IsNullOrEmpty(context.Request.Form["hidIsPostBack"]))
  {
   if (!string.IsNullOrEmpty(strNum1) && !string.IsNullOrEmpty(strNum2))
   {

    if (int.TryParse(strNum1, out num1) && int.TryParse(strNum2, out num2))
    {
     result = (num1 + num2).ToString();
    }
    else
    {
     result = "輸入格式錯誤";
    }
   }
  }
  //-------------------------輸出html到浏覽器------------------------
  //字符串替換,進行賦值
  strHTML = strHTML.Replace("{num1}", num1.ToString()).Replace("{num2}", num2.ToString()).Replace("{result}", result.ToString());
  context.Response.Write(strHTML);
 }
 
 public bool IsReusable {
  get {
   return false;
  }
 }

}

//---------------------------------模版網頁顯示---------------------------------------
<! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
< html>
< head>
 < title> 計算器 </title >
</ head>
< body>
 < form action ='06Calculate.ashx' method ='post'>
 < input type ='text' name ='txtNum1' value ='{num1}' /> + 
 < input type ='text' name ='txtNum2' value ='{num2}' /> =
 < input type ='text' readonly ='readonly' value ='{result}' />< br />
 < input type ='submit' value ='計算' />
 < input type ='hidden' name ='hidIsPostBack' value ='1' />
 </ form>
</ body>
</ html>

12.表單的提交方式Get與Post 

     get傳遞的數據量是有限的, post發送的數據量沒有限制  
     post會產生刷新重新提交表單的問題, get就沒有這樣的問題,  可以通過地址欄重敲解決該問題 
     Get方式URL數據格式,  ? 後面  & 分割,  URL中有漢字會進行URL編碼 

     表單域只有設定了name的才會傳參, get看得清楚, submit如果有value, 也會傳遞

13.數據自增 

•http是無狀態的, 浏覽器每次請求服務器的頁面類時,服務器都會創建一個該類的對象,並調用裡面的方法執行,最後返回輸出結果給浏覽器,然後對象銷毀斷開連接
•浏覽器和服務器都是不認識對方的 

Connection: Keep-Alive  告訴服務器浏覽器希望使用的長連接   短連接是相當於一次性連接 

短連接的缺點: 盡管客戶只想訪問一個頁面,html但依然向浏覽器發送了多次新的連接請求,建立了多次新的連接,消耗了雙方的時間的資源 

http短連接: 服務器在每次響應完浏覽器的一個請求後立馬關閉當前連接(socket). 

長連接:  服務器不會立刻在發送完數據後關閉連接通道(套接字),而是會等一段時間(2秒),兩秒之內,如果相同浏                             覽器再次發送請求過來,那麼繼續使用此連接通道向浏覽器輸出數據,然後再登一段時間,直到2秒後,沒有新的請求過來,那麼服務器關閉連接通道 

反編譯工具不停去找,去理解原理,運行機制  ---  牛人 

一般處理程序_簡單請求, 關於ContentType, 獲得url參數(http參數get/post傳遞本質). (請求過程原理; 總體請求過程原理,頁面編譯過程), 請求數據和接受數據以及定向原理, 模擬WebForm回傳檢查機制, 模擬wubForm的用戶控件數據保持, 自增(解決http的無狀態), 登錄過程 

接下去的學習: 

加法計算器, 增刪查改, 搭建三層構架, 列表和刪除, 刪除信息功能, 新增 

上傳單個文件, 生成縮略圖, 一般處理程序輸出圖片(簡單驗證碼圖片), 輸出水印圖片, 附近下載, 復習總結。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved