----http是無狀態的,
每次http請求戶不影響,都是獨立的;不會記的上次請求;
-------iis原理:輸入地址--socket封裝請求體報文--發送---iis解析封裝響應體---返回;
----httpcontext-兩個對象:httprequest(封裝http請求)和httpResponse(封裝相應響應);
---請求的報文
httprequest解析請求報文,分割請求體的各個部分;
---請求原理總結:
發送一個請求----有httpApplication的processrequest方法 創建一個httpcontext上下文--
并將請求報文信息封裝到httpcontext上下文的httprequest中,并創建響應報文httpresponse;
--代碼:
//將請求報文封裝
1.HttpContext context=new HttpContext("requestr");
//封裝響應
2.HttpApplication application=new HttpApplication();
3.application.ProcessRequest(context);
//發送相應報文:(頭部和主體)
4.socket.Send(context.Response.GetHeader());
4.socket.Send(context.Response.BodyData());
?
----HttpApplication.ProcesssRequet的內部實現
public class HttpApplication
{
?? public void processRequest(hhttpContext context)
?? {
????? //處理當前請求,并將相應正文放入response中
????? //處理靜態文件js,css,html,htm
????? //模擬請求靜態頁面(根據請求判斷css,jpg,js,html等類型)
????? //獲取服務端絕對路徑
????? string currenturl=AppDomain.CurrentDomain,baseDirectory;
????? //拼接總路徑
?????? string fileName=path.combine(currenturl,context.request.requesturl);
?????? context.response.bodydata=file.readallbytes(filename);
?? }
}
----處理動態頁面的實現:
public void ProcessDynamicFile(httpcontext context)
{
?? //獲取請求類文件即類名
?? string classname=path.getfilenamewithoutextension(context.request.requesturl);
?? //通過反射獲取當前命名空間
?? string namespace=system.reflection.methodbase.getcurrentMethod?? ().DeclaringType.Namespace;
?? //拼接
?? string fullname=namespace+"."+className;
?? //因為每頁頁面實現Ihttphander(內部封裝了ProcessRequest(context)方法;
?? IhttpHandler obj=(IhttpHandler)System.reflation.Assembly.getexecutingassembly().
?? createinstance(fullName,true);
?? obj.processRequest(context);
}
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
