码迷,mamicode.com
首页 > Web开发 > 详细

Programming ASP.NET(1) - ASP.NET WebForms

时间:2014-09-18 16:15:04      阅读:196      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   io   os   使用   strong   for   

HTTP请求:

浏览器请求URL-->通过DNS转换为IP地址-->浏览器打开一个socket,连接到IP所指服务器的80端口。

请求报文:
GET /default.aspx HTTP/1.1 (此外还有GET, PUT, DELETE等)
Host: www.mycloud.com (标头:http报头)
User-Agent:(标识发出该请求的浏览器类型)
Connection:(关闭连接或保持现有连接有效)
If-Modified-Since:(提供客户端缓存验证)

HTTP响应:

包含一个状态行和几个标头

HTTP/1.1 200 OK (状态行:包括消息协议版本和状态码)
Server: Microsoft-IIS/6.0
Content-Type: text/html (该类型由给定的MIME类型(text/html)表示)
Content-Length: 55

<html><body><h1>Asp.net Programming</h1></body></html>

最后一个标头和HTTP响应内容之间的空行并不只是为了格式化——回车与换行是必不可少的,且是该schema中相当重要的内容之一。

服务器端抽象层的构建:

浏览器与Web服务器间的每次会话都会引起数据包(packet)报文的交互,这与前面我们所讨论的类似。如果所请求的URL是一个HTML页面,则Web服务器一般会读取该.html文件的内容,并将其刷新到(flush)响应报文的主体中。如果URL是ASP.NET页面,则会涉及一个特殊的IIS模块。这个模块是一个IIS ISAPI插件,被称作“ISAPI扩展”。
 
ISAPI扩展是按照一个文件一个扩展的方式注册的动态链接库(DLL)。每当有.aspx文件的请求时,就需要有一个用来处理这种文件(资源)类型的ISAPI扩展。这个ISAPI扩展会分析该请求,并配置要实际处理该页面的服务器端环境。若成功获取该请求的状态并完全还原,便允许这个页面运行并输出期望的结果。 

提交窗体:

HTML的<form>标签是唯一授权、能将客户端数据提交到服务器端的标签。根据设计,当用户单击“submit”类型的按钮时,浏览器便将隶属于该窗体(form)的所有控件的当前内容填充进一个字符串。随后,根据<form>标签所设置的属性(attribute),将该字符串作为GET 或POST指令的一部分传给服务器。

下面的HTML片段给出了一个简单的窗体,它只包含一个文本框和一个提交按钮。可以看出,这个窗体将POST指令和default.aspx URL关联在一起:

<form method="post" action="default.aspx">
    <input type="text" name="EmpCode" />
    <input type="submit" value="Send" />
</form>

下面的请求显示了用户输入雇员代码1001,并单击提交按钮时提交的Web服务器POST指令:

POST /default.aspx HTTP/1.1
Host: www.contoso.com
Content-Type: application/x-www-form-urlencoded
Content-Length: 12
EmpCode=1001

在处理页面请求的过程中,ISAPI扩展对请求主体进行解析,并通过方便程序员使用的对象模型将得到的所有请求信息显露出来。例如,EmpCode变量不再是一简单的键/值对,而是转换成一个应用级的集合(Request.Form集合)。该集合代表在原始HTTP编程模型之上建立的第一层抽象Request、ResponseServer等对象构成该调用的HTTP上下文,同样,它们代表了目前大多数Web开发平台(包括JSP和ASP)中的最小对象集合。ASP.NET中的对象要多得多。

Programming ASP.NET(1) - ASP.NET WebForms

标签:style   blog   http   color   io   os   使用   strong   for   

原文地址:http://www.cnblogs.com/thlzhf/p/3979303.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!