zoukankan      html  css  js  c++  java
  • Spring框架ioc概括

     什么是Spring且能做什么

    • Spring是一个开源框架,它由Rod Johnson创建。它是为了解决企业应用开发的复杂性而创建的。
    • Spring使用基本的JavaBean来完成以前只可能由EJB完成的事情。
    • Spring的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度而言,任何Java应用都可以从Spring中受益。
    • 目的:解决企业应用开发的复杂性
    • 功能:使用基本的JavaBean代替EJB,并提供了更多的企业应用功能
    • 范围:任何Java应用
    • 简单来说,Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架。

    图解,如果框架太多的话,会导致开发复杂性大大提高,框架与框架之间到处串联;

     但是如果以spring框架为中心去串联其他框架,就大大降低了开发的复杂性


    什么是控制反转(Ioc)

    • 控制反转(IoC=Inversion of Control)IoC,用白话来讲,就是由容器控制程序之间的(依赖)关系,而非传统实现中,由程序代码直接操控。这也就是所谓“控制反转”的概念所在:(依赖)控制权由应用代码中转到了外部容器,控制权的转移,是所谓反转。
    • IoC还有一个另外的名字:“依赖注入 (DI=Dependency Injection)”  ,即由容器动态的将某种依赖关系注入到组件之中

    案例:实现Spring的IoC

    IOC/DI
    将以前由程序员实例化对象/赋值的工作交给了spring处理

    Biz层

    创建一个接口类,写一个方法接口

    package com.ht.ioc.biz;
    /**
     * 需求:
     *     上传文件:
     *         完成的思路:完成功能好    文件上传就行了
     * @author Administrator
     *
     */
    public interface UserBiz {
    
        public void read();
    }

    为了体现出差距和弊端,就写俩个实现类吧

    UserBizipml01

    public class UserBizimpl implements UserBiz{
    
        @Override
        public void read() {
            // TODO Auto-generated method stub
            System.out.println("本是青灯不归客,却因浊酒留风尘。");
        }
    }

    UserBizipml02

    public class UserBizipml02 implements UserBiz{
    
        @Override
        public void read() {
            // TODO Auto-generated method stub
            System.out.println("星光不问赶路人,岁月不负有心人。");
        }
    
    }

    写一个测试类去调用web层的测试方法让他在控制台上实现效果

    package com.ht.ioc.test;
    
    import com.ht.ioc.web.UserAction;
    
    /**
     * 模拟浏览器请求后台
     * @author Administrator
     *
     */
    public class Demo1 {
    public static void main(String[] args) {
        //实例化一个用户web类
        UserAction userAction=new UserAction();
        userAction.text03();//调用web层中的测试方法
    }
    }

    在web层中调用接口不同的实现类

    public class UserAction {
        // 实例化一个接口
        private UserBiz userBiz = new UserBizimpl();
    
        public void text03() {
            userBiz.read();
        }
    
    }

    效果图:

    public class UserAction {
        // 实例化一个接口
        private UserBiz userBiz = new UserBizipml02();
    
        public void text03() {
            userBiz.read();
        }
    
    }

    效果图:

    由此也可以看出来弊端:

      当需求变化非常快的时候,不便于维护,因为维护的权利是属于程序员的 

    spring的ioc就是解决这一个问题的
     将维护代码的权利由程序员转交给spring容器来完成

    如何在spring当中定义和配置一个JavaBean(使用无参构造方法+set方法创建一个JavaBean)

    • id:在容器中查找Bean的id(唯一、且不能以/开头)
    • class:bean的完整类名
    • name:在容器中查找Bean的名字(唯一、允许以/开头、允许多个值,多个值之间用逗号或空格隔开)
    • scope:(singleton|prototype)默认是singleton
    • singleton(单例模式):在每个Spring IoC容器中一个bean定义对应一个对象实例
    • prototype(原型模式/多例模式):一个bean定义对应多个对象实例
    • abstract:将一个bean定义成抽象bean(抽象bean是不能实例化的),抽象类一定要定义成抽象bean,非抽象类也可以定义成抽象bean
    • parent:指定一个父bean(必须要有继承关系才行)
    • init-method:指定bean的初始化方法
    • constructor-arg:使用有参数构造方法创建javaBean

     set注入

    1. 基本数据类型

    userAction类

    public class UserAction {
        private int uid;
        private String uname;
        private List<String> hobby =new ArrayList<String>();
    public void setUid(int uid) {
            this.uid = uid;
        }
    
        public void setUname(String uname) {
            this.uname = uname;
        }
        public void setHobby(List<String> hobby) {
            this.hobby = hobby;
        }
        public int getUid() {
            return uid;
        }
        public String getUname() {
            return uname;
        }
        public List<String> getHobby() {
            return hobby;
        }
        /**
         * set注入ע
         * 
         */
        public void text01() {
            System.out.println("uid:"+this.uid);
            System.out.println("uname:"+this.uname);
            System.out.println("hobby:"+this.hobby);
        }
    }

    spring-context.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:aop="http://www.springframework.org/schema/aop"
        xmlns:context="http://www.springframework.org/schema/context"
        xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
            http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.3.xsd 
            http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd">
        <bean id="userAction" class="com.ht.ioc.web.UserAction">
            <property name="uid" values="23"></property>
            <property name="uname" values="zk"></property>
            <!-- <constructor-arg name="uid" value="22"></constructor-arg>
                <constructor-arg name="uname" value="zs"></constructor-arg> -->
            <property name="hobby">
                <list>
                <value>青灯</value>
                <value>15</value>
                <value>古镇</value>
                </list>
            </property>
        </bean>
    </beans>

    测试类

    public class Demo1 {
    public static void main(String[] args) {
    //    UserAction userAction=new UserAction();
    //    userAction.text03();
    //    userAction.text01();
        ApplicationContext context = new ClassPathXmlApplicationContext("/spring-context.xml");
        UserAction userAction = (UserAction) context.getBean("userAction");
        userAction.text01();
    }
    }

    运行结果:

    uid:23

    uname:zk

    hobby:[青灯,15,古镇]

      2.set注入(引用类型)

    useAction类改变一下

    private UserBiz userBiz;
        //    private UserBiz userBiz = new UserBizipml02();
        public UserBiz getUserBiz() {
            return userBiz;
        }
    
        public void setUserBiz(UserBiz userBiz) {
            this.userBiz = userBiz;
        }

    spring-context.xml

    <bean id="userAction" class="com.ht.ioc.biz.impl.UserBizimpl"></bean>
        <bean id="userAction" class="com.ht.ioc.web.UserAction">
            <!-- <property name="uid" values="23"></property>
            <property name="uname" values="zk"></property> -->
            <constructor-arg name="uid" value="22"></constructor-arg>
                <constructor-arg name="uname" value="zs"></constructor-arg>
            <property name="hobby">
                <list>
                <value>青灯</value>
                <value>15</value>
                <value>古镇</value>
                </list>
            </property>
        </bean>

    运行效果

    uid:22

    uname:zs

    hobby:[青灯,15,古镇]

    构造注入

    userAction类

    public UserAction() {
            super();
        }
    
        public UserAction(int uid, String uname, List<String> hobby) {
            super();
            this.uid = uid;
            this.uname = uname;
            this.hobby = hobby;
        }

    spring-context.xml

    <bean id="userAction" class="com.ht.ioc.web.UserAction">
            <!-- <property name="uid" values="23"></property>
            <property name="uname" values="zk"></property> -->
            <constructor-arg name="uid" value="22"></constructor-arg>
                <constructor-arg name="uname" value="zs"></constructor-arg>
            <property name="hobby">
                <list>
                <value>青灯</value>
                <value>15</value>
                <value>古镇</value>
                </list>
            </property>
        </bean>

    自动装置

    • 在spring-context.xml里加上

        default-autowire="byType"

      因为是根据类别进行查询,所以出现多个实体类时就不行了

    • 在spring-context.xml里加上

        default-autowire="byName"

          这是根据名字查询,追踪的位置比较清晰,所以就不会报错

    tomcat管理spring

    实现思路:

    如何将spring的上下文交给tomcate上下文进行管理
    首先spring上下文为什么tomact?
    分析: 目前工程中的所有javabean都交给了spring进行管理,那么浏览器发送请求,请求的是tomcat,
    由tomcat来处理请求,tomcat处理请求一般来说都要访问数据库,数据库是由Dao层访问的,
    Dao层的实体类又是spring的上下文管理,那就意味着,tomcat要处理请求,必须拿到spring的上下文,
    才能拿到Dao层的javabean

    上代码:

    SpringLoadListener类

    package com.ht.ioc.test;
    
    import javax.servlet.ServletContext;
    import javax.servlet.ServletContextEvent;
    import javax.servlet.ServletContextListener;
    
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.support.ClassPathXmlApplicationContext;
    
    public class SpringLoadListener implements ServletContextListener{
        private String springXmlLocation="";
        @Override
        public void contextInitialized(ServletContextEvent sce) {
            System.out.println("启动........");
            ServletContext servletContext = sce.getServletContext();
            springXmlLocation=servletContext.getInitParameter("springXmlLocation");
            if(null==springXmlLocation||"".equals(springXmlLocation)) {
                springXmlLocation ="/spring-context.xml";
            }
            System.out.println("springXmlLocation:"+springXmlLocation);
            ApplicationContext springContext= new ClassPathXmlApplicationContext(springXmlLocation);
            servletContext.setAttribute("spring_context_key", springContext);
        }
    }

    userServlet类

    package com.ht.ioc.test;
    
    import java.io.IOException;
    
    import javax.servlet.ServletContext;
    import javax.servlet.ServletException;
    import javax.servlet.annotation.WebServlet;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    import com.ht.ioc.web.UserAction;
    
    @WebServlet("/user")
    public class UserServlet extends HttpServlet{
            @Override
            protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
                doPost(req, resp);
            }
            
            @Override
            protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
                // TODO Auto-generated method stub
                ServletContext servletContext = req.getServletContext();
                ApplicationContext springContext = (ApplicationContext) servletContext.getAttribute("spring_context_key");
                UserAction bean = (UserAction) springContext.getBean("userAction");
                bean.text03();
            }
    }

    谢谢观看!

  • 相关阅读:
    WPF DataGrid列放入Btn整理
    WPF XAML颜色变换整理
    摄影
    Markdown学习
    leetcode 54 螺旋矩阵
    leetcode 120 三角形最小路径和
    LeetCode 63 不同路径||
    程序员职业发展建议
    怎样才能使自己的内心平静
    mysql基础SQL ALTER TABLE
  • 原文地址:https://www.cnblogs.com/huangting/p/11234060.html
Copyright © 2011-2022 走看看