谈谈.NET MVC QMVC高级开发

    自从吾修主页上发布了QMVC1.0,非常感兴趣,用了半月的时间学习,真的感觉收益非浅,在此声明非常感谢吾修大哥的分享!

    1、轻快简单,框架就几个类,简单,当然代码少也就运行快!单纯的MVC,使的如果你想扩展框架,可以轻易的在QMVC上增加和减少功能,也就是说更容易的去修改和读懂源码。

    2、可以与webform框架融合,也就是说你用webform和mvc共同在同一个项目中运行。

    3、QMVC APP开发,QMVC APP可以轻易实现多个QMVC项目合并到一个项目中运行,也可以轻易将其分离开独立运行,比如一个网站常有论坛、文章系统、新闻系统等,如果你的程序用qmvc app,哪么可以轻易实现多个系统的融合。

    本文主题:“QMVC高级开发”,所谓高级我可不认为就是学不会,搞不懂的忽悠者是高级!而是高与初级的层面上知识,所以在此,我假设你己经懂了QMVC的基础级应用,如果想了解QMVC的初级应用,可以参考我写的一篇文章《高性能.NET MVC之QMVC》,或QMVC官网(www.wuxiu.org)。

    怎样的框架是最适合你的?哪么豪无疑问,最适合你的框架,什么是最适合自己的?肯定是量身定制的!就像是如果说qmvc,他的代码非常少,层次简单,逻辑清晰,简单。你可以通过基于QMVC轻易扩展成适合自己系统的框架!本文就谈谈如何扩展自己的MVC APP框架、谈谈QMVC源码结构!

    1、QMVC源码分析

    首先QMVC源码中存在两种MVC模式,一种是QMVC基本框架,一种是QMVC APP框架,QMVC APP的代码是基于QMVC基本框架实现的,源码中APPS目录中存的是关于QMVC APP框架的实现代码。根目录下是QMVC基本框架,Router为QMVC的路由功能,用HTTP请求地址的分析。

    ControllerBase类    所有控制器的基类

    IMVCModel  模型调用接口,当然你的Model也可以不继承于此接口,如果想在Model中调用QMVCRazorPage类,哪么可以实现接口中获取。

    MVCRazorPageBase类  是关于View模板的基类

     QMVCCore类          QMVC框架的核心类,控制qmvc运行的支持者。

    ViewResult类        是Controller传值给QMVCCore去调用Razor模板时的信息类,Controller把要显示的信息给ViewResult,QMVCCore通过ViewResult加载Razor模板。

    Router.IRouterProvider接口   如果你想重写QMVC的路由功能,哪么可以实现Router.IRouterProvider接口实现。

    至于APPS中的类于以上的类类似,并且实现了固定的Router。

    如果你想重写模板显示路径规则可以重写ControllerBase类中的getTemplateUrl方法,这无疑对你编写自己的框架起到了最大控制的空间,原方法代码:

protected virtual string getTemplateUrl(string themeName,string controllerName,string viewName)
{return "~/" + themeName + "Views/" + controllerName + "/" + viewName + ".cshtml";
}

DefaultRouter类

using System;
using System.Collections.Generic;
using System.Collections.Specialized;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Text.RegularExpressions;
using System.Web;namespace wuxiu.QMVC.Router
{public class DefaultRouter : IRouterProvider{string DefaultController;string DefaultAction;RouterControllerCollection controllers = new RouterControllerCollection();public DefaultRouter(Assembly asm, string defaultController, string defaultAction){DefaultController = defaultController;DefaultAction = defaultAction;//
            controllers.LoadAssembly(asm);}public ControllerBase LoadUrl(HttpContextBase context, string apprawurl){string controllerName = DefaultController;string action = DefaultAction;string pageurl;if (apprawurl.IndexOf('?') != -1){pageurl = apprawurl.Substring(0, apprawurl.IndexOf('?'));}else pageurl = apprawurl;string[] urls= Utils.ClearStrArrayEmpty(pageurl.Split('/'));string[] urldata;if(urls.Length>0){controllerName=urls[0];}else controllerName=DefaultController;if(urls.Length>1){action=urls[1];if (!action.EndsWith(".action",StringComparison.OrdinalIgnoreCase)){return null;} action = action.Substring(0,action.Length - ".action".Length);}else action=DefaultAction;if(urls.Length>2){urldata=new string[urls.Length-2];for(int i=2;i<urls.Length;i++)urldata[i-2]=urls[i];}else urldata=new string[]{};Type ControllerType = controllers.GetController(controllerName);if (ControllerType != null){ControllerBase controller = Activator.CreateInstance(ControllerType) as ControllerBase;controller.init(context, controllerName, action, urldata);return controller;}return null;}}
}

QMVC默认路由器类,没有实现正则表达式,其实我觉得这是一个好事,因为使用字符分析更准确性能更佳。DefaultRouter类中实现了IRouterProvider接口,在LoadUrl函数中分析了http请求地址,并且通过反射的方式调用的控制器中的方法。

   2、QMVC APP介绍

  QMVC APP的实现目的是为了实现多个项目融合提出的解决方案,当然如果你的程序按照QMVC APP模式开发,可以很容易的实现与另一个APP之间融合到一个站点中运行。   如果你的项目按照QMVC APP模式开发,哪么Controller是继承自wuxiu.QMVC.APPS.APPController基类,每一个应用中必须实现APPProvider类。每个应用中存放app.config文件。

    QMVC APP目录结构

    APPS

     APPName

        DefaultViews

           ControllerName

              ActionName.cshtml

           ...

        App.config

  Controllers

  Models

  APPProvider.cs

  Global.asax

  Web.config

  以上树中,APPS目录是必须目录,用于包含当前项目中所有的应用文件夹,APPName是应用的文件夹,其中包括了Views和app.config,Views里存放了应用所用的视图,app.config中定义了应用的配置信息。

  APPProvider.cs是APPS模式中所有应用实现的一个类,他继承于wuxiu.QMVC.APPS.APPProvider类,该类在QMVC初始化时调用,用于初始化APP。   Models和Controllers文件为当前应用的相关控制器和模型存放目录。

   QMVC APP项目配置

  若建一个QMVC APP模式的项目,必须以6.2节中定义的目录结构外,需要修改一些配置文件,让ASP.NET运行框架支持QMVC APP运行。

  Web.config中,添加或修改以下配置项:

  

<configuration><system.web><compilation debug="true" targetFramework="4.5"><assemblies><add assembly="System.Web.WebPages.Razor2, Version=0.0.0.0, Culture=neutral, PublicKeyToken=14679ed9c77dd5f5" /><add assembly="System.Web.WebPages2, Version=0.0.0.0, Culture=neutral, PublicKeyToken=14679ed9c77dd5f5" /><add assembly="System.Web.Razor2, Version=0.0.0.0, Culture=neutral, PublicKeyToken=14679ed9c77dd5f5" /></assemblies><buildProviders><remove extension=".cshtml"/><addextension=".cshtml"type="System.Web.WebPages.Razor.RazorBuildProvider, System.Web.WebPages.Razor2"/></buildProviders></compilation></system.web><system.webServer><modules runAllManagedModulesForAllRequests="true"/></system.webServer></configuration>

  APPS/web.config中,添加或修改以下配置项:

<configuration><configSections><sectionGroup name="system.web.webPages.razor" type="System.Web.WebPages.Razor.Configuration.RazorWebSectionGroup, System.Web.WebPages.Razor2"><section name="host" type="System.Web.WebPages.Razor.Configuration.HostSection, System.Web.WebPages.Razor2" requirePermission="false" /><section name="pages" type="System.Web.WebPages.Razor.Configuration.RazorPagesSection, System.Web.WebPages.Razor2" requirePermission="false" /></sectionGroup></configSections><system.web></system.web><system.web.webPages.razor><pages pageBaseType="wuxiu.QMVC.MVCRzorPageBase"><namespaces><add namespace="wuxiu.QMVC" /></namespaces></pages></system.web.webPages.razor>
</configuration>

APPS/APPName/APPProvider.config

 

 <?xml version="1.0" encoding="utf-8" ?><app name="贴吧系统"version="1.0"copyright="bobby"urlFolder="wuxiu"appProviderClass="wuxiu.tiebaAPP.TiebaAPPProvider"assembly="bin:wuxiu.tiebaAPP"enable="true"><appSettings><add key="" value=""/>... </appSettings><customElements></customElements>  </app>

  如果您创建一个QMVC APP,哪么必须写一个app.config描述您的应用信息,QMVC会按照您的配置去加载应用,并且把您的配置信息传给应用。

  APP节点属性

Name 应用的名称 Version                 当前应用的版本号 appProviderClass 表示实现wuxiu.QMVC.APPS.APPProvider类的命名空间和类名,用于初始化APP的类。 assembly         当前应用的APPProvider所在的类库,值有两种书写形式:

                        1、file冒号开头,标识app/bin/目录下的dll文件名,如:“file:mydll.dll”。

                        2、bin:默认为程序跟目录Bin目录下的程序集名称,如:“bin:mydll”。

说明:推荐使用bin前缀,因为file虽然可以独立自己的程序目录,确存在着运行中独占的问题,可能导致程序运行页dll不允许移动和删除。 Enable 标识当前程序是否可用,值有两个:true或false。

以上章节是翻译自吾修主页的QMVC Doumentation章节中关于QMVC APP章节!     

实现一个自己的AppController

public class HomeController:wuxiu.QMVC.APPS.APPController{public wuxiu.QMVC.ViewResult Index(){return View();}
}

实现一个IMVCModel类

当在模型类中可以获取到MVCRazorPage对象无疑将Model的功能增加,他可以更灵活的提供些程序逻辑,减少了Razor模板中的代码,毕竟Razor是给美工操作的层面代码。

    public class MyModel:wuxiu.QMVC.IQMVCModel{public string LoginPageUrl { get { return page.APPUrlStart + "/user/login.action"; } }wuxiu.QMVC.APPS.APPRazorPage page;public void Init(QMVCRzorPageBase page){this.page = (wuxiu.QMVC.APPS.APPRazorPage)page;}}

 

转载于:https://www.cnblogs.com/jsmblog/p/qmvc_app.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/473349.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

天池 在线编程 最小振幅(排序)

文章目录1. 题目2. 解题1. 题目 https://tianchi.aliyun.com/oj/231188302809557697/235445278655844966 给定一个由N个整数组成的数组A&#xff0c;一次移动&#xff0c;我们可以选择此数组中的任何元素并将其替换为任何值。 数组的振幅是数组A中的最大值和最小值之间的差。…

文件系统的类型

文件系统的类型 文件系统类型&#xff1a; ext2 &#xff1a; 早期linux中常用的文件系统 ext3 &#xff1a; ext2的升级版&#xff0c;带日志功能 RAMFS &#xff1a; 内存文件系统&#xff0c;速度很快 NFS &#xff1a; 网络文件系统&#xff0c;由SUN发明&a…

Git中非常重要的一个文件——.gitignore详解

首先要强调一点&#xff0c;这个文件的完整文件名就是“.gitignore”&#xff0c;注意最前面有个“.”。这样没有扩展名的文件在Windows下不太好创建&#xff0c;这里给出win7的创建方法&#xff1a; 创建一个文件&#xff0c;文件名为&#xff1a;“.gitignore.”&#xff0c…

行先知 为您的办公室管理提供方便

《行先知》为您的办公室管理提供方便■省时间和空间 公司人员去向及预定事项一目了然。不管你位置在哪里&#xff0c;不需要回头、翘首去看通知栏。不需要一次次去擦写、修改通知栏。尽管公司人员分布在不同的楼层、不同的建筑&#xff0c;人员去向一目了然。不需要再往纸上写留…

Python把两张图片拼接为一张图片并保存

这里主要用Python扩展库pillow中Image对象的paste()方法把两张图片拼接起来 from os import listdir from PIL import Imagedef pinjie():# 获取当前文件夹中所有JPG图像im_list [Image.open(fn) for fn in listdir() if fn.endswith(.jpg)]# 图片转化为相同的尺寸ims []for…

ubuntu 13.04下MYSQL 5.5环境搭建

解决的问题&#xff1a; 安装mysql server和mysql client 5.5 新建远程账户 远程访问权限 MYSQL默认字符集修改为UTF8 检查防火墙 一、安装 BTW:可以使用查找命令查看安装包 sudo apt- 安装命令 sudo apt-get install mysql-server-5.5 回车 &#xff08;有一个带core的&…

天池 在线编程 高效作业处理服务(01背包DP)

文章目录1. 题目2. 解题1. 题目 https://tianchi.aliyun.com/oj/231188302809557697/235445278655844967 Twitter正在测试一种名为Pigeon的新工作处理服务。 Pigeon可以用任务实际持续时间的两倍处理任务&#xff0c;并且每个任务都有一个权重。 此外&#xff0c;Pigeon在一…

【django学习】request.POST与request.POST.get两者主要区别

request.POST是用来接收前端传过来的数据 一、request.POST.get&#xff08;sth&#xff09;与 request.POST [sth] - 区别 request.POST[sth]KeyError如果sth不在&#xff0c;将提出异常request.POST。 request.POST.get(sth)将返回None如果sth不在request.POST。 此外&…

转载:mongoDB java驱动学习笔记

http://www.blogjava.net/watchzerg/archive/2012/09/22/388346.html mongoDB java驱动学习笔记 指定新mongo实例&#xff1a;Mongo m new Mongo();Mongo m new Mongo( "localhost" );Mongo m new Mongo( "localhost" , 27017 );// or, to connect to a…

LeetCode 1694. 重新格式化电话号码(模拟)

文章目录1. 题目2. 解题1. 题目 给你一个字符串形式的电话号码 number 。 number 由数字、空格 、和破折号 - 组成。 请你按下述方式重新格式化电话号码。 首先&#xff0c;删除 所有的空格和破折号。 其次&#xff0c;将数组从左到右 每 3 个一组 分块&#xff0c;直到 剩…

Python中查找包含它的列表元素的索引,index报错!!!

对于列表["foo", "bar", "baz"]和列表中的项目"bar"&#xff0c;如何在Python中获取其索引&#xff08;1&#xff09;&#xff1f; 一、index >>> ["foo", "bar", "baz"].index("bar&qu…

LeetCode 1695. 删除子数组的最大得分(前缀和+哈希+双指针)

文章目录1. 题目2. 解题1. 题目 给你一个正整数数组 nums &#xff0c;请你从中删除一个含有 若干不同元素 的子数组。 删除子数组的 得分 就是子数组各元素之 和 。 返回 只删除一个 子数组可获得的 最大得分 。 如果数组 b 是数组 a 的一个连续子序列&#xff0c;即如果它…

大型网站系统与Java中间件实践

大型网站系统与Java中间件实践&#xff08;贯通分布式高并发高数据高访问量网站架构与实现之权威著作&#xff0c;九大一线互联网公司CTO联合推荐&#xff09; 曾宪杰 著 ISBN 978-7-121-22761-5 2014年4月出版 定价&#xff1a;65.00元 340页 16开 编辑推荐 到底是本什么书…

2019年CSDN人气最高博客排名榜(前20强),业界传说,膜拜!

截止到2019年02月12日&#xff0c;CSDN前二十的大神&#xff1a; 1. stpeace&#xff1a;原创2150&#xff0c;粉丝5037&#xff0c;评论2966&#xff0c;访问量1613万 链接&#xff1a;https://blog.csdn.net/stpeace/ 简介&#xff1a;近几年排名稳步上升&#xff0c;至今仍…

LeetCode 1696. 跳跃游戏 VI(优先队列 / 单调队列)

文章目录1. 题目2. 解题2.1 贪心错误解2.2 优先队列/单调队列1. 题目 给你一个下标从 0 开始的整数数组 nums 和一个整数 k 。 一开始你在下标 0 处。每一步&#xff0c;你最多可以往前跳 k 步&#xff0c;但你不能跳出数组的边界。 也就是说&#xff0c;你可以从下标 i 跳到…

Unable to open /dev/sda的原因之一

fdsik /dev/sda需要在root权限下运行&#xff0c;普通用户就会出现上述情况。 转载于:https://www.cnblogs.com/cnsec/p/3789828.html

Python判断变量是否存在的方法

方法一&#xff1a;使用try: ... except NameError: ...。 try:var except NameError:var_exists False else:var_exists True 方法二&#xff1a;使用内置函数locals()&#xff1a; locals()&#xff1a;获取已定义对象字典 #testvar未定义 In [1]: testvar in locals().…

LeetCode 1697. 检查边长度限制的路径是否存在(排序+并查集)

文章目录1. 题目2. 解题1. 题目 给你一个 n 个点组成的无向图边集 edgeList &#xff0c;其中 edgeList[i] [ui, vi, disi] 表示点 ui 和点 vi 之间有一条长度为 disi 的边。请注意&#xff0c;两个点之间可能有 超过一条边 。 给你一个查询数组queries &#xff0c;其中 qu…

限制RICHTEXTBOX的输入的范围

附件&#xff1a;http://files.cnblogs.com/xe2011/WindowsFormsApplication_LimitRichTextBoxInput.rarusing System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using Syst…

NLP项目工作流程

文章目录1. 谷歌Colab设置2. 编写代码3. flask 微服务4. 打包到容器5. 容器托管参考 基于深度学习的自然语言处理使用这篇文章的数据(情感分类)进行学习。 1. 谷歌Colab设置 Colab 地址 新建笔记本 设置 选择 GPU/TPU 加速计算 测试 GPU 是否分配 import tensorflow…