struts、spring、hibernate联系
2个回答
展开全部
没什么联系!
实际上这些框架的产生的背景就是因为开发上有各层之间脱离关系的需要(解耦)
但是要达到完全的没有交互,完全的不具侵入性是很难的.主要作为容器框架的spring就对于其它层的相当多的框架具有整合接口.
这样在整合的时候还是具有侵入性的,但是作为开发来说还是松散的结构.
打个比方,这三种框架就好比互联网(互联网的一大特点就是松散)上的pc或者服务器或者工作站或者数据中心,说没有关系的话不对,因为它们在同一个互联网上。说有关系的话也不准确,因为少了一台机器完全不会对于其它机器有必然的影响.
但是,从根本上来说,它们是没有关系的.
更准确地说是不相互依赖的.
楼上的用MVC来表述SSH的关系是根本错误的,实际上Struts就是MVC框架,除了它还有其它的MVC框架,比如JSF、webwork.
hibernate是O/R Mapping框架,负责对象关系映射.之所以有hibernate这样的框架是因为当前的主流持久化产品比如XML、关系型数据库等等都是平面的二维度表示法来描述数据,而OOP语言操纵的是对象.它的产生是为了简化对象到二维数据之间的转换.和MVC中的Model根本不是对应关系,Model是指业务逻辑,应该由领域模型完成.而O/R Mapping框架们喜欢的是缺血模型,领域模型里面的业务方法是它们力图避开的东西.
spring框架也不是C,C是control-导航控制层,对应于struts里面的action或者是servlet里面的service方法.而spring是粘合剂,在开发期和运行期对于整个系统进行装配管理,并且对于一些设计模式不太熟练的团队提供架构支持,和导航控制完全是两个概念.
而struts属于经典MVC框架,tapestry、jsp这些是view视图,action+struts.xml负责导航,而业务逻辑(Model)应该是交由外部的service方法(针对缺血模型)或者领域模型(充血模型)去完成.
实际上这些框架的产生的背景就是因为开发上有各层之间脱离关系的需要(解耦)
但是要达到完全的没有交互,完全的不具侵入性是很难的.主要作为容器框架的spring就对于其它层的相当多的框架具有整合接口.
这样在整合的时候还是具有侵入性的,但是作为开发来说还是松散的结构.
打个比方,这三种框架就好比互联网(互联网的一大特点就是松散)上的pc或者服务器或者工作站或者数据中心,说没有关系的话不对,因为它们在同一个互联网上。说有关系的话也不准确,因为少了一台机器完全不会对于其它机器有必然的影响.
但是,从根本上来说,它们是没有关系的.
更准确地说是不相互依赖的.
楼上的用MVC来表述SSH的关系是根本错误的,实际上Struts就是MVC框架,除了它还有其它的MVC框架,比如JSF、webwork.
hibernate是O/R Mapping框架,负责对象关系映射.之所以有hibernate这样的框架是因为当前的主流持久化产品比如XML、关系型数据库等等都是平面的二维度表示法来描述数据,而OOP语言操纵的是对象.它的产生是为了简化对象到二维数据之间的转换.和MVC中的Model根本不是对应关系,Model是指业务逻辑,应该由领域模型完成.而O/R Mapping框架们喜欢的是缺血模型,领域模型里面的业务方法是它们力图避开的东西.
spring框架也不是C,C是control-导航控制层,对应于struts里面的action或者是servlet里面的service方法.而spring是粘合剂,在开发期和运行期对于整个系统进行装配管理,并且对于一些设计模式不太熟练的团队提供架构支持,和导航控制完全是两个概念.
而struts属于经典MVC框架,tapestry、jsp这些是view视图,action+struts.xml负责导航,而业务逻辑(Model)应该是交由外部的service方法(针对缺血模型)或者领域模型(充血模型)去完成.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询