struts、hibernate和spring是我们java开发中的常用关键,他们分别针对不同的应用场景给出最合适的解决方案。但你是否知道,这些知名框架最初是怎样产生的?
推荐课程:java教程。
我们知道,传统的java web应用程序是采用jsp+servlet+javabean来实现的,这种模式实现了最基本的mvc分层,使的程序结构分为几层,有负责前台展示的jsp、负责流程逻辑控制的servlet以及负责数据封装的javabean。但是这种结构仍然存在问题:如jsp页面中需要使用符号嵌入很多的java代码,造成页面结构混乱,servlet和javabean负责了大量的跳转和运算工作,耦合紧密,程序复用度低等等。
java三大框架是:
1、struts
为了解决这些问题,出现了struts框架,它是一个完美的mvc实现,它有一个中央控制类(一个servlet),针对不同的业务,我们需要一个action类负责页面跳转和后台逻辑运算,一个或几个jsp页面负责数据的输入和输出显示,还有一个form类负责传递action和jsp中间的数据。jsp中可以使用struts框架提供的一组标签,就像使用html标签一样简单,但是可以完成非常复杂的逻辑。从此jsp页面中不需要出现一行包围的java代码了。
可是所有的运算逻辑都放在struts的action里将使得action类复用度低和逻辑混乱,所以通常人们会把整个web应用程序分为三层,struts负责显示层,它调用业务层完成运算逻辑,业务层再调用持久层完成数据库的读写。
使用jdbc连接来读写数据库,我们最常见的就是打开数据库连接、使用复杂的sql语句进行读写、关闭连接,获得的数据又需要转换或封装后往外传,这是一个非常烦琐的过程。
2、hibernate
这时出现了hibernate框架,它需要你创建一系列的持久化类,每个类的属性都可以简单的看做和一张数据库表的属性一一对应,当然也可以实现关系数据库的各种表件关联的对应。当我们需要相关操作是,不用再关注数据库表。我们不用再去一行行的查询数据库,只需要持久化类就可以完成增删改查的功能。使我们的软件开发真正面向对象,而不是面向混乱的代码。我的感受是,使用hibernate比jdbc方式减少了80%的编程量。
现在我们有三个层了,可是每层之间的调用是怎样的呢?比如显示层的struts需要调用一个业务类,就需要new一个业务类出来,然后使用;业务层需要调用持久层的类,也需要new一个持久层类出来用。通过这种new的方式互相调用就是软件开发中最糟糕设计的体现。简单的说,就是调用者依赖被调用者,它们之间形成了强耦合,如果我想在其他地方复用某个类,则这个类依赖的其他类也需要包含。程序就变得很混乱,每个类互相依赖互相调用,复用度极低。如果一个类做了修改,则依赖它的很多类都会受到牵连。 为此,出现spring框架。
3、spring
spring的作用就是完全解耦类之间的依赖关系,一个类如果要依赖什么,那就是一个接口。至于如何实现这个接口,这都不重要了。只要拿到一个实现了这个接口的类,就可以轻松的通过xml配置文件把实现类注射到调用接口的那个类里。所有类之间的这种依赖关系就完全通过配置文件的方式替代了。所以spring框架最核心的就是所谓的依赖注射和控制反转。
现在的结构是,struts负责显示层,hibernate负责持久层,spring负责中间的业务层,这个结构是目前国内最流行的java web应用程序架构了。另外,由于spring使用的依赖注射以及aop(面向方面编程),所以它的这种内部模式非常优秀,以至于spring自己也实现了一个使用依赖注射的mvc框架,叫做spring mvc,同时为了很好的处理事物,spring集成了hibernate,使事物管理从hibernate的持久层提升到了业务层,使用更加方便和强大。
struts框架是2000年就开始起步了,技术相当成熟,目前全球java开发中struts框架是显示层技术中当之无愧的王者。它拥有大量的用户群和很好的开发团队。这也是国内大部分java软件公司对新进员工的基本要求。
其他
java这个名词似乎注定和开源紧密联系在一起了,在java界,每天都有大量的开源技术出现,由于是开放源代码的,技术中存在的问题和不足很快就会被人发现,开源软件提供者会很快的修正或扩展这些技术,因此版本更新很快,几个星期或者几天就有一个新版本出来。
当我们在技术线路中选择了java,也就选择了你必须持续学习,经常关注最新的技术,了解它们,看是否适合你的需要,然后学习使用它们。
java的ssm的组合也是非常的不错,大家可以去学习了解。
以上就是java三大框架是什么的详细内容。