applicationContext.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-2.5.xsd ">
<bean id="Oracle" class="com.zyl.dao.UserOraDAO" />
<bean id="Sql" class="com.zyl.dao.UserSqlDAO" />
<bean id="User" class="com.zyl.manager.UserMessageImpl">
<!-- <constructor-arg ref="Oracle"/>-->
<property name="userDao" ref="Oracle" />
</bean>
</beans>
----------------------------------------------
package com.zyl.Test;
import org.springframework.beans.factory.BeanFactory;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.zyl.dao.UserSqlDAO;
import com.zyl.dao.UserOraDAO;
import com.zyl.manager.UserMessage;
import com.zyl.manager.UserMessageImpl;
public class TestMain {
public static void main(String[] args) {
/*UserMessage user = new UserMessageImpl(new UserSqlDAO());
user.save("zyl", "123");*/
BeanFactory factory= new ClassPathXmlApplicationContext("applicationContext.xml");
UserMessage user =(UserMessage)factory.getBean("User");
user.save("zyl","123");
}
}
----------------------------------
package com.zyl.manager;
public interface UserMessage {
public void save(String username, String password);
}
-----------------
package com.zyl.manager;
import com.zyl.dao.UserDAO;
import com.zyl.dao.UserSqlDAO;
public class UserMessageImpl implements UserMessage {
private UserDAO userDao;
/* public UserMessageImpl(UserDAO userDao) {
this.userDao=userDao;
}*/
public void save(String username, String password) {
this.userDao.show(username,password);
}
public void setUserDao(UserDAO userDao){
this.userDao=userDao;
}
}
---------------------------------------
package com.zyl.dao;
public interface UserDAO {
public void show(String username, String password);
}
----------------
package com.zyl.dao;
public class UserOraDAO implements UserDAO {
public void show(String username, String password) {
System.out.println("Oracle"+username+password);
}
}
----------------
package com.zyl.dao;
public class UserSqlDAO implements UserDAO {
public void show(String username, String password) {
System.out.println("Sql"+username+password);
}
}
------------------------------------
Spring 依赖注入 构造方法注入
最新推荐文章于 2025-07-06 16:46:20 发布
本文通过一个具体的示例展示了如何使用Spring框架进行依赖注入。包括配置文件定义bean及依赖关系,实现不同数据库操作接口并在主类中调用这些bean完成数据保存操作。
2万+

被折叠的 条评论
为什么被折叠?



