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

【.NET特供-第三季】ASP.NET MVC系列:传统WebForm网站和MVC网站运行机制对比

时间:2014-08-21 17:17:04      阅读:216      评论:0      收藏:0      [点我收藏+]

标签:webform   mvc   

本文以图形化的方式,从‘运行机制’方面对比传统WebForm网站和MVC网站。

请参看以下图形:

bubuko.com,布布扣


一、运行机制

当我们访问一个网站的时候,浏览器和服务器都是做了哪些动作呢?

(本文只是提供一个简单的运行过程,有兴趣的找资料研究一下复杂的网络过程。)

 

(一)WebForm网站运行机制

假设为:www.baidu.com/index.aspx

1、Http请求(物理地址:index.aspx)

①发送请求

    浏览器向服务器发送请求报文,此时由IIS虚拟目录接受。(通过配置过IIS,把网站挂载在服务器上,通过访问虚拟目录的方式访问网站的。)

②转交请求

    服务器端的IIS软件接收到请求后,把请求交给.NET FrameWork进行处理

③创建页面类对象

    .NET FrameWork根据请求的地址index.aspx,会创建对应的index_aspx类的对象(页面对象)。

IIS的内部机制:

  1. 实现一个IHttphandler的接口
  2. 该接口实现一个ProcessRequest方法
  3. 该方法会调用对应页面的Page_load方法
    • 处理的业务逻辑或者是访问数据库的代码
    • 要输出的Html或者其它内容

2、返回给浏览器

①转交回复

通过IIS传输出给浏览器,要输出的html元素或其他内容(html+js+css等)

②解析为图形界面

浏览器解析html代码,并翻译为图形化界面

 

(二)MVC网站的运行机制

假设为:www.baidu.com/news/index

1、Http请求(逻辑地址:news/index)

①发送请求(news/index)

②转交请求(同上)

③创建类对象+方法

    .NET FrameWork根据路由配置,解析URL,并创建news类的对象,并调用对象的index方法。通过View方法加载视图,然后访问视图文件夹下的index.cshtml 

2、返回给浏览器(同上)

 

二、区别

1、请求方式

①WebForm:index.aspx页面

www.baidu.com/index.aspx

    在用户看来请求的是index.aspx页面,实际上服务器端运行的是index.aspx对应的类(前台页面类的对象),先调用ProcessRequest方法,然后调Page_Load方法

②MVC:类名+方法名

www.baidu.com/news/index

2、服务器端创建对象

①webForm:页面类对象

服务器端创建index.asp的前台页面类的对象‘index.aspx’

②MVC:类对象

MVC:创建news类对象,并调用Index方法。

    .NET FrameWork根据路由配置,解析URL,并创建news类的对象,并调用对象的index方法。通过View方法加载视图,然后访问视图文件夹下的index.cshtml

3、传值方式

①WebForm:CodeBehand

前台-->后台

    前台页面继承于后台页面,可以通过<%...%>方式,访问 台页面公开的属性(强耦合)

后台-->前台

    包含runat=Server控件的前台页面,都会以变量的方式存在于后台类中,供后台调用

②MVC: ViewData

    把ViewData当作一个中间类在Controller和View之间传输数据。好处:强类型视图(将在后续文章中进行论述)。

 

三、总结

本文分别从以下方面,对比了传统WebForm网站和MVC网站的区别:请求方式、创制方式、服务器创建对象。

虽然如此,但WebForm和MVC都是基于ASP.NET管道模型上的两种不同的开发方式。

    (文中粗粒度的知识点,将在后续文中陆续展开)

    



【.NET特供-第三季】ASP.NET MVC系列:传统WebForm网站和MVC网站运行机制对比,布布扣,bubuko.com

【.NET特供-第三季】ASP.NET MVC系列:传统WebForm网站和MVC网站运行机制对比

标签:webform   mvc   

原文地址:http://blog.csdn.net/zhaolijing2012/article/details/38730281

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