zoukankan      html  css  js  c++  java
  • Spring基础

    13.1 Spring 概述

    Spring框架的主要优势之一是其分层架构,分层架构允许选择使用任一个组件,同时为 Java EE 应用程序开发提供集成的框架。Spring 框架的分层架构,由 7 个定义良好的模块组成。Spring 模块构建在核心容器之上,核心容器定义了创建、配置和管理 Bean 的方式,如图7.1所示。

              image

    组成Spring 框架的每个模块(或组件)都可以单独存在,或者与其他一个或多个模块联合实现。每个模块的功能如下:

    l Spring Core:核心容器提供 Spring 框架的基本功能。核心容器的主要组件是 BeanFactory,它是工厂模式的实现。BeanFactory 使用控制反转(IOC)模式将应用程序的配置和依赖性规范与实际的应用程序代码分开。

    Spring Context:Spring 上下文是一个配置文件,向 Spring 框架提供上下文信息。Spring 上下文包括企业服务,例如 JNDI、EJB、电子邮件、国际化、校验和调度功能。

    Spring AOP(面向方面编程):通过配置管理特性,Spring AOP 模块直接将面向方面的编程功能集成到了Spring框架中,所以,可以很容易地使 Spring 框架管理的任何对象支持 AOP。Spring AOP 模块为基于Spring 的应用程序中的对象提供了事务管理服务。通过使用Spring AOP,不用依赖EJB组件,就可以将声明性事务管理集成到应用程序中。

    Spring DAO(数据访问对象):JDBC DAO 抽象层提供了有意义的异常层次结构,可用该结构来管理异常处理和不同数据库供应商抛出的错误消息。异常层次结构简化了错误处理,并且极大地降低了需要编写的异常代码数量(例如打开和关闭连接)。Spring DAO 的面向 JDBC 的异常遵从通用的 DAO 异常层次结构。

    Spring ORM(对象关系映射):Spring 框架插入了若干个 ORM 框架,从而提供了ORM 的对象关系工具,其中包括 JDO、Hibernate 和 iBatis SQL Map。所有这些都遵循 Spring 的通用事务和 DAO 异常层次结构。

    Spring Web 模块:Web 上下文模块建立在应用程序上下文模块之上,为基于 Web 的应用程序提供了上下文,所以,Spring 框架支持与 Jakarta Struts 的集成。Web 模块还简化了处理多部分请求以及将请求参数绑定到域对象的工作。

    Spring Web MVC 框架:MVC 框架是一个全功能的构建 Web 应用程序的 MVC 实现。通过策略接口,MVC 框架变成为高度可配置的,MVC 容纳了大量视图技术,其中包括 JSP、Velocity、Tiles、iText 和 POI。

    项目开发实例

    1.建立项目

    首先,建立Web项目(该例为应用程序,也可以建立Java项目),命名为“SpringDemo”

    2.添加Spring的核心类库

    添加Spring的核心类库有两种方法,一种是下载Spring的完全包,把Spring的核心类库复制到项目的lib文件下,另一种是利用MyEclipse中包含的Spring的类库。本例就是应用第二种方法,右击项目名“SpringDemo”,依次选择“Build Path”→“configure Build Path...”,出现如图13.2所示的对话框。

    image

    选择左边的“Add Library...”按钮,出现如图13.3所示的对话框,选中“MyEclipse Libraries”,单击“Next”按钮,出现如图13.4所示的选择要添加的类库的界面,选中“Spring 2.5 Core Libraries”,单击“Finish”按钮完成,会回到图13.2所示的界面,但此时在Libraries框中多出了“Spring 2.5 Core Libraries”类库,单击“OK”完成类库的添加。

    image             image  

    项目目录结构如图13.5所示。

    image

    3.编写模型类HelloWorld.java

    该类主要是输出信息的get和set方法,用于为属性赋值,该类放在“org.model”包下,代码为:

    package org.model;

    public class HelloWorld {

    private String message;

    public String getMessage() {

    return message;

    }

    public void setMessage(String message) {

    this.message = message;

    }

    }

    在一般情况下,可以直接编写测试类,例如:

    package org.test;

    import org.model.HelloWorld;

    public class Test {

    public static void main(String [] args){

    HelloWorld helloWorld=new HelloWorld();

    helloWorld.setMessage("Hello World!");

    System.out.println(helloWorld.getMessage());

    }

    }

    运行该测试类,在控制台就可以输出“HelloWorld”了,如图13.6所示。

    image

    4.创建Spring的核心配置文件config.xml

    值得一提的是,该文件名不是固定的,可以更改。把该文件放置在src下(也可以放在其他地方,但是在测试程序中加载该文件的路径会根据放置地方的不同而改变),该配置文件代码如下:

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

    <beans xmlns="http://www.springframework.org/schema/beans"

    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

    xsi:schemaLocation="http://www.springframework.org/schema/beans

    http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">

    <bean id="HelloWorld" class="org.model.HelloWorld">

    <property name="message" >

    <value>Hello World!</value>

    </property>

    </bean>

    </beans>

    5. 编写测试类HelloWorldTest.java代码如下:

    package org.test;

    import org.model.HelloWorld;

    import org.springframework.context.ApplicationContext;

    import org.springframework.context.support.FileSystemXmlApplicationContext;

    public class HelloWorldTest {

    public static void main(String[] args) {

    //获取ApplicationContext对象

    ApplicationContext ac=

    new FileSystemXmlApplicationContext("/WebRoot/WEB-INF/classes/config.xml");

    //根据ApplicationContact对象获得HelloWorld对象,getBean方法中的参数即为

    //配置文件中的Bean的id值

    HelloWorld helloWorld=(HelloWorld) ac.getBean("HelloWorld");

    //输出

    System.out.println(helloWorld.getMessage());

    }

    }

    运行该测试类,结果与上面的Test.java的运行结果相同。但程序若要输出“Hello Yabber”,则只需修改配置文件中的“value”值即可,即:

    <value>Hello Yabber!</value>

    不需要修改任何程序中的代码,运行“HelloWorldTest.java”,控制台输出结果如图13.7所示。

    image

  • 相关阅读:
    easyui-tree/combotree 子节点前端懒加载(主要解决ie11下加载慢
    解决 Chrome 下表单自动填充问题 (两种方法
    代码编辑器:本地JS文件上传并加载到页面
    PC端使用rem进行屏幕适配
    ECharts 点击非图表区域的点击事件不触发问题
    Angular2+ 使用 Post 请求下载文件
    Express + Element-ui 实现图片/文件上传
    phpMyAdmin -- 没有权限操作用户
    Note of Moment -- 日期处理
    Angular 自定义表单控件 -- CheckboxGroupComponent
  • 原文地址:https://www.cnblogs.com/elite-2012/p/4364885.html
Copyright © 2011-2022 走看看