【Spring】浅析Spring框架的搭建

时间:2021-07-24 01:31:27

Spring是什么

Spring是一个开源的容器框架,用于配置bean并且维护bean之间关系的。其主要的思想就是IOC(Inversion Of Control,控制反转)或者称作DI(Dependency Injection,依赖注入)。IOC的解释就是程序中对象的获取方式发生反转,最初由new方式创建对象转化为由容器创建,注入,这样可以降低对象之间的耦合度。依赖注入,就是IOC的另一种说法,程序中被注入的对象依赖IOC容器中配置的对象。

Spring的结构图:

【Spring】浅析Spring框架的搭建

搭建Spring框架步骤

  1. 下载Spring开发包,Spring-4.3.4完整开发包下载
  2. 在JavaProject下面建立一个lib目录,将开发包下面的libs目录里的所有以spring开头的jar文件,和commons-logging文件都拷贝到新建的lib里面。
  3. 将拷贝的文件全部选中,然后添加到Build path里。

简单Demo

我的结构目录:

【Spring】浅析Spring框架的搭建

  1. 建立一个User类

    package cn.shop.bean;
    
    import java.sql.Date;
    
    public class User {
    
        private int id;
    private String login_name;
    private String password;
    private Date birth; public User() {
    super();
    } public User(int id, String login_name, String password, Date birth) {
    super();
    this.id = id;
    this.login_name = login_name;
    this.password = password;
    this.birth = birth;
    } public int getId() {
    return id;
    } public void setId(int id) {
    this.id = id;
    } public String getLogin_name() {
    return login_name;
    } public void setLogin_name(String login_name) {
    this.login_name = login_name;
    } public String getPassword() {
    return password;
    } public void setPassword(String password) {
    this.password = password;
    } public Date getBirth() {
    return birth;
    } public void setBirth(Date birth) {
    this.birth = birth;
    } @Override
    public String toString() {
    return "User [id=" + id + ", login_name=" + login_name + ", password=" + password + ", birth=" + birth + "]";
    } }

    User.java

  2. 建立一个UserDao类

    package cn.shop.dao;
    
    import java.util.List;
    
    import org.springframework.jdbc.core.BeanPropertyRowMapper;
    import org.springframework.jdbc.core.support.JdbcDaoSupport; import cn.shop.bean.User; public class UserDao extends JdbcDaoSupport { public List<User> selectAllUser(){
    return getJdbcTemplate().query("select * from xdl_user", new BeanPropertyRowMapper<User>(User.class));
    } }

    UserDao

    该类继承了JdbcDaoSupport类,该类里面有一个dataSource属性,该属性是用来创建jdbcTemplate用的。因为UserDao类直接继承了JdbcDaoSupport,因此可以拥有dataSource,便于后面在配置文件中设置。

    上面除了query,还有queryForObject、update、execute。

    new BeanPropertyRowMapper<User>(User.class)

    这样代码采用了反射技术,就是把查询到结果集反射到User类的属性上。因此该类的属性应该和数据表中的字段名对应,可以忽略大小写。

    当然除了使用BeanPropertyRowMapper,还可以使用RowMapper。

  3. 建立一个Test类

    package cn.shop.test;
    
    import java.util.List;
    
    import org.junit.Test;
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.support.ClassPathXmlApplicationContext; import cn.shop.bean.User;
    import cn.shop.dao.UserDao; public class UserDaoTest { @Test
    public void Test() throws Exception {
    ApplicationContext ac=new ClassPathXmlApplicationContext("applicationContext.xml");
    UserDao userDao=ac.getBean("userDao", UserDao.class);
    List<User> users = userDao.selectAllUser();
    System.out.println(users);
    }
    }

    UserDaoTest.java

    ApplicationContext是一个接口,由ClassPathXmlApplicationContext寻找applicationContext这个文件,在开发包里一个index.html的网页文件,读者可以在里面查找相应Spring版本的API文档。

    ClassPathXmlApplicationContext类用来加载文件

    ApplicationContext ac=new ClassPathXmlApplicationContext("applicationContext.xml");

  4. 建立applicationContext文件

    <?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:context="http://www.springframework.org/schema/context"
    xmlns:jdbc="http://www.springframework.org/schema/jdbc"
    xmlns:jee="http://www.springframework.org/schema/jee"
    xmlns:tx="http://www.springframework.org/schema/tx"
    xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:mvc="http://www.springframework.org/schema/mvc"
    xmlns:util="http://www.springframework.org/schema/util"
    xmlns:jpa="http://www.springframework.org/schema/data/jpa"
    xsi:schemaLocation="
    http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd
    http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-4.1.xsd
    http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-4.1.xsd
    http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.1.xsd
    http://www.springframework.org/schema/data/jpa http://www.springframework.org/schema/data/jpa/spring-jpa-1.3.xsd
    http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.1.xsd
    http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd
    http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.1.xsd"> <!--导入数据库相关文件-->
    <util:properties id="db" location="classpath:db.properties"></util:properties> <bean id="database" class="org.apache.commons.dbcp.BasicDataSource">
    <!-- 驱动地址 -->
    <property name="driverClassName" value="#{db.driverClassName}"></property>
    <!-- 数据库的连接地址 -->
    <property name="url" value="#{db.url}"></property>
    <!-- 数据库的帐号 -->
    <property name="username" value="#{db.username}"></property>
    <!-- 数据库的密码 -->
    <property name="password" value="#{db.password}"></property>
    </bean> <bean id="userDao" class="cn.shop.dao.UserDao">
    <!--
    在调用set方法进行赋值,
    Spring容器是通过反射技术 ,根据我们传递的name参数 , 得到对应的set方法名称, 将其调用
    -->
    <property name="dataSource" ref="database"></property>
    </bean>
    </beans>

    applicationContext.xml

  5. 建立db.properties文件

    driverClassName=oracle.jdbc.OracleDriver
    url=jdbc:oracle:thin:@localhost:1521:xe
    password=517839
    username=system

    关于上面beans的一些属性的使用,读者可以参见:Spring创建对象的三种方式

Spring-tool-suite的是什么

Spring-tool-suite就是一个方便Spring开发的工具,在使用之前是需要进行安装的,Eclipse安装Spring-tool-suite

这里介绍的配置Spring的方法,不足以达到SpringMVC的使用,关于SpringMVC的配置可以参见SpringMVC的非注解配置的两种方式

参考文章

http://blog.csdn.net/zoutongyuan/article/details/27073683

本文为博主原创文章,如需转载请注明出处。

【Spring】浅析Spring框架的搭建的更多相关文章

  1. Spring&plus;SpringMvc&plus;Mybatis框架集成搭建教程

    一.背景 最近有很多同学由于没有过SSM(Spring+SpringMvc+Mybatis , 以下简称SSM)框架的搭建的经历,所以在自己搭建SSM框架集成的时候,出现了这样或者那样的问题,很是苦恼 ...

  2. 用IntelliJ IDEA 开发Spring&plus;SpringMVC&plus;Mybatis框架 分步搭建四:配置springmvc

    在用IntelliJ IDEA 开发Spring+SpringMVC+Mybatis框架 分步搭建三:配置spring并测试的基础上 继续进行springmvc的配置 一:配置完善web.xml文件

  3. 用IntelliJ IDEA 开发Spring&plus;SpringMVC&plus;Mybatis框架 分步搭建三:配置spring并测试

    这一部分的主要目的是 配置spring-service.xml  也就是配置spring  并测试service层 是否配置成功 用IntelliJ IDEA 开发Spring+SpringMVC+M ...

  4. 用IntelliJ IDEA 开发Spring&plus;SpringMVC&plus;Mybatis框架 分步搭建二:配置MyBatis 并测试(2 配置spring-dao和测试)

    用IntelliJ IDEA 开发Spring+SpringMVC+Mybatis框架 分步搭建二:配置MyBatis 并测试(1 搭建目录环境和依赖) 四:在\resources\spring 下面 ...

  5. 用IntelliJ IDEA 开发Spring&plus;SpringMVC&plus;Mybatis框架 分步搭建二:配置MyBatis 并测试(1 构建目录环境和依赖)

    引言:在用IntelliJ IDEA 开发Spring+SpringMVC+Mybatis框架 分步搭建一   的基础上 继续进行项目搭建 该部分的主要目的是测通MyBatis 及Spring-dao ...

  6. 用IntelliJ IDEA 开发Spring&plus;SpringMVC&plus;Mybatis框架 分步搭建一:建立MAVEN Web项目

    一:创建maven web项目er

  7. SSM&lpar;Spring&plus;SpringMVC&plus;Mybatis&rpar;框架环境搭建&lpar;整合步骤&rpar;&lpar;一&rpar;

    1. 前言 最近在写毕设过程中,重新梳理了一遍SSM框架,特此记录一下. 附上源码:https://gitee.com/niceyoo/jeenotes-ssm 2. 概述 在写代码之前我们先了解一下 ...

  8. Struts2&plus;Spring&plus;Hibernate&lpar;SSH&rpar;框架的搭建

    首先需要下载struts2 ,spring4,hibernate5  的资源包; struts2资源包下载路径:http://www.apache.org/spring资源包下载路径:http://p ...

  9. Spring&plus;SpringMvc&plus;Mybatis框架集成搭建教程一&lpar;项目创建&rpar;

    一.框架搭建环境 Spring 4.2.6.RELEASE SpringMvc 4.2.6.RELEASE Mybatis 3.2.8 Maven 3.3.9 Jdk 1.7 Idea 15.04 二 ...

  10. Spring&plus;SpringMvc&plus;Mybatis框架集成搭建教程四&lpar;项目部署及测试&rpar;

    在IDEA中将项目部署到本地Tomcat下进行运行并验证整合结果 (1).点击如下图所示的下拉按钮,弹出Edit Configurations...后点击该项. (2).跳出如下界面后,点击红框内的& ...

随机推荐

  1. 读书笔记--SQL必知必会19--存储过程

    不同的DBMS对存储过程的实现不同,差异巨大,这里不涉及具体的DBMS,仅仅说明存储过程的简单含义. 19.1 存储过程 简单来说,存储过程就是为以后使用而保存的一条或多条SQL语句. 可以将存储过程 ...

  2. 自然数的K次幂的数列求和

        ------------------------------------------------------------------------------- 转载请注明出处 博客园 刺猬的温 ...

  3. 免费好用的web应用托管平台

    1.前言 曾经很久以前,想找一个免费的空间部署一个属于自己的技术博客真是太难了,使用过SAE,但是很快就面临收费了,后面也就不了了之了.目前自己又找到一个免费的PAAS平台,可以部署各种语言的web应 ...

  4. Windows环境下安装Redis

    1:首先下载redis.从下面地址下:https://github.com/MSOpenTech/redis/releases2:创建redis.conf文件:这是一个配置文件,指定了redis的监听 ...

  5. NSIS:卸载时选择组件

    原文 NSIS:卸载时选择组件 有时候,我们想要在卸载时也可以选择组件,进行定制性的卸载,那么,以下文字将简略讨论这个问题: 题外:我们想要卸载时选择组件,当然是在安装时要有组件选择页面的前提下,也就 ...

  6. 使用dotnet build时复制引用dll到生成目录

    默认配置下dotnet build只会输出项目代码的dll,依赖用的是dotnet缓存中的dll,只有dotnet publish才会把依赖的dll一起输出到生成目录. 在项目csproj文件中添加以 ...

  7. 04&lowbar;web基础(八)之车票实现增删改查初级版本

    43.web页面显示车票列表简略完成 代码: 控制层代码 package com.day03.station.controller; import com.day03.station.model.Ti ...

  8. 服务级别协议(SLA)与运行水平协议(OLA)

    服务级别协议(SLA)与运行水平协议(OLA): 服务级别管理和服务级别协议在国内已被广泛接受并成用.本文试图讨论服务级别协议(SLA)和运行水平协议(OLA)的异同. 1. SLA a.定义 服务级 ...

  9. CSS技巧教程&colon;margin在IE中的表现

    margin的位移方向是指margin数值为正值时候的情形,如果是负值则位移方向相反. 如上图所示:黄色子元素盒的margin-top,margin-left为负值时,如-10px,则黄色子元素盒向上 ...

  10. MySQL更新丢失

    MySQL多主结构(比如: MGR Multi Master模式),如果多主都可以写的话,很有可能出现更新丢失的情况. 定义:  T1时间,T2时间,T3时间 定义:  事务A, 事务B Node1节 ...