Object(Asp.NET核心機制內置對象彙總)

ASP.NET有個大佬,HttpContext(在.Net Core中依然是它)Http請求的上下文,任何一個環節都是須要HttpContext的,須要的參數信息,處理的中間結果,最終的結果,都是放在HttpContext,是一個貫穿全局的對象。html

所謂的六大對象,其實就是HttpContext的屬性json

一、Requestapi

  url參數,form參數,url地址,URLRefer,content-encoding,就是http請求提供的各類信息,後臺裏面都是能夠拿到的context.Request.Headers["User-Agent"],包括自定義的BasicAyth,請求信息的解讀是asp.net_isapi按照http協議解析出來的跨域

二、Response瀏覽器

  響應,response.Write,各類Result擴展就是序列化+response,所謂response都是給客戶端響應內容,出了body(json/html/file),其實還有不少東西,各類header,反正都是交給瀏覽器去用的緩存

三、Application服務器

  全局的東西,多個用戶共享的,技術---統計下網站的請求書cookie

四、Server session

  也就是個幫助類庫負載均衡

五、Cookie

  用戶登陸驗證,登陸時寫入,驗證時獲取,保存用戶數據(記住帳號;購物車,如今不放cookie裏面了;訪問過哪幾個頁面),一個用戶一個cookie,也是字典式的。

  存在客戶端,不能有敏感信息,推薦加密,每次請求的時候,都會提交,不能太大,能夠存瀏覽器,沒有指定expiretime,關閉瀏覽器就丟失了,想存在硬盤就指定expiretime,想清空就修改有效期。同一個瀏覽器登陸覆蓋問題,一個瀏覽器cookie只有一個地方存儲。可使用谷歌瀏覽器的無痕模式,是不存cookie的。

六、Session

  用戶登陸驗證時,登陸時寫入,驗證時獲取,驗證碼,跳轉到當前頁,一個用戶一個session,k-v形式的,字典式的。  

  服務器內存(sessionstateserver/SQLserver),體積不要太大,能夠存敏感信息,重啓丟失。一個用戶一條,常常作傳值(tempdata),負載均衡下session怎麼處理?會話粘滯/session共享。若是瀏覽器禁用了cookie,還能用session嗎?不能的,可是能夠經過url地址傳遞sessionid。

瀏覽器關閉,登陸就失效了,這是爲何呢?

  cookie存在瀏覽器內存,關閉瀏覽器後,cookie就沒了,再次打開分配了新的sessionid,因此沒有登陸,以前登陸的那個session仍是在內存裏面的。

  若是但願從新打開用戶還在登陸狀態,就是在硬盤上存儲cookie(expiretime),後臺要檢測cookie,承認cookie的有效性(第一次檢測cookie,而後仍是寫入session,每次仍是checksession)

協議:

  就是一個約定,保證多方的信息傳輸(中文也是一種約定)

  Http協議:超文本傳輸協議,也就是個文本傳輸的規範,瀏覽器/客戶端遵循;服務端也遵循,那麼就能夠發起交互了。

Http協議理解,請求/響應

 

 

Http的請求過程,就像發一個命令,實現約定好對個,瀏覽器按照格式組裝命令

請求行:url長度有限制

Header:有不少默認都是瀏覽器寫的,也能夠本身來,WebApi的Authorize,瀏覽器其實是一個實現了Http協議標準的應用程序

Body:表單參數/上傳的文件/圖片(字符串),沒有長度限制

 

C/S,客戶端/服務端

  客戶端連接到服務器socket,發起請求,服務器完成響應,釋放連接

 B/S,瀏覽器/服務器

  簡單快速,靈活,任何類型均可以返還,無狀態(沒有長時間的連接,沒有連續的連接),無狀態(兩次請求都沒有關聯,因此沒法識別)

  回發一個結果,實現約定好規格,服務器按照格式組裝結果

  響應行:StatusCode

  Header:壓縮格式,緩存,WebApi權限,跨域,你控制的得瀏覽器支持

  Body:返回的主體

相關文章
相關標籤/搜索