spring导入jar包和配置xml文件启动 spring通过导入jar包和配置xml文件启动的步骤详解

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

spring导入jar包和配置xml文件启动 spring通过导入jar包和配置xml文件启动的步骤详解

平头哥糊口养家   2021-02-02 我要评论
想了解spring通过导入jar包和配置xml文件启动的步骤详解的相关内容吗,平头哥糊口养家在本文为您仔细讲解spring导入jar包和配置xml文件启动的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:spring导入jar包,spring配置xml文件启动,下面大家一起来学习吧。

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

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

第二步,打开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数据库

总结

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们