前言
本文流程#1:
从一个空项目->模拟实现一个从/Home/Test形式的URL敲入->后台逻辑处理->传入后台model参数->调用razor引擎->前台展示
涉及到的知识点#2:
mvc源码 路由 razor引擎等。
适合人群#3:
接触mvc有段时间了,但是想深入了解的人。高手就算了
一.新建一个空项目:
data:image/s3,"s3://crabby-images/13f0d/13f0db286aa4b3f6ec6e774d312b55353c1ed5d3" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
因为web项目的入口是 Global.asax 。所以,我们也新建一个:
data:image/s3,"s3://crabby-images/bc162/bc162158c341e1f50034968d91df5217b8946ffb" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
F5运行程序
data:image/s3,"s3://crabby-images/070d0/070d09abd762aee09fdad5be7a9e325cecec1f72" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
果然进来了,这些是前提,方便后续阅读
二.访问路径(模拟与MVC一致)
如果我们想访问Home下面的Index。url为http://localhost:11673/Home/Test.html
data:image/s3,"s3://crabby-images/7c3a7/7c3a7f365d85e29b98d83c3f4d02c9b73c668671" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
那么首先做的就是把这个url改成与mvc访问方式一致的,如http://localhost:11673/Home/Test
那么第一个需要讲的便是路由,通过路由规则来改变指向。
看下mvc的代码是这样写的,这里便是mvc路由规则了
data:image/s3,"s3://crabby-images/19444/1944400e5c372d63d92492e170fb172d11b7792d" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
data:image/s3,"s3://crabby-images/a7c3b/a7c3b8958d0c84bb69527658bd6104c3113e0994" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
想用路由,首先要引入System.Web.Routing.dll
然后在Application_Start中添加路由映射的如下代码,写法如下:
data:image/s3,"s3://crabby-images/db347/db347c2ee5fb0b011d424a5a7a553c473c7e05d4" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
你也许会说为啥不跟mvc的一样使用MapRoute啊?其实mvc对Route进行了扩展(使用扩展方法)。所以在不引入MVC库的情况下,是无法使用的。
具体源码在:System.Web.Mvc的RouteCollectionExtensions下面,有意者可前去查看。我们后续还要参照这源码。先贴出一小段
data:image/s3,"s3://crabby-images/e0ea3/e0ea372d07866087411f4a7f01d4cede88e31429" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
那么下面我们来访问: http://localhost:11673/Home/Test
data:image/s3,"s3://crabby-images/8c574/8c5740db8a2ed5c1979e88c1e99ef790e10a8d0a" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
出错了,说没有提供 ".html" 为后缀名的提供程序。
需要配置一下 web.congfig ,指定处理程序
data:image/s3,"s3://crabby-images/91865/918658a6d5bfd6836c463ce8b7447b66a92774cc" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
然后再次运行:
data:image/s3,"s3://crabby-images/79fb8/79fb8b21cf6f499a53a8445bf2e5ad48e186b9ef" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
当时你会说,这只是个静态文件啊。如果运行到这里之前还要执行好多逻辑代码呢
那么首先想到的是转向一个"一般处理程序"。一般处理程序执行逻辑,然后拼装html内容,再返回给前台。
那我们试试如何让它指向一个Handle程序,看看参数提示:
data:image/s3,"s3://crabby-images/068d5/068d5da7589a65fface1a06b709f59cbf605a9fb" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
这里要注意route中接收IRouteHandle参数
那么我们就写一个,其实IRouteHandle也就是返回一个IHttpHandler。微软应该是为了扩展性,又加了这么个东西
具体实现代码如下:
data:image/s3,"s3://crabby-images/e6efd/e6efd95de748dafd181c6210b4d0ae3ed6ee79e7" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
F5运行:
data:image/s3,"s3://crabby-images/87f35/87f35462fb48b3e27efc3efe2f041a88e1a5aaa2" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
果然可以啊……
好了,我们去看看MVC是咋处理的,请看mvc的RouteConfig,并进入源码.请顺着箭头看。本人装了自动反编译工具,所以看源码很方便
data:image/s3,"s3://crabby-images/fe212/fe212ed23e9c31813baddb181370a33ce17a79de" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
其实处理过程跟我们是一样的……
那么你又会问了,人家想要用Razor视图啊。和后台数据绑定多帅啊^_^……
那么我们就要引入Razor引擎了,引入dll:System.Web.Razor
data:image/s3,"s3://crabby-images/3e665/3e665de7359a8fb45592151905d336eabbc715e1" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
请注意ProcessRequest中的处理过程。通过razor引擎编译html代码,注意Razor.Parse第一个参数为:字符串内容,第二个参数为传入的Model。
所以输出结果为:"欢迎你 test"
F5运行下看看:
data:image/s3,"s3://crabby-images/714d1/714d16c1eb523da7ac8951128be94cda27ea16fa" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
那么再来进一步处理,在后台写个Students集合,绑定到指定的RazorTest.html页面。
data:image/s3,"s3://crabby-images/2aa78/2aa787ebb8c6a00b51ac3179e3fbe5ab44d17475" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
注意这次我们是跟一个页面进行数据绑定了。是不是越来越像了。 看看结果,确实像所想的那样
data:image/s3,"s3://crabby-images/0e867/0e8674cf405e7e46f84c6631f0276e943dfc0815" alt="asp.net MVC 模拟实现与源码分析 asp.net MVC 模拟实现与源码分析"
好吧,就到这里吧。也是越说越多的,越深入就会越来越深入的(需要源码的请索要)。闲的没事,还是写写博客吧……下节继续吧!