Eclipse中 搭建 Spring+SpringMVC+Mybatis整合(下)
通过前面的步骤可以搭建好 Maven 以及下载依赖框架,那么接下来就是编写框架的配置文件了,配置分为以下三个步骤:
- 配置 SpringMVC
- 配置 Mybatis
- 配置 log
以下配置 SpringMVC:
- 确定包结构,以及每个包的作用
- 配置 web.xml 启用 SpringMVC
Xml代码
- <!DOCTYPE web-app PUBLIC
- "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
- "http://java.sun.com/dtd/web-app_2_3.dtd" >
- <web-app>
- <display-name>SSM</display-name>
- <!-- Spring MVC -->
- <context-param>
- <!-- 指定配置文件位置(非默认) -->
- <param-name>contextConfigLocation</param-name>
- <param-value>classpath:spring/spring-mvc.xml</param-value>
- </context-param>
- <servlet>
- <servlet-name>springMvc</servlet-name>
- <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
- <!-- 通知 Web 容器, 启动时初始化 Spring MVC -->
- <load-on-startup>1</load-on-startup>
- </servlet>
- <servlet-mapping>
- <servlet-name>springMvc</servlet-name>
- <!-- 指定拦截以 .do 结尾的配置, 如果配置为 "/" 则需要在配置文件中排除静态资源, 如: .css, .jsp, .png等等 -->
- <url-pattern>*.do</url-pattern>
- </servlet-mapping>
- </web-app>
- 配置 spring-mvc.xml
Xml代码
- <?xml version="1.0" encoding="UTF-8"?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context"
- xmlns:aop="http://www.springframework.org/schema/aop"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
- http://www.springframework.org/schema/context
- http://www.springframework.org/schema/context/spring-context-3.0.xsd
- http://www.springframework.org/schema/mvc
- http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd
- http://www.springframework.org/schema/aop
- http://www.springframework.org/schema/aop/spring-aop-3.0.xsd">
- <!-- 配置资源文件 -->
- <!-- * 指定 classPath 相对路径 * -->
- <context:property-placeholder location="classpath:jdbc.properties" />
- <!--
- * 指定文件(绝对)路径 *
- <context:property-placeholder location="file:D:/home/appadmin/config/jdbc.properties" />
- -->
- <!-- 加载组件配置 -->
- <import resource="classpath:spring-dao.xml" />
- <!-- 启用spring mvc 注解, conversion-service 用于注册 Handler 的参数类型转换器 -->
- <mvc:annotation-driven conversion-service="conversionService" />
- <!-- 注册参数转换器 -->
- <bean id="conversionService"
- class="org.springframework.format.support.FormattingConversionServiceFactoryBean">
- <property name="converters">
- <set>
- <!-- 枚举转换器: 支持 ordinal 和 name(区分大小写) -->
- <bean class="org.hy.ssm.web.converter.StringToEnumConverterFactory" />
- <!-- 日期转换器: 支持的模式列表查看源码, 可支持毫秒值(字符串) -->
- <bean class="org.hy.ssm.web.converter.StringToDate" />
- </set>
- </property>
- </bean>
- <!-- 启用spring mvc 注解扫描 -->
- <context:annotation-config />
- <!-- 自动扫描注解 -->
- <context:component-scan base-package="org.hy.ssm" />
- <!-- 完成请求和注解POJO的映射 -->
- <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" />
- <!--
- * 将 webapp(WEB-INF同级) 静态资源映射新路径,
- * 当前示例 /wabapp/statics/
- * statics/ 为静态资源文件夹, 如: csss/templates/images/js/等等
- -->
- <mvc:resources location="/statics/" mapping="/resource/**" cache-period="31536000" />
- <!--
- * 视图解析器, (必须)
- * 前缀 /WEB-INF/
- * 后缀 .jsp
- * 示例: handler 返回字符串(视图映射路径)为 user/list, 则映射路径为: /WEB-INF/user/list.jsp
- -->
- <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" p:prefix="/WEB-INF/" p:suffix=".jsp" />
- <!--
- * 配置 JSON 转换器(必须)
- * handler 返回 Model 数据时需要用到
- * 与 @ResponseBody 联合使用
- -->
- <bean id="mappingJacksonHttpMessageConverter" class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">
- <property name="supportedMediaTypes">
- <list>
- <value>text/html;charset=UTF-8</value>
- </list>
- </property>
- </bean>
- <!-- 注册 JSON 转换器 -->
- <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
- <property name="messageConverters">
- <list>
- <ref bean="mappingJacksonHttpMessageConverter" /><!-- json转换器 -->
- </list>
- </property>
- </bean>
- <!-- 文件上传 -->
- <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
- <property name="defaultEncoding">
- <value>UTF-8</value>
- </property>
- <property name="maxUploadSize">
- <value>32505856</value><!-- 上传文件大小限制为31M -->
- </property>
- <property name="maxInMemorySize">
- <value>4096</value>
- </property>
- </bean>
- <!--
- * 注册验证拦截器(非 javax.servlet.Filter),
- * 拦截器实现需要继承: org.springframework.web.filter.OncePerRequestFilter
- -->
- <bean id="loginFileter" class="org.hy.ssm.web.filter.LoginFilter"></bean>
- <!--
- * Spring 邮件配置
- * 注意:这里的参数(如用户名、密码)都是针对邮件发送者的
- -->
- <bean id="mailSender" class="org.springframework.mail.javamail.JavaMailSenderImpl">
- <property name="host" value="${email.stmp.server}" />
- <property name="defaultEncoding" value="utf-8" />
- <property name="username" value="${email.username}" />
- <property name="password" value="${email.password}" />
- <property name="port" value="${email.stmp.port}" />
- <property name="javaMailProperties">
- <props>
- <prop key="mail.smtp.auth">true</prop>
- <prop key="mail.smtp.timeout">25000</prop>
- </props>
- </property>
- </bean>
- </beans>
- spring-dao.xml 配置 (包含Mybatis)
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:tx="http://www.springframework.org/schema/tx"
- xmlns:aop="http://www.springframework.org/schema/aop"
- xsi:schemaLocation="
- http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
- http://www.springframework.org/schema/tx
- http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
- http://www.springframework.org/schema/aop
- http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
- ">
- <!-- 配置 alibaba 数据源 -->
- <bean name="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
- <property name="url" value="${jdbc_url}" />
- <property name="username" value="${jdbc_username}" />
- <property name="password" value="${jdbc_password}" />
- <property name="initialSize" value="0" />
- <property name="maxActive" value="20" />
- <property name="minIdle" value="0" />
- <property name="maxWait" value="60000" />
- <property name="validationQuery" value="${validationQuery}" />
- <property name="testOnBorrow" value="false" />
- <property name="testOnReturn" value="false" />
- <property name="testWhileIdle" value="true" />
- <property name="timeBetweenEvictionRunsMillis" value="60000" />
- <property name="minEvictableIdleTimeMillis" value="25200000" />
- <property name="removeAbandoned" value="true" />
- <property name="removeAbandonedTimeout" value="1800" />
- <property name="logAbandoned" value="true" />
- <property name="filters" value="mergeStat" />
- </bean>
- <!-- MyBits 的 SessionFactory -->
- <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
- <!-- 数据源 -->
- <property name="dataSource" ref="dataSource" />
- <!-- 数据访问接口对应的 SQL 实现 -->
- <property name="mapperLocations" value="classpath:mapping/*.xml" />
- <!-- Mybatis 其他配置 -->
- <property name="configLocation" value="classpath:mybatis/mybatis-config.xml" />
- </bean>
- <!-- Mybatis 托管给 Spring 的接口与扫描配置 -->
- <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
- <!--
- * 当前数据源所管理的数据访问接口包
- * 如果项目中配置了多个数据源时,
- * 应避免相同数据访问接口包
- -->
- <property name="basePackage" value="com.cnp.catalog.dao" />
- <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
- </bean>
- <!-- 开启spring的事物管理功能 -->
- <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
- <property name="dataSource" ref="dataSource" />
- </bean>
- <!-- 使用注解管理事物 -->
- <tx:annotation-driven transaction-manager="transactionManager" />
- </beans>
(如何配置多个数据源:1、jdbc.properties 中新增一套jdbc配置[url/username/pwd];3、配置唯一的dataSource、transactionManager;3、修改 MapperScannerConfigurer.basePackage 的值为新的数据访问接口包,一个数据访问接口包只能绑定一个数据源;4、修改 SqlSessionFactoryBean.mapperLocations 的值为新的数据访问接口 SQL 实现配置,推荐为每个数据源指定不同的实现包)
配置 Mybatis
- mybatis-config.xml
Xml代码
- <?xml version="1.0" encoding="UTF-8" ?>
- <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-config.dtd">
- <configuration>
- <!-- 别名 -->
- <typeAliases>
- <!--
- * 在ParameterType或ResultType中直接使用类名,
- * 首字母大小写均可
- -->
- <package name="org.hy.ssm.model.entities"/>
- <!-- 或指定类型, 指定别名 -->
- <typeAlias type="org.hy.ssm.model.entities.User" alias="user"/>
- </typeAliases>
- <!-- 枚举类型处理器 -->
- <typeHandlers>
- <!--
- * handler: 枚举类型转换器, 当前使用 Ordinal, 如: Gender.MALE.ordinal(), 所以数据库应该是短整型
- * javaType: 目标枚举类型(Copy Qualified Name)
- -->
- <typeHandler
- handler="org.apache.ibatis.type.EnumOrdinalTypeHandler"
- javaType="org.hy.ssm.model.entities.User$Gender"
- />
- <!-- 多个枚举时配置多套 typeHandler 标签即可 -->
- <!--
- <typeHandler
- handler="org.apache.ibatis.type.EnumOrdinalTypeHandler"
- javaType="org.hy.ssm.model.entities.User$JobTitle"
- />
- -->
- </typeHandlers>
- </configuration>
- mapper 示例(UserMapper.xml)
Xml代码
- <?xml version="1.0" encoding="UTF-8" ?>
- <!DOCTYPE mapper PUBLIC
- "-//mybatis.org//DTD Mapper 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-mapper.dtd"
- >
- <!-- namespace 通常使用 DAO 接口的权限命名 -->
- <mapper namespace="org.hy.ssm.dao.UserDao">
- <!--
- * 这里能使用 resultType="user" 是因为配置了 package name="org.hy.ssm.model.entities"
- *
- * 小技巧:
- * 1. 如果查询的数据非常确认只有一条时, 可在SQL的尾部明确的指出: LIMIT 1
- * 2. 有 WHERE 的情况下, 先判断条件是否成立而后再使用, 可以提高 SQL 接口复用率
- * 以上仅个人观点
- -->
- <!-- 指定用户账户查询用户 -->
- <select id="selectUserByAccount" parameterType="string" resultType="user">
- SELECT
- *
- FROM
- ssm_user u
- <if test="account != null and account != ''">
- <where>
- u.account = #{account}
- </where>
- </if>
- LIMIT
- 1
- </select>
- </mapper>
到目前为止必要的配置已经完成 80%,还剩下最后一项日志,本例使用的日志框架为:log4j, slf4j,配置文件(log4.properties):
- log4j.rootLogger=DEBUG, stdout, R
- log4j.appender.stdout=org.apache.log4j.ConsoleAppender
- log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
- log4j.appender.stdout.layout.ConversionPattern=[catalog] [%5p] [%d{yyyy-MM-dd HH:mm:ss}] (%F:%L) %m%n
- log4j.appender.R=org.apache.log4j.RollingFileAppender
- log4j.appender.R.File=/home/appadmin/logs/catalog.log
- log4j.appender.R.MaxFileSize=5012KB
- log4j.appender.R.MaxBackupIndex=50
- log4j.appender.R.layout=org.apache.log4j.PatternLayout
- log4j.appender.R.layout.ConversionPattern=[catalog][%5p] [%d{yyyy-MM-dd HH:mm:ss}] (%F:%L) %m%n
- log4j.logger.org.apache=DEBUG
- log4j.logger.com.opensymphony=DEBUG
- log4j.logger.org.springframework=DEBUG
- log4j.logger.org.mybatis=DEBUG
- log4j.logger.org.apache.commons.httpclient=ERROR
当前说明只能让你快速搭建项目,如果想要了解更深层次的原理及其应用则需要更多的其他相关资料。
ssm.zip (25.3 KB)
转载于:https://www.cnblogs.com/xm1-ybtk/p/5112058.html
Eclipse中 搭建 Spring+SpringMVC+Mybatis整合(下)相关推荐
- Spring boot(6)---在Eclipse中搭建Spring boot 项目
Spring boot入门:在Eclipse中搭建Spring boot 项目 Eclipse中的STS插件 打开Eclipse-Help-Eclipse Marketplace-popular 下载 ...
- Spring+SpringMVC+MyBatis整合基础篇
基础篇 Spring+SpringMVC+MyBatis+easyUI整合基础篇(一)项目简介 Spring+SpringMVC+MyBatis+easyUI整合基础篇(二)牛刀小试 Spring+S ...
- Spring+SpringMVC +MyBatis整合配置文件案例66666
Spring+SpringMVC +MyBatis整合配置文件案例 标签: springspringmvcmybatismvcjava 2017-04-13 19:12 228人阅读 评论(1) 收藏 ...
- SSM整合——Spring+SpringMVC+MyBatis整合
文章目录 1. 数据库环境 2. 项目基本结构搭建 3. 配置MyBatis 4. 配置Spring 5. 配置SpringMVC 6. Controller和视图层编写 7. 配置Tomcat,进行 ...
- Spring+SpringMVC+Mybatis整合
一.简单测试工程搭建 1.Mybatis所需要的的jar包(包含数据库驱动包和相关的日志包).SpringMVC和Spring的jar包 2.然后构建一个基本的工程,这里我们使用mapper代理的方式 ...
- Spring+SpringMVC+MyBatis整合教程
2019独角兽企业重金招聘Python工程师标准>>> 1.基本概念 1.1.Spring Spring是一个开源框架,Spring是于2003 年兴起的一个轻量级的Java 开发框 ...
- Spring+SpringMVC+Mybatis整合【L】
我喜欢直接上代码,这里做个解说,代码下载 http://download.csdn.net/detail/q260996583/9905047 项目框架图: 1.pom.xml 文件内容 <pr ...
- springmvc教程--整合mybatis开发(spring+springMVC+mybatis整合开发)
一.整合mybatis 为了更好的学习 springmvc和mybatis整合开发的方法,需要将springmvc和mybatis进行整合. 整合目标:控制层采用springmvc.持久层使用myba ...
- Eclipse中实现SpringBoot与Mybatis整合(图文教程带源码)
场景 数据库中数据 实现效果 项目结构 前面参照 Eclipse中新建SpringBoot项目并输出HelloWorld https://blog.csdn.net/BADAO_LIUMANG_QIZ ...
最新文章
- 一篇关于java变量定义的文章
- Python自定义:粒子群优化算法
- cobalt strick 4.0系列教程(3)---数据管理
- 官宣!又一所新大学来了!
- Bean context must contain FilterChainProxy
- poster--2011 Pacific-RimConference on Multimedia
- python字符串函数使用_Python字符串函数用法
- ROS学习笔记(一)#ROS系统及RoboWare的安装
- 扫描全能王文件上传不了服务器,如何将扫描全能王的文档轻松保存到坚果云?...
- Python 使用Gmail发送邮件
- python安装失败0x80070005_win10系统运行提示0x80070005错误的解决办法
- 栈和队列的区别与栈和堆的区别
- 二维码登录原理+Web端即时通讯技术
- 如何将m4a音频转换mp3格式,5种简单方法帮你处理
- 各种SD卡参数及接口
- 西北大学21年计算机考研情况 信科院专硕初试考数一英一分数线265分
- 语音识别技术是什么 语音识别基本方法介绍【图文】
- 如何在WorkNC中载入机床?
- π-Day快乐:Python可视化π
- cocoscreator 浏览器调试技巧