Spring MVC 浅谈

aside section ._1OhGeD · · 1364 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

MVC这个词儿,最早的定义应该是作为一种软件架构设计模式出现在软工里面的,即使用model、view、controller 来设计及定义web软件的。

Spring MVC 是指Java 当前阶段最大的开源项目Spring 对于MVC 做出了具体的实现,叫做Spring MVC,作为Spring 的一个子集存在。顺道提一下Spring,现阶段的Spring 已经不再是当年那个Ioc、AOP、MVC的简单的“小”web框架了。看一下Spring 官网的一个图: 又差不多25个应用。覆盖的应用面已经达到了Java 服务器端开发的方方面面,几乎已经是Java 服务器端开发的规范。

image.png

回到MVC,MVC上文说到了不是Java 所特有的,它是一种软件架构的设计模式。

主要通过 1、拦截外部请求。2、完成对应逻辑处理。3、返回试图。而去看一个MVC框架也主要是从这几点出发去探究。

那么这种模式除了Spring MVC还有哪些类似的实现,可以对比的去看。

比如

Java 中除Spring MVC,几年前还有一个叫做 struts

Struts:1、依赖于servlet API实现(支持每一个模块有单独的Request Processors(生命周期),但是模块中的所有Action必须共享相同的生命周期 ),经典的单例模式,需要注意Action资源的并发安全问题。2、结合JSTL(一种比较方便的表达式语言),以JSP为基础实现视图。

Struts2:2、依赖于过滤器API 进行实现,每个线程所持有的资源都是私有的,不用担心并发问题。2、支持JSTL、OGNL,使用ValueStack将页面与相关对象解绑,使得部分属性对象可以复用。被诟病也被实证这种方式存在严重的方式遭到弃用。

C# 中的ASP.NET,Golang中的Beego,PHP中的yii。

就性能而言,除了yii,另外几个差异也还好,而且相对于最多的业务场景,瓶颈通常在数据库那儿,因为压根不是一个数量级,这方面基本可以忽略不计吧。通常一个框架封装程度越高相对复杂,性能一般是成反比的。

就是开发效率,给人直观感觉这几个基本相近的,Java 中的Struts 系列开发效率较低。

就生态而言:Java 无疑是当前阶段最繁荣,然后PHP&Golang,然后C#,不过PHP里面感觉好多东西有点封装过度,灵活性什么说实话没那么强。

这方面的比较仅仅为个人观点,最简单的方式就是写个hello world demo,亲自感受下吧。

这里的主题是Java中的Spring MVC 所以话题回到Java 这边

Java 生态内比较的话,Spring MVC相对于struts:

1、struts 主要是类级别的拦截,而spring MVC主要是方法级别的拦截,较开发而言,Spring MVC更加方便管理一些。

2、struts 基于过滤器实现,而过滤器这个东西压根就不应该作为请求的拦截及对应的分发(个人观点),而Spring MVC 基于原生servlet 作为请求统一的入口,然后分发到各个controller中的request mapping。

3、struts 生态圈着实不如Spring MVC,Spring MVC 无缝集成生态内的其他功能框架,一直到今天的Spring Boot,Java 对于业务场景已经近乎简化到了极致。

4、开发效率上,指定一下controller,requestmapping,几行业务代码,基本就完成了一个小的HTTP 服务,在Spring Boot 就是一个注解加一个逻辑函数,连最基本的配置都省去了。Spring是占绝对优势的。

5、Spring 不再依赖于JSP 那种古老的模式,而struts 那种描述视图还有开发模式仍然跟JSP类似。

至于Spring MVC 的进一步分析,请看后期的文章


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:aside section ._1OhGeD

查看原文:Spring MVC 浅谈

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1364 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传