学习任何一门语言或熟悉一个框架,首先要运用其写一个简单的例子,然后慢慢深入理解各个要点以达到熟悉和精通的程度。Hello,World在程序史上的特殊地位使其成为几乎所有计算机从业人员开始学习编程语言和技术框架编写的第一个示例。这里我们也选择它作为我们学习的开始。
首先是搭建开发环境,我们选择MyEclipse作为工具,建立一个新的Java工程,为了学习的思路更加清晰,我没有选择导入MyEclipse自带的Spring框架,而是采取手工导入Spring框架的相关包,主要有三个,spring.jar,log4j-1.2.15.jar,commons-logging.jar。为了方便测试我们将Junit4相关包也导入进来。
Spring采用Apache common_logging,并结合Apache log4j作为日志输出组件。为了在调试过程中能观察到Spring的日志输出,在CLASSPATH中新建log4j.properties配置文件,
内容如下:
log4j.rootLogger=DEBUG, stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%c{1} - %m%n
还有spring的配置文件,为了确保配置bean.xml位于工作路径之下,注意工作路径并不等同于CLASSPATH ,MyEclipse的默认工作路径为项目根路径,也就是.project文件所在的目录,而默认输出目录/bin是项目CLASSPATH的一部分,并非工作路径。
配置完成后,项目的结构目录如下:
下面开始编写程序Hello.java
package cn.com.sping.bean;
public class Hello {
private String msg = null;
public void setMsg(String msg){
this.msg = msg;
}
public String getMsg(){
return this.msg;
}
}
然后在bean.xml配置文件,对bean进行配置
<?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">
<description>Spring Quick Start!!</description>
<bean id="hello_bean" class="cn.com.sping.bean.Hello">
<property name="msg">
<value>Hello,World</value>
</property>
</bean>
</beans>
接下来就是测试程序的编写了,编写测试类TestUtils.java
package cn.com.sping.test;
import junit.framework.TestCase;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;
import cn.com.sping.bean.Hello;
public class TestUtils extends TestCase {
private ApplicationContext actx = new FileSystemXmlApplicationContext("bean.xml");
@Test
public void test1(){
Hello hello = (Hello)actx.getBean("hello_bean");
System.out.println(hello.getMsg());
}
}
运行测试程序,JUnit显示通过,控制台打印出相应的日志信息和Hello,World。
现在我们修改bean.xml配置文件将属性值修改成如下:
<value>Hello,World This is my first Spring demo</value>
再次运行测试程序,和上次不同的是这次打印出来的是:Hello,World This is my fist Spring demo
通过测试,可以发现控制打印的Msg信息就是配置文件中所配置的信息,这就是Spring的依赖注入功能(DI)也成为控制反转(IoC)这里称之为依赖注入似乎更容易结合例子进行理解。这个是对bean属性的注入。下面我们来对以上示例程序做一下修改:
1.我们编写一个DoSth.java的接口,如下:
package cn.com.sping.bean;
public interface DoSth {
public void doSomeThing();
}
2.改写Hello.java重命名为LowerHello.java 使其实现DoSth.java接口,如下:
package cn.com.sping.bean;
public class LowerHello implements DoSth{
private String msg = null;
public void setMsg(String msg) {
this.msg = msg;
}
public String getMsg() {
return this.msg;
}
@Override
public void doSomeThing() {
System.out.println(this.getMsg().toLowerCase());
}
}
3.编写UpperHello.java,使其同样实现DoSth.java接口,如下
package cn.com.sping.bean;
public class UpperHello implements DoSth {
private String msg = null;
public void setMsg(String msg) {
this.msg = msg;
}
public String getMsg() {
return this.msg;
}
@Override
public void doSomeThing() {
System.out.println(this.getMsg().toUpperCase());
}
}
4.修改配置文件bean.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">
<description>Spring Quick Start!!</description>
<bean id="hello_bean" class="cn.com.sping.bean.LowerHello">
<property name="msg">
<value>Hello,World This is my first Spring demo</value>
</property>
</bean>
</beans>
5.修改测试程序
package cn.com.sping.test;
import junit.framework.TestCase;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;
import cn.com.sping.bean.DoSth;
public class TestUtils extends TestCase {
private ApplicationContext actx = new FileSystemXmlApplicationContext("bean.xml");
@Test
public void test1(){
DoSth doSth = (DoSth)actx.getBean("hello_bean");
doSth.doSomeThing();
}
}
6.运行测试程序,控制台输出:hello,world this is my first spring demo
7.修改配置文件bean.xml,将bean的class属性值改成如下:
<bean id="hello_bean" class="cn.com.sping.bean.UpperHello">
<property name="msg">
<value>Hello,World This is my first Spring demo</value>
</property>
</bean>
8.运行测试程序,控制台输出:HELLO,WORLD THIS IS MY FIST SPRING DEMO
以上对之前示例程序的改造,我们使用Spring框架对其配置文件稍作一点改动就可以达到非常奇特的效果,甚至这个修改就像是一个开关一样,可以将我们的程序模块随意切换到任意部分,只需要付出很小的代价就能达到近乎重构的目的。
另外通过使用Spring你是不是也体会到了面向接口编程的好处呢
通过以上的简单的示例程序那么你对Spring的核心特性DI或是IoC的理解是不是就由空洞抽象的概念编程了直观而具体的认识呢。