Struts2和SpringMVC的action是单例还是原型的?

struts2的acion单独使用的时候应是多例的,也就是原型(prototype)。
因为它是基于类开发的,它的三种获取页面传参的方式都是通过成员变量的方式来接受的。
如果用struts2框架基于方法的形式进行开发(一个方法对应一个请求处理的话),那么意味着这多个方法都可以共享成员变量。这时候,那么就可能会出现并发问题:不同的请求对同一个实例中的成员变量一起操作,出现数据安全问题。比如前一个人的密码可能被后面的人看到,提交的数据被修改等。
这就是为什么struts2为什么是多例的原因。

值得注意的是,当把struts交给spring管理的时候,由于spring管理的bean默认是单例的,随之创建的action实例也是单例的,这时候我们要显式地把它定义成原型(prototype)。

springMVC的action默认是单例的
虽然springmvc是单例的,但是一般它不会出现安全的问题,因为它是基于方法开发的:它通过方法的形参列表来接受用户传过来的前端参数,这些参数属于局部变量,所以每个请求之间的参数互不相通。
上面说的一般不会出现安全问题,那什么是不一般呢?
当你在action中定义了成员属性的时候,那么代表所有的请求都有可能会操作这个属性,这时候就出现了数据安全问题了,所以不推荐使用成员属性。如果你不得不用,那么你可以把action定义成原型的。

原文地址:https://www.cnblogs.com/iisme/p/10480251.html

时间: 2024-08-29 08:59:29

Struts2和SpringMVC的action是单例还是原型的?的相关文章

SpringMVC之控制器的单例和多例管理

版权声明:本文为博主原创文章,未经博主允许不得转载. 在使用Spring3对控制器Controller进行bean管理时,如果要对控制器是否单例进行管理. 有两种方式配置多例模式: 1.springXML 2.注解本身的控制器类 [java] view plaincopyprint? @Controller @Scope("prototype") public class HelloContorller { private int index=0; Logger logger=Logg

erlang与设计模式(一)——概述、单例、原型

Russell-X-Shanso 大家好,我是狼夜行(嫌不好记叫我哈士奇也成).仅以此系列随笔跟大家来讨论一下erlang和设计模式. 本文背景: (1)设计模式在面向对象语言编程中广泛受到关注: (2)对于非面向对象语言而言,各领域的朋友也有总结一些设计模式,整体受众及受关注度不大: (3)国内erlang圈不大,玩票的游击队朋友较多,新手引导少: 本文目标: (1)按面向对象中设计模式的套路生搬硬套过来,借用erlang的形式向erlang为主要语言的朋友们进行介绍,希望对两者更熟悉的朋友能

设计模式理解(二)创建型——单例、原型

设计模式理解(二)单例(Singleton)与原型(Prototype) 为什么一起写,因为懒.... 单例,就是用了面向对象语言的一些奇技淫巧,把构造函数私有了,然后用一个自身类型的静态指针作为全局唯一的实例的引用.碰到并发之类就呵呵了. 这么简单都能画个UML图,还煞有介事似的,我晕. -----------------------   分割线   ------------------------ 原型(Prototype) 我理解就是给一个类糊弄个cloneable之类的接口,让它自己决定

单例和原型模式-创建型

单例模式 确保一个特殊类的实例是独一无二的(它是这个类的唯一实例),并且这个实例易于被访问. 解决方案 1)全局变量:一个全局变量使得一个对象可以被访问,但它不能防止你实例化多个对象.因为你的任何代码都能修改全局变量,这将不可避免的引起更多调试的意外.换句话说,全局变量的状态总是会出现一些问题的. 2)类构造函数私有和类自身的静态方法:让类自身负责保存它的唯一实例(静态变量).这个类可以保证没有其他实例可以被创建(通过截取创建新对象的请求) ,并且它可以提供一个访问该实例的方法(静态方法).这就

springboot 响应消息 message简单封装 单例和原型模式

直接上代码: 1.定义静态方法 import com.alibaba.fastjson.JSON; public class MessageUtils implements Cloneable { private static final MessageUtils instance = new MessageUtils(); // 单例模式 public MessageUtils clone() { try { return (MessageUtils) super.clone(); } cat

SpringMVC Controller单例和多例

对于SpringMVC Controller单例和多例,下面举了个例子说明下. 第一次:类是多例,一个普通属性和一个静态属性. 结果:普通属性:0.............静态属性:0 普通属性:0.............静态属性:1 普通属性:0.............静态属性:2 普通属性:0.............静态属性:3 所以说:对于多例情况普通属性时不会共用的,不会产生影响,对于静态属性会去共用这个属性. 第二次:类改为单例 结果:普通属性:0.............静态属

Spring 4.2 方法注入解决单例Bean的原型Bean依赖问题

当你在单例Bean中使用原型Bean依赖时,注意,依赖在实例化时解析.因此,如果你依赖注入一个原型Bean到单例Bean中,新的原型Bean被实例化然后依赖注入到单例Bean中.提供给单例Bean的原型实例是唯一的. 然而,假设你想单例Bean在运行时多次获取一个新的原型Bean的实例.你不能依赖注入一个原型Bean到你的单例Bean中,因为注入只发生一次,当Spring容器实例化单例Bean时解析并注入它的依赖.如果你在运行时多次需要一个新的原型Bean,可以使用方法注入. 在大多数应用程序情

struts2的action是多例,servlet是单例

struts2中action是多例的,即一个session产生一个action如果是单例的话,若出现两个用户都修改一个对象的属性值,则会因为用户修改时间不同,两个用户访问得到的 属性不一样,操作得出的结果不一样.举个例子:有一块布长度300cm,能做一件上衣(用掉100cm)和一件裤子(用掉200cm);甲和乙同时访问得到的 长度都是300cm,甲想做上衣和裤子,他先截取100cm去做上衣,等上衣做完再去做裤子,而乙这时正好也拿100cm去做上衣,那 好,等甲做完上衣再做裤子的时候发现剩下的布(

SpringMvc 单例

struts2的controller是多例,是因为其中有modeldriven将比如user 或者其他属性暴露出来,接受属性,特别是继承了actionsupport之后,fielderror的属性也会设置进来,如果是单例,就会出错. springmvc 是在方法中加入Model或者Map(不常用)参数,用model.addAttribute()的方法来加入键值对,在页面用EL表达式即可取到值.个人觉得这个是存到了request对象里面去. 但是,注意的是,如果你没有在方法参数中,设置一个局部变量