spring的开发
spring与web的整合
1. 整合的原理:
Spring容器随着tomcat容器ServletContext的启动而启动,并且在初始化完成后放到整个应用都可以访问的范围。
ApplicationContext随着服务器的启动而启动,可以借助与Servlet/Filter/Listener任何一个;
把创建好的ApplicationContext放到ServletContext中,整个应用范围,想怎访问就怎么访问;
spring-web-4.2.4.RELEASE.jar包中提供了Listener的支持(spring建议的方式)
WebApplicationContextUtils是Spring官方提供的一个web环境下便捷从ServletContext中获取ApplicationContext的工具类。
2. 整合的步骤
● 添加依赖
<!-- https://mvnrepository.com/artifact/org.springframework/spring-web -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>4.2.4.RELEASE</version>
</dependency>
<!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
<scope>provided</scope>
</dependency>
● 配置监听器,监听web项目的启动
<!-- needed for ContextLoaderListener -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param> <!-- Bootstraps the root web application context before servlet initialization -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
● 创建servlet,在servlet中获取spring容器
public class ContextServlet extends HttpServlet {
private static final long serialVersionUID = 1L; protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// 1. 获取spring容器
// 获取servletContext域对象
ServletContext servletContext = getServletContext();
// web环境的spring容器
WebApplicationContext applicationContext = WebApplicationContextUtils.getWebApplicationContext(servletContext);
// 2. 从容器中获取javabean对象
Person person = (Person) applicationContext.getBean("person4");
System.out.println(person.getUsername());
response.getWriter().append("Served at: ").append(request.getContextPath());
} protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}
● 访问servlet进行测试
浏览器访问:http://localhost:8080/ContextServlet
spring容器基于注解方式的开发
● 优缺点:
缺点:
1、如果所有的内容都配置在.xml文件中,那么.xml文件将会十分庞大;如果按需求分开.xml文件,那么.xml文件又会非常多。总之这将导致配置文件的可读性与可维护性变得很低。
2、在开发中在.java文件和.xml文件之间不断切换,是一件麻烦的事,同时这种思维上的不连贯也会降低开发的效率。
优点:
Spring基于注解方式的开发,通过"@XXX"的方式,让注解与Java Bean紧密结合,既大大减少了配置文件的体积,又增加了Java Bean的可读性与内聚性。
● 开发步骤:
导入依赖
<!-- https://mvnrepository.com/artifact/org.springframework/spring-aop -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aop</artifactId>
<version>4.2.4.RELEASE</version>
</dependency>
添加context命名空间的schema
开启注解扫描context:component-scan
<!-- 开启spring的注解扫描 -->
<!-- 扫描包下带注释的类及类中带注释的属性 -->
<context:component-scan base-package="spring.annotation.demo"></context:component-scan>
添加注解
Spring中和注入相关的常见注解有Autowired、Resource、Qualifier、Service、Controller、Repository、Component。
- Autowired是自动按照类型注入,自动从spring的上下文找到合适的bean来注入
- Resource用来指定名称注入
- Qualifier和Autowired配合使用,指定bean的名称
- Service,Controller,Repository分别标记类是Service层类,Controller层类,数据存储层的类,spring扫描注解配置时,会标记这些类要生成bean。
- Component是一种泛指,标记类是组件,spring扫描注解配置时,会标记这些类要生成bean。
上面的Autowired和Resource是用来修饰字段,并做属性注入的。而Service,Controller,Repository,Component则是用来修饰类,标记这些类要生成bean。
@Repository
public class CarDao {
public void insertCar(){
System.out.println("CarDao中的insertCar的方法被调用... ...");
}
}
@Service
//@Component
@Scope(value="singleton")
public class CarService {
// 自动按照类型注入,自动从spring上下文中找到合适的bean来注入
@Autowired
private CarDao carDao; public void insertCar(){
carDao.insertCar();
System.out.println("CarService中的insertCar方法");
} @PostConstruct
public void init(){
System.out.println("init方法被调用... ...");
} @PreDestroy
public void destory(){
System.out.println("destory方法被调用... ...");
}
}
编写测试代码
public static void main(String[] args) {
ClassPathXmlApplicationContext applicationContext = new ClassPathXmlApplicationContext("applicationContext-annotation.xml");
CarService bean = (CarService) applicationContext.getBean("carService");
bean.insertCar();
}
@Autowired + @Qualifier 结合使用:指定注入bean的名称
@Resouce注解:@Resource注解实现的效果和@Autowired+@Qualifier的效果是一样的
@Scope用于指定scope作用域的(用在类上)
@PostConstruct用于指定初始化方法(用在方法上)
@PreDestory用于指定销毁方法(用在方法上)
@Value 可以为我们的基本数据类型以及string进行属性赋值
xml配置方式与注解方式的对比
spring与Junit整合测试
整合后测试的优点
整合后测试变得非常简单
避免频繁、重复的容器加载
整合Junit的步骤
导入spring-test的jar包
<dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>4.12</version> <scope>test</scope> </dependency>
编写Junit整合测试类
@RunWith(SpringJUnit4ClassRunner.class)//使用Junit4进行测试
@ContextConfiguration("classpath:applicationContext-annotation.xml")//加载配置文件
public class JunitSpringTest {
@Autowired
private CarService carService; @Autowired
private CarDao carDao; @Test
public void test01(){
carDao.insertCar();
}
}
最新文章
- unity文件解析以及版本控制
- BitTorrent Sync - 神奇的文件同步软件,无需服务器让多台电脑互相同步!
- 在bootstrap ace样式框架上修改的后台管理型模板(Tab页后台管理模板)
- C#使用FtpWebRequest上传文件
- Android View绘制13问13答
- c# webbrowser获取滚动条最大值
- [Python笔记]第五篇:递归
- Mybaits入门之起航
- myeclipse如何恢复已删除的文件和代码
- 如何重置密码 oracle sys和system
- ASM检查RAC是否成功
- 【javaScript基础】异常处理
- angular4中引入quill editor
- django用户权限操作
- sqlite "insert or replace" 和 "insert or ignore" 用法
- header头参数不能带下划线
- classpath分析
- ubuntu apache linux
- 【PAT】1032 Sharing (25)(25 分)
- C++对运算符进行重载学习笔记