mybatis学习笔记(六) -- maven+spring+mybatis从零开始搭建整合详细过程(下)
继续 mybatis学习笔记(五) -- maven+spring+mybatis从零开始搭建整合详细过程(上)
五、使用监听器启动Spring容器
1、修改pom.xml文件,添加Spring-web
2、修改web.xml,配置启动Spring容器
3、新建BookServer
4、新建BookServlet
5、修改ApplicationContext.xml
6、测试
继续!!!
五、使用监听器启动Spring容器
1、修改pom.xml,添加Spring-web包(注:上一篇中的pom.xml已经添加)
- <!--添加spring-web包 -->
- <dependency>
- <groupId>org.springframework</groupId>
- <artifactId>spring-web</artifactId>
- <version>4.1.4.RELEASE</version>
- </dependency>
2、修改web.xml文件(src/main/webapp/WEB-INF/web.xml),如果该目录下没有这个文件,则新建一个
- <?xml version="1.0" encoding="UTF-8"?>
- <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
- <welcome-file-list>
- <welcome-file>index.jsp</welcome-file>
- </welcome-file-list>
- <listener>
- <description>Spring容器启动监听器</description>
- <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
- </listener>
- <context-param>
- <param-name>contextConfigLocation</param-name>
- <param-value>classpath*:ApplicationContext.xml</param-value>
- </context-param>
- </web-app>
3、新建一个BookService
- package com.lmei.service;
- import java.util.List;
- import javax.annotation.Resource;
- import org.springframework.stereotype.Service;
- import com.lmei.dao.BookDaoI;
- import com.lmei.entity.Book;
- @Service
- public class BookService {
- @Resource
- BookDaoI bookDao;
- public List<Book> getAllBook() {
- return bookDao.getAllBook();
- }
- }
@Service切记勿漏写,如果没写,运行时会报错“org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [com.lmei.service.BookService] is defined”
4、新建BookServlet
- package com.lmei.action;
- import java.io.IOException;
- import java.io.PrintWriter;
- import javax.servlet.ServletException;
- import javax.servlet.annotation.WebServlet;
- import javax.servlet.http.HttpServlet;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import org.springframework.web.context.WebApplicationContext;
- import org.springframework.web.context.support.WebApplicationContextUtils;
- import com.lmei.service.BookService;
- @WebServlet("/BookServlet.do")
- public class BookServlet extends HttpServlet {
- private static final long serialVersionUID = 1L;
- BookService bookService;
- @Override
- public void init() throws ServletException {
- //在当前上下文中获得Spring容器
- WebApplicationContext ctx = WebApplicationContextUtils.getWebApplicationContext(getServletContext());
- //从容器中获得bean
- bookService = ctx.getBean(BookService.class);
- }
- protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
- PrintWriter writer = response.getWriter();
- writer.print(bookService.getAllBook().size());
- }
- protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
- doGet(request, response);
- }
- }
serialVersionUID作用:序列化时为了保持版本的兼容性,即在版本升级时反序列化仍保持对象的唯一性。
两种生成方式:
一个是默认的1L,比如:private static final long serialVersionUID = 1L;
一个是根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段,比如:private static final long serialVersionUID = xxxxL;
5、修改ApplicationContext.xml,新增配置
- <!--自动扫描映射接口-->
- <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
- <!-- 指定sql会话工厂,在上面配置过的 -->
- <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
- <!-- 指定基础包,即自动扫描com.lmei.dao这个包下的所有接口类 -->
- <property name="basePackage" value="com.lmei.dao"></property>
- </bean>
- <!--自动扫描组件 -->
- <context:component-scan base-package="com.lmei">
- <context:exclude-filter type="aspectj" expression="com.lmei.dao.*"/>
- </context:component-scan>
- <aop:aspectj-autoproxy proxy-target-class="true"></aop:aspectj-autoproxy>
完整的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" xmlns:p="http://www.springframework.org/schema/p"
- xmlns:aop="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans.xsd
- http://www.springframework.org/schema/context
- http://www.springframework.org/schema/context/spring-context-4.3.xsd
- http://www.springframework.org/schema/aop
- http://www.springframework.org/schema/aop/spring-aop-4.3.xsd">
- <!-- 引入db.properties属性文件 -->
- <context:property-placeholder location="classpath:db.properties" />
- <!--定义一个jdbc数据源,创建一个驱动管理数据源的bean -->
- <bean id="jdbcDataSource"
- class="org.springframework.jdbc.datasource.DriverManagerDataSource">
- <property name="driverClassName" value="${jdbc.driver}" />
- <property name="url" value="${jdbc.url}" />
- <property name="username" value="${jdbc.username}" />
- <property name="password" value="${jdbc.password}" />
- </bean>
- <!--创建一个sql会话工厂bean,指定数据源 -->
- <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
- <!-- 指定数据源 -->
- <property name="dataSource" ref="jdbcDataSource" />
- <!--类型别名包,默认引入com.lmei.entity下的所有类 -->
- <property name="typeAliasesPackage" value="com.lmei.entity"></property>
- <!--指定sql映射xml文件的路径 -->
- <property name="mapperLocations"
- value="classpath:com/lmei/mapper/*Mapper.xml"></property>
- </bean>
- <!--自动扫描映射接口-->
- <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
- <!-- 指定sql会话工厂,在上面配置过的 -->
- <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
- <!-- 指定基础包,即自动扫描com.lmei.dao这个包下的所有接口类 -->
- <property name="basePackage" value="com.lmei.dao"></property>
- </bean>
- <!--自动扫描组件 -->
- <context:component-scan base-package="com.lmei">
- <context:exclude-filter type="aspectj" expression="com.lmei.dao.*"/>
- </context:component-scan>
- <aop:aspectj-autoproxy proxy-target-class="true"></aop:aspectj-autoproxy>
- </beans>
6、测试
项目右键->Run AS->Run On Server->Tomcat Server at localhost(运行前确认是否已配置Apache Tomcat)
运行成功后,在浏览器输入:http://localhost:8888/spring_mybatis_1/BookServlet.do
返回 4,表示有4条符合条件的结果。
本篇到此结束!!!
如有兴趣了解Springmvc+spring+mybatis可前往:
springmvc学习总结(二) -- maven+springmvc+spring+mybatis+mysql详细搭建整合过程讲解
mybatis学习笔记(六) -- maven+spring+mybatis从零开始搭建整合详细过程(下)的更多相关文章
- mybatis学习笔记(五) -- maven+spring+mybatis从零开始搭建整合详细过程(附demo和搭建过程遇到的问题解决方法)
文章介绍结构一览 一.使用maven创建web项目 1.新建maven项目 2.修改jre版本 3.修改Project Facts,生成WebContent文件夾 4.将WebContent下的两个文 ...
- Mybatis学习(六)————— Spring整合mybatis
一.Spring整合mybatis思路 非常简单,这里先回顾一下mybatis最基础的根基, mybatis,有两个配置文件 全局配置文件SqlMapConfig.xml(配置数据源,全局变量,加载映 ...
- MyBatis学习笔记-1 Idea配置MyBatis
一.创建工程 1.创建Java项目,勾选Java EE,Next,修改名称,Finish 2.在WEB-INF下创建两个文件夹classes和lib,分别用作输出文件目录和库文件目录 3.File-P ...
- 吴裕雄--天生自然JAVA SPRING框架开发学习笔记:SSH框架(Struts2+Spring+Hibernate)搭建整合详细步骤
在实际项目的开发中,为了充分利用各个框架的优点,通常都会把 Spring 与其他框架整合在一起使用. 整合就是将不同的框架放在一个项目中,共同使用它们的技术,发挥它们的优点,并形成互补.一般而言,在进 ...
- Mybatis 学习笔记1 不整合Spring的方式使用mybatis
两种方式都包含了: package com.test.mybatis; import java.util.List; import org.apache.ibatis.io.Resources; im ...
- Mybatis学习笔记(六) —— 动态sql
通过mybatis提供的各种标签方法实现动态拼接sql. 需求:根据性别和名字查询用户 查询sql: SELECT id, username, birthday, sex, address FROM ...
- MyBatis学习笔记(六)——调用存储过程
转自孤傲苍狼的博客:http://www.cnblogs.com/xdp-gacl/p/4270352.html 一.提出需求 查询得到男性或女性的数量, 如果传入的是0就女性否则是男性 二.准备数据 ...
- MyBatis学习笔记(八)——Mybatis3.x与Spring4.x整合
转自孤傲苍狼的博客:http://www.cnblogs.com/xdp-gacl/p/4271627.html 一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: mvn arc ...
- MyBatis学习总结(六)——Mybatis3.x与Spring4.x整合
一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: mvn archetype:create -DgroupId=me.gacl -DartifactId=spring4-myba ...
随机推荐
- 【DS】排序算法之归并排序(Merge Sort)
一.算法思想 归并排序是建立在归并操作上的一种有效的排序算法.该算法是采用分治法的一个非常典型的应用,指的是将两个已经排序的序列合并成一个序列的操作.其归并思想如下: 1)申请空间,使其大小为两个已经 ...
- SQL语句(六)成批导入导出数据
(六) 成批导入导出数据 假设已经存在teaching数据库, 存在一张Student表,如图: 右键teaching->任务->导入数据 下一步->数据源(Microsoft Ex ...
- 流媒体技术学习笔记之(四)解决问题video.js 播放m3u8格式的文件,根据官方的文档添加videojs-contrib-hls也不行的原因解决了
源码地址:https://github.com/Tinywan/PHP_Experience 总结: 说明: 测试环境:本测试全部来自阿里云直播和OSS存储点播以及本地服务器直播和点播 播放器:Vid ...
- 8 Productivity hacks for Data Scientists & Business Analysts
8 Productivity hacks for Data Scientists & Business Analysts Introduction I was catching up with ...
- [python]小技巧集锦
1.数组过滤,只适用于numpy alpha[alpha>0]:返回alpha中大于0的元素组成的数组 2.在范围内选取不等于某值的数值 j = i while j==i: j = int(ra ...
- MongoDB 之 Limit 选取 Skip 跳过 Sort 排序 MongoDB - 7
我们已经学过MongoDB的 find() 查询功能了,在关系型数据库中的选取(limit),排序(sort) MongoDB中同样有,而且使用起来更是简单 首先我们看下添加几条Document进来 ...
- Python人工智能之图片识别,Python3一行代码实现图片文字识别
1.Python人工智能之图片识别,Python3一行代码实现图片文字识别 2.tesseract-ocr安装包和中文语言包 注意:
- VELT-0.1.5开发:使用kgdb调试Linux内核【转】
转自:http://demo.netfoucs.com/lights_joy/article/details/44106589 VELT的全称是Visual EmbedLinuxTools,它是一个与 ...
- sublime text2快捷键
mac: command+option+f : 替换, find what: (.*) replace with:"$1": "1" 或者: data: ...
- Batch Normalization 与 Caffe中的 相关layer
在机器学习领域,通常假设训练数据与测试数据是同分布的,BatchNorm的作用就是深度神经网络训练过程中, 使得每层神经网络的输入保持同分布. 原因:随着深度神经网络层数的增加,训练越来越困难,收敛越 ...