spring通过导入jar包和配置xml文件启动

本文介绍了如何启动Spring框架。首先从官方仓库下载dist.zip包,包含jar和文档。接着在IDEA中通过Project Structure导入beans、context、core、expression、jcl五个jar包。特别指出,导入jcl是为了避免NoClassDefFoundError异常。完成导入后,创建XML配置文件并编写代码。示例展示了配置文件内容,强调业务逻辑类需通过getter和setter与DAO对象交互以确保配置正确。

第一步,进到 spring仓库下载一个spring包,大家前往官网下载的时候,记得下载dist.zip后缀的包,里面包括了jar包和对应的英文文档。

下面是自己已经下载的一个,提供百度云链接:
百度云,提取码:fb3s

第二步,打开idea -> File -> Project Structrure -> Libraries,点击上面的 "+"号,找到存放spring源码的目录,进入libs目录,然后将 beans、context、core、expression、jcl这5个jar包导入,如下截图:
在这里插入图片描述
导入 jcl 这个包是引入 org/apache/commons/logging,不然编译的时候会出现如下报错:

Exception in thread “main” java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory

第三步,导入成功之后,就可以开始使用spring框架了。
下面做一个例子:

先给大家看一下目录结构:
在这里插入图片描述
spring.xml这个文件是通过 File -> New -> XML Configuration File -> Spring Config 创建出来的。
上面的代码分别如下:

//这是目录结构中的IUserDao接口类
package dao;

/**
 * @program: Spring_01
 * @description
 * @author: 
 * @create: 2020-08-05 16:16
 **/
public interface IUserDao {
    void getUser();
}

//这是目录结构中的IUserDao接口类的实现
package dao.impl;

import dao.IUserDao;

/**
 * @program: Spring_01
 * @description
 * @author:
 * @create: 2020-08-05 16:36
 **/
public class UserDaoOracleImpl implements IUserDao {

    @Override
    public void getUser() {
        System.out.println("查询的是Oracle数据库");
    }
}

//这是目录结构中的IUserService接口类
package service;

/**
 * @program: Spring_01
 * @description
 * @author: 
 * @create: 2020-08-05 08:51
 **/
public interface IUserService {

    void getUser();
}

//这是目录结构中的IUserService接口类的实现
package service.impl;

import dao.IUserDao;
import service.IUserService;

/**
 * @program: Spring_01
 * @description
 * @author: 
 * @create: 2020-08-05 08:52
 **/
public class UserServiceImpl implements IUserService {

    IUserDao dao_oracle;

    public IUserDao getDao_oracle() {
        return dao_oracle;
    }

    public void setDao_oracle(IUserDao dao_oracle) {
        this.dao_oracle = dao_oracle;
    }

    @Override
    public void getUser() {
        getDao_oracle().getUser();
    }
}

//这是目录结构中的MyTest测试类的实现
package test;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import service.IUserService;
import service.impl.UserServiceImpl;

/**
 * @program: Spring_01
 * @description
 * @author: 
 * @create: 2020-08-05 16:20
 **/
public class MyTest {
    public static void main(String[] args) {
    
        ApplicationContext ioc = new ClassPathXmlApplicationContext("spring.xml");
        
        IUserService service = ioc.getBean(IUserService.class);
        
        service.getUser();
    }
}

下面是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"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

    <bean class="dao.impl.UserDaoOracleImpl" id="userDaoOracle"/>
    <bean class="service.impl.UserServiceImpl" id="userService">
        <property name="dao_oracle" ref="userDaoOracle"/>
    </bean>

</beans>

这里我想提醒大家注意的是,service业务逻辑类必须通过getter 和 setter方式获取dao对象和设置dao对象,不然配置spring.xml的时候, name标签不能实现自动提示,也就是说不能编译通过

编译运行之后会出现如下结果:
查询的是Oracle数据库

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值