java开发中经典的三大框架SSH

  首先我们要明白什么是框架为什么用?相信一开始学习编程的时候都会听到什么、什么框架之类的;首先框架是一个软件半成品,都会预先实现一些通用功能,使用框架直接应用这些通用功能而不用重新实现,所以大多数企业都用框架都是提高开发效率,节约开发成本。

  绝大多数框架都遵循着一种mvc设计模式思想,MVC是Model—View—Controler的简称。即模型—视图—控制器。MVC是一种设计模式,它强制性的把应用程序的输入、处理和输出分开。MVC中的模型、视图、控制器它们分别担负着不同的任务。 

    视图: 视图是用户看到并与之交互的界面。视图向用户显示相关的数据,并接受用户的输入。视图不进行任何业务逻辑处理。 

    模型: 模型表示业务数据和业务处理。相当于JavaBean。一个模型能为多个视图提供数据。这提高了应用程序的重用性 

    控制器: 当用户单击Web页面中的提交按钮时,控制器接受请求并调用相应的模型去处理请求。

  

  从上图可以看出mvc工作场景:MVC的处理过程:首先控制器接受用户的请求,调用相应的模型来进行业务处理,并返回数据给控制器。控制器调用相应的视图来显示处理的结果。并通过视图呈现给用户。

  然后再看看给予mvc模式的经典的框架SSH:分别是Struts、Spring、Hibernate 。

  首先介绍struts2框架:

  1、基于MVC模式的应用层框架技术!

  2、Struts2主要是通过Action动作类,处理请求! (与传统的servlet开发相比,只需要写Action类即可!用Action取代之前的servlet开发!) (Struts是对servletApi进行的封装!)

  3、  Struts2的发展 :Struts2=Struts1 + xwork

  4、Struts2功能的引入,是通过核心过滤器完成的! 如果想用struts的任何功能,必须经过核心过滤器!(被过滤器拦截!) (struts提供的标签的访问,要先经过核心过滤器:StrutsPrepareAndExecuteFilter!)

  还有struts2提供了一些简单的功能,方便开发;例如文件的上传,请求数据封装;代码如下

封装数据请求一:

<body>
      <form action="${pageContext.request.contextPath }/register.action" method="post">
          注册用户:<input type="text" name="userName">  <br/>
          注册密码:<input type="text" name="pwd">  <br/>
          
          <input type="submit" value="注册!">
      
      </form>
  </body>

 

public class UserAction extends ActionSupport {
    
    // 封装请求数据,方式1:
    private String userName;
     // request.getParameter(“userName”)
    // 把值作为方法参数传入!
    public void setUserName(String userName) {
        this.userName = userName;
    }
    private String pwd;
    public void setPwd(String pwd) {
        this.pwd = pwd;
    }

    @Override
    public String execute() {
        System.out.println(userName + "\t" + pwd);
        return "success";
    }
}

封装数据请求二:

注册用户:<input type="text" name="user.userName">  <br/>
 注册密码:<input type="text" name="user.pwd">  <br/>
public class UserAction extends ActionSupport {
    
    // 封装请求数据,
    private User user;
    public void setUser(User user) {
        this.user = user;
    }
    // 注意:如果是基本类型只用给set方法即可;  如果是对象,必须给set和get!
    public User getUser() {
        return user;
    }
}

从上面两种请求可以看出:一个是作为基本类型也就是字符串,另一个是对象。大多数用到的都是第二种。

struts2的配置文件简单介绍一下struts2默认访问后缀是.action最为后缀 , 默认执行的方法是execute!

struts2的配置文件大概是这样的

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
    "http://struts.apache.org/dtds/struts-2.3.dtd">

<struts>

    <!-- 
        1. package   包
                 作用: 管理action或管理路径的作用! 
           name   
                   表示包名称! 作用,被其他包继承!
                       <package name="base" extends="struts-default"></package>
                    <package name="config" extends="base">
                   包名不能重复!
           extends 
                   当前包表必须继承struts-default包!
                   (struts-default.xml 中定义了这个包!)
           abstract="true"
                   抽象包中不能有action配置!主要被其他包继承的!    
           namespace
                   名称空间,管理路径!作为路径的一部分!
                   默认值:/
                   访问路径 = namespace  + actionName
                   举例:http://localhost:8080/day27_struts01/user/update.action
                   
                   路径匹配原则:
                   http://localhost:8080/day27_struts01/user/a/b/c/update.action   OK
                http://localhost:8080/day27_struts01/user/a/b/update.action     OK
                http://localhost:8080/day27_struts01/user/a/update.action       OK
                   http://localhost:8080/day27_struts01/user/update.action         OK
                   http://localhost:8080/day27_struts01/a/user/update.action       NOK
                   
                   总结:
                       localhost  本机IP
                       8080       Tomcat
                       /day27_struts01   通常是%tomcat%/webapps下部署项目名称!
                   struts获取:
                       /user/a/b/c/update.action
                   截取得到:
                       /user/a/b/c    名称空间部分
                                      去这个名称空间找action name 是"update" 的路径,没有,就向上一级目录查找
                    /user/a/b     去这个名称找,没有"update", 向上一层找
                    /user/a       没有
                    /user         有则返回(不往下查找!)    ; 如果没有,去默认名称空间找
                    /             没有找到,则404!
         2. action 节点
             作用: 配置访问路径,与,处理action类的映射关系!
             name  
                 与名称空间共同组成访问路径!
             class
                 处理action类的全名!
             method
                 当前请求的处理方法!
                 如果不写,默认是execute!
             result 子节点
                 作用: action类的业务处理方法的返回的跳转标记,与跳转页面的映射关系!
                 name 
                     action类中方法返回的String
                 type
                     表示跳转的类型! (可写值的定义,在struts-default.xml中!)
                     默认是:dispatcher, 为转发!
                     
                     dispacher  默认值; 转发
                     redirect   重定向
                     标签体中可以指定跳转的页面!
                     
                       
     -->
    <package name="config" namespace="/user" extends="struts-default">
    
        <!-- 配置Action -->
        <action name="user" class="cn.itcast.b_config.UserAction" method="execute">
            <result name="success" type="redirect">/index.jsp</result>
        </action>
        
    </package>
    
</struts>

在介绍一下struts的工作原理吧

1.客户端发出一个指向servlet容器的请求;

2.请求会经过StrutsPrepareAndExecuteFilter过滤器;

3.过滤器和请求将访问struts2的底层框架结构。在web容器启动时,struts2框架会自动加载配置文件里相关参数,并转换成相应的类。

如:ConfigurationManager、ActionMapper和ObjectFactory。ConfigurationManager 存有配置文件的一些基本信息,ActionMapper存有action的配置信息。在请求过程中所有的对象(Action,Results,Interceptors,等)都是通过ObjectFactory来创建的。过滤器会通过询问ActionMapper类来查找请求中需要用到的Action。

4.如果找到需要调用的Action,过滤器会把请求的处理交给ActionProxy。ActionProxy为Action的代理对象。ActionProxy通过ConfigurationManager询问框架的配置文件,找到需要调用的Action类。

5.ActionProxy创建一个ActionInvocation的实例。ActionInvocation在ActionProxy层之下,它表示了Action的执行状态,或者说它控制的Action的执行步骤。它持有Action实例和所有的Interceptor。

6.ActionInvocation实例使用命名模式来调用,1. ActionInvocation初始化时,根据配置,加载Action相关的所有Interceptor。2. 通过ActionInvocation.invoke方法调用Action实现时,执行Interceptor。在调用Action的过程前后,涉及到相关拦截器(intercepetor)的调用。

7. 一旦Action执行完毕,ActionInvocation负责根据struts.xml中的配置找到对应的返回结果。

这些类不要太在意,大概知道干什么就可以了,如果想学精通就要查看底层类是使怎么写的,大多数框架都有技术文档

通俗的来讲:

1、发送http请求

2、Web服务器(tomcat/weblogic...)

3、执行struts核心过滤器StrutsPrepareAndExecuteFilter

4、加载struts配置文件中配置信息,找到对应的Action类并实例化

5、执行各类拦截器和Action中对应方法

6、配置文件中找到返回结果

7、转发到具体页面或其它操作

大概是这样

struts还有一个拦截器的概念:Interceptor 表示拦截器!struts2是通过一个个拦截器来完成通用的功能的。

struts2大概介绍到这里,还有其他知识自己学习吧!

Hibernate框架:

首先我们要明白一个东西那就是ORM规则:Object Relation  Mapping  对象关系映射!

所有简单来说Hibernate就是一个操作数据库的东西一般有两个配置文件,一个是关系对象配置文件,一个是主配置文件。例如:User.java

// 封装数据
public class User {

    private int id;
    private String name;
    private char sex;
    private Date birth;
}

User.hbm.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping>

    <class name="cn.itcast.a_hello.User" table="t_user">
        <id name="id" column="uid">
            <generator class="native"></generator>
        </id>
        
        <property name="name" column="uname"></property>
        <property name="sex" column="sex"></property>
        <property name="birth" column="birth"></property>
        
    </class>

</hibernate-mapping>

还有一个主配置文件hibernate.cfg.xml(核心配置文件)

<!DOCTYPE hibernate-configuration PUBLIC
    "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
    <session-factory>
        <!-- 1. 数据库连接信息 -->
        <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>    
        <property name="hibernate.connection.url">jdbc:mysql:///day31</property>    
        <property name="hibernate.connection.username">root</property>    
        <property name="hibernate.connection.password">root</property>    
        
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>    
        
        <property name="hibernate.show_sql">true</property>
        
        <!-- 3. 加载所有的映射 -->
        <mapping resource="User.hbm.xml"/>
        
    </session-factory>
</hibernate-configuration>

写一个类测试一些

public class App {

    // 用Hibernate,不写sql,保存对象!
    @Test
    public void testSave()  {
        // 对象
        User user = new User();
        user.setName("测试");
        user.setSex('它');
        user.setBirth(new Date());
        
        
        // 创建配置管理器对象
        Configuration config = new Configuration();
        // 加载主配置文件: hibernate.cfg.xml
        config.configure();
        // 根据加载的主配置文件,创建Sessionfactory对象!
        SessionFactory sf = config.buildSessionFactory(); 
        // 创建session  (维护了一个连接!)
        Session session = sf.openSession(); 
        // 开启事务
        Transaction tx =  session.beginTransaction(); 
        // --- 保存 ----
        session.save(user);
        // 提交事务、关闭session
        tx.commit();
        session.close();
    }
    
    
    // 用Hibernate,不写sql,查询对象!
    @Test
    public void testGet() throws Exception {
        Configuration config = new Configuration();
        config.configure();
        SessionFactory sf = config.buildSessionFactory(); 
        Session session = sf.openSession(); 
        Transaction tx =  session.beginTransaction(); 
        //--- 操作   --
        User user =  (User) session.get(User.class, 2);
        System.out.println(user);
        
        tx.commit();
        session.close();
    }
}

hibernate执行流程图如下:

原理: 1.读取并解析配置文件 2.读取并解析映射信息,创建SessionFactory 3.打开Session 4.创建事务Transation 5.持久化操作 6.提交事务 7.关闭Session 8.关闭SesstionFactory 

Spring框架:

spring框架有6大功能模块,需要用到那个模块就引用哪个模块,但核心模块必须引用

分别是:Spring Core   核心功能,SpringAop    面向切面编程,SpringWeb    对web开发的支持(spring对struts框架的支持!),SpringJdbc     对jdbc的支持,SpringORM     对ORM的支持(spring对hibenrate的支持),SpringJEE     对javaee其他模块的支持!(EJB)

可以看出Spring 主要是创建创建,与其他框架整合,表示可以帮其他框架创建对象!

举个简单例子如何创建对象

@Test
    public void testapp() throws Exception {
        // 获取容器创建的对象
        ApplicationContext ac = 
            new ClassPathXmlApplicationContext("Spring的xml文件路径");
        //从容器获取创建的对象
        Date d = (Date) ac.getBean("date");
        System.out.println(d);
        
        User user = (User) ac.getBean("user");
    }

就简单介绍一下

Spring核心, 就是指IOC容器!

IOC容器,

         主要是创建对象!

         Inversion  of  control  控制反转!  所以,也叫控制反转容器!

         控制反转,

                   对象的创建交给外部容器完成,程序需要对象,只需要从容器获取即可!

         IOC容器 = applicationContex.xml  + ApplicationContext类

         创建对象之后,给对象属性赋值, 这个叫“依赖注入”!

spring的xml文件大概这样子

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"
     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xmlns:p="http://www.springframework.org/schema/p"
     xsi:schemaLocation="http://www.springframework.org/schema/beans
     http://www.springframework.org/schema/beans/spring-beans.xsd">
</beans> 

里面的一些配置就需要自己查看相应的文档

这些框架都有自己的配置文件,都有相应的技术文档,所有不要觉得框架很难。总的来说学习这些框架式很容易入手的,那就是多练习,然后在上网(大多数在论坛上都有项目)找几个项目做。一个人的学习经验来说,都是模仿别人的项目,自己敲多几次就会了,好好学习吧

转载于:https://www.cnblogs.com/IT-Computer-TcpIp/p/6676086.html

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
.Hibernate<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" /> Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序实用,也可以在Servlet/JSP的Web应用使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构 取代CMP,完成数据持久化的重任。 大多数开发机构经常采取创建各自独立的数据持久层。一旦底层的数据结构发生改变,那么修改应用的其余部分使之适应这种改变的代价将是十分巨大的。Hibernate适时的填补了 这一空白,它为Java应用提供了一个易用的、高效率的对象关系映射框架。hibernate是个轻量级的持久性框架,功能却非常丰富。 优点: a.Hibernate 使用 Java 反射机制而不是字节码增强程序来实现透明性。 b.Hibernate 的性能非常好,因为它是个轻量级框架。映射的灵活性很出色。 c.它支持各种关系数据库,从一对一到多对多的各种复杂关系。 缺点:它限制您所使用的对象模型。(例如,一个持久性类不能映射到多个表)其独有的界面和可怜的市场份额也让人不安,尽管如此,Hibernate 还是以其强大的发展动力减轻了 这些风险。其他的开源持久性框架也有一些,不过都没有 Hibernate 这样有市场冲击力。 面回贴情绪有点激动,希望谅解,我不是因为有人批评Hibernate而感到不快,而是因为帖子里面的观点实在让我觉得荒谬。不管觉得Hibernate好也吧,不好也吧,我唯一觉得 遗憾的是,在文论坛里面找不到一个对Hibernate的真正高水平的评价。在TSS上有一个关于Hibernate的hot thread,跟了几百贴,其包括Hibernate作者Gavin和LiDO JDO的 CTO,对于JDO和Hibernate有过一些激烈的争论,我曾经耐心的看了一遍,仍然没有发现针对Hibernate真正有力的攻击,那些所谓的攻击无非针对Hibernate没有一个GUI的配置工 具,没有商业公司支持,没有标准化等等这些站不住脚的理由。 补充几点我的意见: 一、Hibernate是JDBC的轻量级的对象封装,它是一个独立的对象持久层框架,和App Server,和EJB没有什么必然的联系。Hibernate可以用在任何JDBC可以使用的场合,例如Java 应用程序的数据库访问代码,DAO接口的实现类,甚至可以是BMP里面的访问数据库的代码。从这个意义上来说,Hibernate和EB不是一个范畴的东西,也不存在非此即彼的关系。 二、Hibernate是一个和JDBC密切关联的框架,所以Hibernate的兼容性和JDBC驱动,和数据库都有一定的关系,但是和使用它的Java程序,和App Server没有任何关系,也不存在 兼容性问题。 三、Hibernate不能用来直接和Entity Bean做对比,只有放在整个J2EE项目的框架才能比较。并且即使是放在软件整体框架来看,Hibernate也是做为JDBC的替代者出现的,而 不是Entity Bean的替代者出现的,让我再列一次我已经列n次的框架结构: 传统的架构: 1) Session Bean <-> Entity Bean <-> DB 为了解决性能障碍的替代架构: 2) Session Bean <-> DAO <-> JDBC <-> DB 使用Hibernate来提高上面架构的开发效率的架构: 3) Session Bean <-> DAO <-> Hibernate <-> DB 就上面3个架构来分析: 1、内存消耗:采用JDBC的架构2无疑是最省内存的,Hibernate的架构3次之,EB的架构1最差。 2、运行效率:如果JDBC的代码写的非常优化,那么JDBC架构运行效率最高,但是实际项目,这一点几乎做不到,这需要程序员非常精通JDBC,运用Batch语句,调整 PreapredStatement的Batch Size和Fetch Size等参数,以及在必要的情况下采用结果集cache等等。而一般情况下程序员是做不到这一点的。因此Hibernate架构表现出最快的运行 效率。EB的架构效率会差的很远。 3、开发效率:在有JBuilder的支持下以及简单的项目,EB架构开发效率最高,JDBC次之,Hibernate最差。但是在大的项目,特别是持久层关系映射很复杂的情况下,Hibernate效 率高的惊人,JDBC次之,而EB架构很可能会失败。 4、分布式,安全检查,集群,负载均衡的支持 由于有SB做为Facade,3个架构没有区别。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值