项目源码:https://github.com/weimingge14/Shiro-project
演示地址:http://liweiblog.duapp.com/Shiro-project/login
本节从零开始,一步一步介绍如何搭建一个使用 Spring MVC 、Spring 、MyBatis 、Shiro 集成的一个 Web 项目。该项目主要演示了 Shiro 在 Web 应用中是如何使用的,同时也复习了我们使用 Spring MVC + Spring + MyBatis 如何快速搭建一个 Web 应用。
因为篇幅的原因,在这里就不过多地粘贴源代码。大家可以到我这个项目的 GitHub 仓库地址下载源代码,以及通过浏览 Shiro-project 这个项目的 commits 来观察环境是如何一步一步搭建起来的,以及是如何一点一点增加新的功能。
项目使用 Maven 构建工具。JDK 版本使用 Java8,使用 Jetty 插件
第 1 节 我们先引入 Spring4 和 JUnit 的相关依赖,编写 Spring 的 HelloWorld 。
1、Spring 体系的相关依赖
(有些包其实我们这一节还用不上,先添加进来,但每个包,为什么添加这个包一定要明白。此处只列出 artifactId ,下同)
spring-core、spring-context、spring-beans、spring-jdbc、spring-tx、spring-test
其中 spring-jdbc 提供了数据访问的依赖,spring-tx 提供了事务的支持,spring-test 提供了在 Spring 环境中使用 JUnit 的支持;
2、JUnit 的依赖
junit
3、MyBatis 相关依赖
mybatis、mybatis-spring
4、MySQL 依赖
mysql-connector-java
5、数据库连接池
druid
6、日志框架
log4j、 slf4j-log4j12
引入了配置以后,还要注意:
1、Spring 系列依赖比较多,建议将 Spring 的版本声明通过引入变量的形式来定义,方便以后的修改和升级,例如
<properties>
<spring.version>4.2.6.RELEASEspring.version>
properties>
在引入 spring-core 依赖的时候就可以使用变量 spring.version
<dependency>
<groupId>org.springframeworkgroupId>
<artifactId>spring-coreartifactId>
<version>${spring.version}version>
dependency>
2、可以使用 Maven 的编译插件指定项目使用的 JDK 版本,这样 IDE 工具就不会使用默认的 1.5 的 JDK 了。
<plugin>
<groupId>org.apache.maven.pluginsgroupId>
<artifactId>maven-compiler-pluginartifactId>
<version>3.5.1version>
<configuration>
<source>1.8source>
<target>1.8target>
configuration>
plugin>
<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"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd">
<context:component-scan base-package="com.liwei.shiro.service"/>
beans>
配置文件的意思是:在 com.liwei.shiro.service 这个包下扫描 @Service 、@Repository 、@Component 、@Controller 、@Configuration 注解,添加了这些注解的类成为被 Spring 管理的 Bean。
对于这个配置,我们还可以指定只扫描指定的例如 @Service 这样的注解。
其中,xml 文件
节点中的片段应该到 Spring 的官方文章上去拷贝下来,或者使用 Spring 的开发工具 STS 来添加文档约束,不建议在网上随便找一篇文章粘贴进去。
@Service
public class HelloWorld {
public String hello(String str){
return str;
}
}
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {"classpath:spring/spring-service.xml"})
public class HelloWorldTest {
@Autowired
private HelloWorld helloWorld;
@Test
public void testHelloWorld(){
String str = helloWorld.hello("world");
/**
* 第 1 个参数:测试不通过的时候显示的消息
* 第 2 个参数:期望值
* 第 3 个参数:实际值
*/
Assert.assertEquals("测试不通过","world",str);
}
}
说明:1、@RunWith(SpringJUnit4ClassRunner.class)
表明我们使用的 JUnit4 是在 Spring 的容器下运行的。
2、@ContextConfiguration(locations = {"classpath:spring/spring-service.xml"})
表明了我们的 Spring IOC 容器是通过 locations 属性指定的 xml 文件启动的,locations 属性是一个数组,我们可以设置多个 xml 文件。
以后配置文件模块化以后,很可能是由多个 Spring 的配置文件来启动 Spring 容器的。
3、这里还要注意:指定 Spring 容器启动的配置文件的时候,要加上 classpath:
前缀。