ASP.NET MVC 插件化机制
2015-03-14 22:25 by 杨康新, 1328 阅读, 15 评论, 收藏, 编辑
概述
nopCommerce的插件机制的核心是使用BuildManager.AddReferencedAssembly将使用Assembly.Load加载的插件程序集添加到应用程序域的引用中。具体实现可以参考nopCommerce解决方案中Nop.Core项目的Plugins目录下的相关文件。其中PluginManager.cs文件是核心文件,包含了处理插件化的核心代码。nopCommerce的注释中感谢了其参考的Umbraco项目,并给出了主要参考文章的链接。
我们直接从nopCommerce3.5的实现中抽取必要的实现代码,制作一个简易版的插件系统Demo用于演示ASP.NET MVC的插件化,核心只包含一个标记接口IPlugin,一个管理类PluginManager包含2个必要方法Initialize和ReStart。
架构
新建.NET解决方案SimplePlugin,添加2个类库项目:SimplePlugin.PluginCore、SimplePlugin.SimpleMvcPlugin和一个ASP.NET应用程序项目SimplePlugin.Web。SimplePlugin.Web项目选择Empty模板并选中MVC引用。设置项目之间的依赖关系和程序集引用:向SimplePlugin.SimpleMvcPlugin添加SimplePlugin.PluginCore项目引用,向SimplePlugin.Web项目添加SimplePlugin.PluginCore项目引用。向SimplePlugin.PluginCore项目添加System.Web引用。
data:image/s3,"s3://crabby-images/031f7/031f7984492fb4ee59fa3cd753d4b76fb0b91d98" alt=""
data:image/s3,"s3://crabby-images/a9710/a971011e0120d333f33b81e61d97e2af2b8ed774" alt=""
1.约定
(1)约定"~/Plugins"作为插件根目录。
(2)约定"~/Plugins/bin"作为中等信任级别下的运行时目录。
插件在运行时加载的是插件程序集在运行时目录的副本,不直接加载插件而是加载运行时目录中的副本的原因是避免插件升级或删除时dll文件被锁定。2.基础代码
向SimplePlugin.PluginCore项目添加如下文件:
(1)IPlugin.cs:作为所有插件的抽象接口。
data:image/s3,"s3://crabby-images/d4a79/d4a79314e9d2d78c81c95b3f218cc0b99d4fa512" alt=""
data:image/s3,"s3://crabby-images/4e297/4e29750265b154d85187c5607da673a5d6826da2" alt=""
(2)PluginManager:负责加载插件和引用插件。
data:image/s3,"s3://crabby-images/21dfd/21dfd2881248dd0cfa5bdf67f86aec543509a979" alt=""
data:image/s3,"s3://crabby-images/a4f5b/a4f5ba535b314b538d150fb9593885a9d66494e5" alt=""
(3)向Simple.Web项目添加Plugins目录和Plugins/bin目录。向Simple.Web项目添加Controllers/PluginController.cs
data:image/s3,"s3://crabby-images/09e12/09e1228817f196ef9d514c4e5550b1b6e2f61f75" alt=""
data:image/s3,"s3://crabby-images/6ccb4/6ccb49ee1782e0ab8dc62ad1b00af091ff715b27" alt=""
修改web.config,配置probing元素。指定trust level为中等信任级别下的插件运行时目录。
data:image/s3,"s3://crabby-images/beb58/beb58edd75a656e0c5164d38f41c1c1704b7744e" alt=""
data:image/s3,"s3://crabby-images/4d398/4d398263d41a8f584fca74bd896ec3d761c2a333" alt=""
3.编写插件
通过Nuget向SimplePlugin.SimpleMvcPlugin项目添加MVC程序集引用,需要注意插件的MVC版本与SimplePlugin.PluginCore引用的MVC版本的一致性。
(1)添加Controllers/SimpleMvcPlugin.cs实现接口IPlugin
data:image/s3,"s3://crabby-images/105a7/105a754712d40f7d6dbba65478e7357c3d673e08" alt=""
data:image/s3,"s3://crabby-images/e6d72/e6d72695b46e0d6f477db535e49650f6f31ce103" alt=""
(2)添加Controllers/SimplePluginMvcController.cs
data:image/s3,"s3://crabby-images/3e2dd/3e2dd11f226c68681de4cd8c6cc65dae2e465d7b" alt=""
data:image/s3,"s3://crabby-images/c75cb/c75cb5c9ac819f8a028b47ea27f84b9b010e0fff" alt=""
(2)添加视图Views/SimpleMvcPlugin/Index.cshtml
data:image/s3,"s3://crabby-images/3ab6e/3ab6e36eaece50f912dc026d518cd948ed504972" alt=""
data:image/s3,"s3://crabby-images/f369c/f369ccc9a7c17e857899cce349667019ea6565fe" alt=""
(3)复制SimplePlugin.Web项目中SimplePlugin.Web/Views/web.config文件到当前项目的根目录和Views目录下。
(4)设置.cshtml以及.config文件类型为内容,生成设置为较新则复制。
data:image/s3,"s3://crabby-images/24536/245365f41b7acb57fc63b86bdbda4c2bed1a3cfd" alt=""
data:image/s3,"s3://crabby-images/5c83c/5c83cddac960c31569033facb7ddd7656dbb4335" alt=""
(5)设置SimplePlugin.SimpleMvcPlugin项目引用的程序集属性复制到本地为False。
(6)设置SimplePlugin.SimpleMvcPlugin项目的生成路径为binDebugSimpleMvcPlugin和binReleaseSimpleMvcPlugin
4.手动部署插件
生成解决方案,访问SimplePlugin.Web的插件列表页:
data:image/s3,"s3://crabby-images/6bb17/6bb174d823380dc6f57799efe9e5925db3583f1c" alt=""
data:image/s3,"s3://crabby-images/a27c6/a27c68e683734eaf609904b169a3c0f3be88d0f5" alt=""
拷贝生成的SimpleMvcPlugin文件夹到SimplePlugin.Web项目的Plugins文件夹下,访问SimplePlugin.Web的~/Plugin/Install访问SimplePlugin.Web的插件列表页
data:image/s3,"s3://crabby-images/1b173/1b1734124a9536a74986a414a52e28d85d0bd664" alt=""
data:image/s3,"s3://crabby-images/21b5e/21b5ecd8d344aa0d5febaed3e95947d1489ca0df" alt=""
访问SimplePlugin.Web的~/SimpleMvcPlugin/Index页
data:image/s3,"s3://crabby-images/a8088/a8088b38cfb29ebe49505293798b02a2703386d2" alt=""
data:image/s3,"s3://crabby-images/cc8cc/cc8cc0b9c755ddfaeccace63d3baf8bf9208057e" alt=""
5.自动部署
设置设置SimplePlugin.SimpleMvcPlugin项目的生成路径为:..SimplePlugin.WebPluginsSimpleMvcPlugin 同时设置Debug和Release两种配置。
data:image/s3,"s3://crabby-images/67c83/67c83ef61925460e760649a843baa70c7e34cd8c" alt=""
data:image/s3,"s3://crabby-images/5d287/5d28714901d040cf11bee3add236d0b60583cb0b" alt=""
重新生成解决方案,访问SimplePlugin.Web的插件列表页以及~/SimpleMvcPlugin/Index页:
data:image/s3,"s3://crabby-images/06fe7/06fe7baa6abf0dddcb661584ac708a2e9239d94c" alt=""
data:image/s3,"s3://crabby-images/c379b/c379b6089b74feffe87fe00b4f8d3944dc66d4ad" alt=""
data:image/s3,"s3://crabby-images/7aa5f/7aa5f62419d4c2ed7da9d5756563d15e99a579b7" alt=""
data:image/s3,"s3://crabby-images/b0c76/b0c76e301e264c4803b182b3d39ce8146cbd2d99" alt=""
6.测试中级信任级别
设置web.config的trust元素的level属性为Medium,禁止访问应用程序目录以外的文件。
data:image/s3,"s3://crabby-images/243b7/243b7f55a24a319d7a7f973acb128c1576e301b2" alt=""
data:image/s3,"s3://crabby-images/3ae11/3ae11dd69177da0f1dd614ae56788c50f91a4537" alt=""
重新生成解决方案,访问SimplePlugin.Web的插件列表页以及~/SimpleMvcPlugin/Index页。检查Plugins/bin目录:
data:image/s3,"s3://crabby-images/a79ce/a79ce0baf31afb6449fe111ccfa226b2e7d73475" alt=""
data:image/s3,"s3://crabby-images/a79ce/a79ce0baf31afb6449fe111ccfa226b2e7d73475" alt=""
data:image/s3,"s3://crabby-images/972e3/972e325abf8b6d2b9ae8e0bbfae882930f1f0f61" alt=""
7.测试视图文件修改
修改SimplePlugin.Web项目PluginsSimpleMvcPluginViewsSimpleMvcPlugin目录下的Index.cshtml。查看修改结果:
data:image/s3,"s3://crabby-images/0acc6/0acc6133f491eb0904d2ccd16f130544985271eb" alt=""
data:image/s3,"s3://crabby-images/0faec/0faec99f4c31a051d07845f3ffa7b579bd900191" alt=""
8.Demo下载:点击下载
data:image/s3,"s3://crabby-images/d1417/d1417dae8ed2f31186277667ebe03439852c484b" alt="SimplePlugin.zip"
如果这篇博客内容对您稍有帮助或略有借鉴,请您推荐它帮助更多的人。