为了账号安全,请及时绑定邮箱和手机立即绑定

简易 MVC框架 弃坑

标签:
MVVM

MVC

模型视图控制器模型 这是中文名称
原先是为桌面应用建立的框架,后来转变成为B/S模型。
经典图如下

说一下CGI,是使用CGI 和apache进行连接,当发生一个请求的时候,进入apache,即web server,由web server执行事先编辑好的CGI程序,由CGI程序读取databases,由CGI程序把读取到的dtatBases整合,返回给webserver 再由webserver返回给浏览器,实现了该协议的由php-cgi,但是继续,每次收到一个请求都会fork一个进程,把cgi进行改良,产生了fast-cgi,即,每次处理完成以后,不在清除掉这个进程,而是保留这个进程。再往后出现了php-fpm,为fastCGI的实现,提供了进程管理的功能。其中php-fpm是可以单独执行的,不具有静态的文件处理功能,此时加上apahce,用于对静态文件进行处理,由于站点过多,在加上nginx进行反向代理,实现负载均衡。php-fpm是可以单独执行的。最后,apache和nginx都可以实现负载均衡,不过由于nginx是事件驱动的所以使用nginx用来做反向代理偏多

另外,还有一种是异步机制,属于Node.js,即,当事件发生的时候,入栈,然后,有一个事件环,进行循环处理,其中,事件环为单线程的。此为异步
Node中也有对象机制,即,先发出命名好的事件,事件触发之前注册好的监听器,在Node.js下,需要继承EventEmitter类,并实例化生成。
PS:事件 != 异步,是在异步函数执行完成以后触发事件,基于事件通信的回调机制。
即,后台程序不需要任何修改,只需要使用不同的视图,用来呈现出不同的页面。
mvc有两个版本,在早期当中,jsp页面融合了控制器和视图的功能。即,开发出一堆jsp页面,然后一堆java bean,当用户访问的时候,访问jsp的时候,由tomcat生成对象,送入java bean中进行执行,由java bean负责业务处理,包括数据库的读取,然后返回给浏览器。这里呢,jsp负责控制器和视图,java bean负责业务处理。

第二个 mvc 只是把jsp和java bean分开了。
在第二个版本当中,视图和模型彻底分离。
栗子如下,一个数据展示界面,从一张表中把数据读取,然后展示到页面上,其中页面展示为视图V,从数据库取得数据是模型层M,控制器C是把浏览器接收到的请求,执行模型层M,执行,然后组合视图V,最后把数据返回给客户端。
图如下

首先,HTTP协议发出请求,然后控制器接收请求,控制器接收请求以后,发送给,模型层处理,模型层,把数据提交给逻辑层,逻辑层和持久层进行连接,持久层用于和数据库,进行一对一,一对多,多对多关系映射,取出数据以后,把数据返回给逻辑层,进行业务处理,处理完成以后,返回给模型层,模型层,拿到数据,返回给控制层,控制层,拿到数据,控制器,进行组装视图层,把组装好的视图层,转换成为浏览器可以接收的HTML数据,然后最后再把数据返回给浏览器。

上方是MVC的数据的流的经过

特点,高重用性,低耦合,快速开发,便捷部署。

MVC架构

MVC模块有以上模块,为核心控制器,过滤器,拦截器,视图管理器,模型管理器。

核心控制器

MVC框架入口,接收和反馈HTTP请求。

过滤器

用户过滤HTTP请求。

拦截器

对进出,进入的数据进行拦截

模型管理器

例如session,线程池等

视图管理工具

对,视图进行管理。
提供多种语言的视图

辅助工具

例如,文件管理,对象管理。

数据流

数据流是先通过核心控制器,然后,流到过滤器,进行表单的过滤,再流入拦截器,对不通过的登录进行内拦截,业务代码写在模型层中,对业务进行处理,处理完成以后,返回给控制器,视图管理器中由jsp文件,对jsp文件进行渲染,返回给客户端

大致总结

这是一个目前的大致总结,首先有一个核心控制器,数据进入以后,再次进入拦截器,过滤器,过滤器,和拦截器,对于用户访问web资源是否具有权限进行验证,然后再次进入模型层取出数据,此时通知视图层进行数据更新,最后把视图层进行返回。

统一都注册在控制器中。包括视图管理类,模型管理类。
每次发生改变的时候,通过调用管理类的方式来管理模型和视图,并且加载进入内存。
对于访问资源来说,放置到过滤器和拦截器中。
对于业务逻辑处理放入模型层中。
对于视图层和模型层来说,每次控制器通知模型数据更改以后,触发一个事件,响应到视图管理类中,视图管理类对于视图进行渲染,即生成HTML文件,把生成的HTML文件的URL直接返回给控制器,控制器再次返回给浏览器。

大致总结

对于MVC来说,首先有两个管理类,即,视图管理类和模型管理类,注册在控制器中,控制器基于servlet,每次发生请求的时候,控制器接收到请求,然后传递给拦截器,和过滤器,拦截器和过滤器,用于进行身份验证,和访问资源的验证,然后通过管理类暴露在外的接口,调用模型层,以及书写在模型层中业务代码,包括数据库的读取,模型层数据更新以后,通过观察者模式,通知视图层的管理类,对视图中的数据进行渲染成为HTML文件,由JSP文件直接渲染成为HTML文件,涉及到编译原理的一些知识,最后把生成的URL直接返回给控制器,控制器拿到URL,把URL返回给浏览器。

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消