博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
关于spring mvc 和struts2的描述与对比
阅读量:4960 次
发布时间:2019-06-12

本文共 3222 字,大约阅读时间需要 10 分钟。

链接:

来源:牛客网

------------------------------------------------------------------------------------------------------------------------------------------------

所谓依赖注入就是指:

  在运行期,由外部容器动态地将依赖对象注入到组件中。当spring容器启动后,spring容器初始化,创建并管理bean对象,以及销毁它。所以我们只需从容器直接获取Bean对象就行,而不用编写一句代码来创建bean对象。这种现象就称作控制反转(IOC),即应用本身不负责依赖对象的创建及维护,依赖对象的创建及维护是由外部容器负责的。这样控制权就由应用转移到了外部容器,控制权的转移就是所谓反转。

------------------------------------------------------------------------------------------------------------------------------------------------

spring的IOC容器能够帮我们自动new对象,对象交给spring管之后我们不用自己手动去new对象了,也就是控制权的转让。
spring使用BeanFactory来实例化、配置和管理对象,但是它只是一个接口,里面有一个getBean()方法。
我们一般都不直接用BeanFactory,而是用它的实现类
ApplicationContext ,这个类会自动解析我们配置的
applicationContext.xml

------------------------------------------------------------------------------------------------------------------------------------------------

我们从以下几个维度来区分两者的概念:
1.
 机制:spring mvc的入口是servlet,而struts2是filter。
    补充几点知识:
    《
Filter
实现javax.servlet.Filter接口,在web.xml中配置与标签指定使用哪个Filter实现类过滤哪些URL链接。只在web启动时进行初始化操作。
filter 流程是线性的, url传来之后,检查之后,可保持原来的流程继续向下执行,被下一个filter, servlet接收等,而servlet 处理之

后,不会继续向下传递。filter功能可用来保持流程继续按照原来的方式进行下去,或者主导流程,而servlet的功能主要用来主导流程。

特点:可以在响应之前修改Request和Response的头部,只能转发请求,不能直接发出响应。filter可用来进行字符编码的过滤,检测用户

是否登陆的过滤,禁止页面缓存等》
        《
Servlet,
servlet 流程是短的,url传来之后,就对其进行处理,之后返回或转向到某一自己指定的页面。它主要用来在业务处理之前进行控制

        Listener呢?我们知道 servlet、filter都是针对url之类的,而listener是针对对象的操作的,如session的创建,session.setAttribute的发生,在这样的事件发 生时做一些事情。

2.
性能
  spring会稍微比struts快
spring mvc是基于方法的设计 而sturts是基于类
,每次发一次请求都会实例一个action,每个action都会被注入属性,而spring基于方法,粒度更细(粒度级别的东西比较sychronized和lock),但要小心把握像在servlet控制数据一样。
spring3 mvc是方法级别的拦截,拦截到方法后根据参数上的注解,把request数据注入进去,在spring3 mvc中,一个方法对应一个request上下文。
而struts2框架是类级别的拦截,每次来了请求就创建一个Action,然后调用setter getter方法把request中的数据注入;struts2实际上是通过setter getter方法与request打交道的struts2中,一个Action对象对应一个request上下文。
 
3.
参数传递:
  struts是在接受参数的时候,可以用属性来接受参数,这就说明参数是让多个方法共享的
 
4.
设计思想上:
struts更加符合oop的编程思想
, spring就比较谨慎,在servlet上扩展。
 
5.
intercepter(拦截器)的实现机制:struts有以自己的interceptor机制,
spring mvc用的是独立的AOP方式
。这样导致struts的配置文件量还是比spring mvc大,虽然struts的配置能继承,所以我觉得,就拿使用上来讲,spring mvc使用更加简洁,
开发效率Spring MVC确实比struts2高
spring mvc是方法级别的拦截,一个方法对应一个request上下文,而方法同时又跟一个url对应,所以说从架构本身上
spring3 mvc就容易实现restful url
struts2是类级别的拦截,一个类对应一个request上下文;实现restful url要费劲,因为struts2 action的一个方法可以对应一个url;而其类属性却被所有方法共享,这也就无法用注解或其他方式标识其所属方法了。
spring3 mvc的方法之间基本上独立的,独享request response数据,请求数据通过参数获取,处理结果通过ModelMap交回给框架方法之间不共享变量,
而struts2搞的就比较乱,虽然方法之间也是独立的,但其所有Action变量是共享的,这不会影响程序运行,却给我们编码,读程序时带来麻烦。
6. 另外,spring3 mvc的验证也是一个亮点,支持JSR303,
处理ajax的请求更是方便
,只需一个注解
@ResponseBody
 ,然后直接返回响应文本即可。
代码:
    1. @RequestMapping (value= "/whitelists" )  
    2. public  String index(ModelMap map) {  
    3.     Account account = accountManager.getByDigitId(SecurityContextHolder.get().getDigitId());  
    4.     List<Group> groupList = groupManager.findAllGroup(account.getId());  
    5.     map.put("account" , account);  
    6.     map.put("groupList" , groupList);  
    7.     return   "/group/group-index" ;  
    8. }  
    9. // @ResponseBody ajax响应,处理Ajax请求也很方便   
    10. @RequestMapping (value= "/whitelist/{whiteListId}/del" )  
    11. @ResponseBody   
    12. public  String delete( @PathVariable  Integer whiteListId) {  
    13.     whiteListManager.deleteWhiteList(whiteListId);  
    14.     return   "success" ;  

转载于:https://www.cnblogs.com/Lxiaojiang/p/6728264.html

你可能感兴趣的文章
目录导航「深入浅出ASP.NET Core系列」
查看>>
简易爬虫(爬取本地数据)
查看>>
python 进程间通信
查看>>
深拷贝 vs 浅拷贝 释放多次
查看>>
Javascript 有用参考函数
查看>>
点群的判别(三)
查看>>
GNSS 使用DFT算法 能量损耗仿真
查看>>
【转】Simulink模型架构指导
查看>>
MYSQL数据库的导出的几种方法
查看>>
SQL Server-5种常见的约束
查看>>
硬件之美
查看>>
[转载]java开发中的23种设计模式
查看>>
表格的拖拽功能
查看>>
函数的形参和实参
查看>>
文字过长 用 ... 表示 CSS实现单行、多行文本溢出显示省略号
查看>>
1Caesar加密
查看>>
【TP SRM 703 div2 500】 GCDGraph
查看>>
MapReduce 重要组件——Recordreader组件 [转]
查看>>
webdriver api
查看>>
apache 实现图标缓存客户端
查看>>