zoukankan      html  css  js  c++  java
  • springmvc+mybatis集成配置

    简单之美,springmvc,mybatis就是一个很好的简单集成方案,能够满足一般的项目需求。闲暇时间把项目配置文件共享出来,供大家参看:

    1.首先我们来看下依赖的pom:

      1 <!-- spring -->
      2         <dependency>
      3             <groupId>org.springframework</groupId>
      4             <artifactId>spring-core</artifactId>
      5             <version>${spring.version}</version>
      6         </dependency>
      7 
      8         <dependency>
      9             <groupId>org.springframework</groupId>
     10             <artifactId>spring-beans</artifactId>
     11             <version>${spring.version}</version>
     12         </dependency>
     13 
     14         <dependency>
     15             <groupId>org.springframework</groupId>
     16             <artifactId>spring-context</artifactId>
     17             <version>${spring.version}</version>
     18         </dependency>
     19 
     20         <dependency>
     21             <groupId>org.springframework</groupId>
     22             <artifactId>spring-tx</artifactId>
     23             <version>${spring.version}</version>
     24         </dependency>
     25 
     26         <dependency>
     27             <groupId>org.springframework</groupId>
     28             <artifactId>spring-web</artifactId>
     29             <version>${spring.version}</version>
     30         </dependency>
     31 
     32         <dependency>
     33             <groupId>org.springframework</groupId>
     34             <artifactId>spring-webmvc</artifactId>
     35             <version>${spring.version}</version>
     36         </dependency>
     37 
     38         <dependency>
     39             <groupId>org.springframework</groupId>
     40             <artifactId>spring-jdbc</artifactId>
     41             <version>${spring.version}</version>
     42         </dependency>
     43 
     44         <dependency>
     45             <groupId>org.springframework</groupId>
     46             <artifactId>spring-test</artifactId>
     47             <version>${spring.version}</version>
     48             <scope>test</scope>
     49         </dependency>
     50 
     51         <!-- mybatis 包 -->
     52         <dependency>
     53             <groupId>org.mybatis</groupId>
     54             <artifactId>mybatis</artifactId>
     55             <version>3.2.8</version>
     56         </dependency>
     57 
     58         <!--mybatis spring 插件 -->
     59         <dependency>
     60             <groupId>org.mybatis</groupId>
     61             <artifactId>mybatis-spring</artifactId>
     62             <version>1.2.2</version>
     63         </dependency>
     64 
     65         <!-- mysql连接 -->
     66         <dependency>
     67             <groupId>mysql</groupId>
     68             <artifactId>mysql-connector-java</artifactId>
     69             <version>5.1.34</version>
     70         </dependency>
     71 
     72         <!-- 数据源 -->
     73         <dependency>
     74             <groupId>com.alibaba</groupId>
     75             <artifactId>druid</artifactId>
     76             <version>1.0.12</version>
     77         </dependency>
     78 
     79         <dependency>
     80             <groupId>org.aspectj</groupId>
     81             <artifactId>aspectjweaver</artifactId>
     82             <version>1.8.4</version>
     83         </dependency>
     84 
     85         <!-- log4j -->
     86         <dependency>
     87             <groupId>log4j</groupId>
     88             <artifactId>log4j</artifactId>
     89             <version>1.2.17</version>
     90         </dependency>
     91 
     92         <!-- servlet -->
     93         <dependency>
     94             <groupId>javax.servlet</groupId>
     95             <artifactId>servlet-api</artifactId>
     96             <version>3.0-alpha-1</version>
     97         </dependency>
     98 
     99         <dependency>
    100             <groupId>javax.servlet</groupId>
    101             <artifactId>jstl</artifactId>
    102             <version>1.2</version>
    103         </dependency>
    104 
    105         <!-- json -->
    106         <dependency>
    107             <groupId>org.codehaus.jackson</groupId>
    108             <artifactId>jackson-mapper-asl</artifactId>
    109             <version>1.9.13</version>
    110         </dependency>
    111 
    112         <dependency>
    113             <groupId>com.alibaba</groupId>
    114             <artifactId>fastjson</artifactId>
    115             <version>1.2.3</version>
    116         </dependency>
    117 
    118         <dependency>
    119             <groupId>com.fasterxml.jackson.core</groupId>
    120             <artifactId>jackson-annotations</artifactId>
    121             <version>${jackson.version}</version>
    122         </dependency>
    123 
    124         <dependency>
    125             <groupId>com.fasterxml.jackson.core</groupId>
    126             <artifactId>jackson-core</artifactId>
    127             <version>${jackson.version}</version>
    128         </dependency>
    129 
    130         <dependency>
    131             <groupId>com.fasterxml.jackson.core</groupId>
    132             <artifactId>jackson-databind</artifactId>
    133             <version>${jackson.version}</version>
    134         </dependency>
    135         <!-- 文件上传 -->
    136         <dependency>
    137             <groupId>commons-io</groupId>
    138             <artifactId>commons-io</artifactId>
    139             <version>2.4</version>
    140         </dependency>
    141 
    142         <dependency>
    143             <groupId>commons-fileupload</groupId>
    144             <artifactId>commons-fileupload</artifactId>
    145             <version>1.2.2</version>
    146         </dependency>
    View Code

    spring 选用的是4.1.4的版本,根据系统需要我们可以选择自己适合的版本。

    2.相关的配置文件:

        a)spring.xml

     1 <?xml version="1.0" encoding="UTF-8"?>
     2 <beans xmlns="http://www.springframework.org/schema/beans"
     3     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
     4     xsi:schemaLocation="http://www.springframework.org/schema/beans
     5             http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
     6             http://www.springframework.org/schema/context
     7             http://www.springframework.org/schema/context/spring-context-4.1.xsd">
     8 
     9     <!--引入配置属性文件 -->
    10     <context:property-placeholder location="classpath:config.properties" />
    11 
    12     <!--自动扫描含有@Service将其注入为bean -->
    13     <context:component-scan base-package="com.demo.report.web.service" />
    View Code

        b)spring-mvc.xml

     1 <?xml version="1.0" encoding="UTF-8"?>
     2 <beans xmlns="http://www.springframework.org/schema/beans"
     3     xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     4     xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context"
     5     xsi:schemaLocation="http://www.springframework.org/schema/beans 
     6         http://www.springframework.org/schema/beans/spring-beans-4.1.xsd 
     7         http://www.springframework.org/schema/context 
     8         http://www.springframework.org/schema/context/spring-context-4.1.xsd 
     9         http://www.springframework.org/schema/mvc 
    10         http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd">
    11 
    12     <!-- 自动扫描controller包下的所有类,如果@Controller注入为bean -->
    13     <context:component-scan base-package="com.demo.report.web.controller" />
    14 
    15     <!-- 避免IE执行AJAX时,返回JSON出现下载文件 -->
    16     <bean id="mappingJacksonHttpMessageConverter"
    17         class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
    18         <property name="supportedMediaTypes">
    19             <list>
    20                 <value>text/html;charset=UTF-8</value>
    21             </list>
    22         </property>
    23     </bean>
    24 
    25     <!-- 启动Spring MVC的注解功能,完成请求和注解POJO的映射 -->
    26     <bean
    27         class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
    28         <property name="messageConverters">
    29             <list>
    30                 <!-- json转换器 -->
    31                 <ref bean="mappingJacksonHttpMessageConverter" />
    32             </list>
    33         </property>
    34     </bean>
    35 
    36     <!-- 对模型视图名称的解析,即在模型视图名称添加前后缀 -->
    37     <bean
    38         class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    39         <property name="viewClass"
    40             value="org.springframework.web.servlet.view.JstlView" />
    41         <property name="prefix" value="" />
    42         <property name="suffix" value="" />
    43     </bean>
    44 
    45     <!-- 配置多文件上传 
    46     <bean id="multipartResolver"
    47         class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    48         <property name="defaultEncoding">
    49             <value>UTF-8</value>
    50         </property>
    51         <property name="maxUploadSize">
    52             <value>32505856</value>
    53         </property>
    54         <property name="maxInMemorySize">
    55             <value>4096</value>
    56         </property>
    57     </bean>-->
    58 
    59 </beans>
    View Code

        c)spring-mybatis.xml

     1 <?xml version="1.0" encoding="UTF-8"?>
     2 <beans xmlns="http://www.springframework.org/schema/beans"
     3     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="http://www.springframework.org/schema/tx"
     4     xmlns:aop="http://www.springframework.org/schema/aop"
     5     xsi:schemaLocation="
     6         http://www.springframework.org/schema/beans 
     7         http://www.springframework.org/schema/beans/spring-beans-4.1.xsd 
     8         http://www.springframework.org/schema/tx 
     9         http://www.springframework.org/schema/tx/spring-tx-4.1.xsd
    10         http://www.springframework.org/schema/aop 
    11         http://www.springframework.org/schema/aop/spring-aop-4.1.xsd
    12         ">
    13 
    14     <!-- 配置数据源 使用的是Druid数据源 -->
    15     <bean name="dataSource" class="com.alibaba.druid.pool.DruidDataSource"
    16         init-method="init" destroy-method="close">
    17         <property name="url" value="${jdbc.url}" />
    18         <property name="username" value="${jdbc.username}" />
    19         <property name="password" value="${jdbc.password}" />
    20 
    21         <!-- 初始化连接大小 -->
    22         <property name="initialSize" value="0" />
    23         <!-- 连接池最大使用连接数量 -->
    24         <property name="maxActive" value="20" />
    25         
    26         <!-- 连接池最小空闲 -->
    27         <property name="minIdle" value="0" />
    28         <!-- 获取连接最大等待时间 -->
    29         <property name="maxWait" value="60000" />
    30         <property name="poolPreparedStatements" value="true" />
    31         <property name="maxPoolPreparedStatementPerConnectionSize"
    32             value="33" />
    33         <!-- 用来检测有效sql -->
    34         <property name="validationQuery" value="${validationQuery}" />
    35         <property name="testOnBorrow" value="false" />
    36         <property name="testOnReturn" value="false" />
    37         <property name="testWhileIdle" value="true" />
    38         <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
    39         <property name="timeBetweenEvictionRunsMillis" value="60000" />
    40         <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
    41         <property name="minEvictableIdleTimeMillis" value="25200000" />
    42         <!-- 打开removeAbandoned功能 -->
    43         <property name="removeAbandoned" value="true" />
    44         <!-- 1800秒,也就是30分钟 -->
    45         <property name="removeAbandonedTimeout" value="1800" />
    46         <!-- 关闭abanded连接时输出错误日志 -->
    47         <property name="logAbandoned" value="true" />
    48         <!-- 监控数据库 -->
    49         <property name="filters" value="mergeStat" />
    50     </bean>
    51 
    52     <!-- myBatis文件 -->
    53     <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    54         <property name="dataSource" ref="dataSource" />
    55         <!-- 自动扫描entity目录, 省掉Configuration.xml里的手工配置 -->
    56         <property name="mapperLocations" value="classpath:com/demo/report/web/mapper/*.xml" />
    57     </bean>
    58 
    59     <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    60         <property name="basePackage" value="com.feidai.report.web.mapper" />
    61         <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
    62     </bean>
    63 
    64     <!-- 配置事务管理器 -->
    65     <bean id="transactionManager"
    66         class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    67         <property name="dataSource" ref="dataSource" />
    68     </bean>
    View Code

        d)web.xml

     1 <display-name>springmvc_mybatis_demo</display-name>
     2 
     3     <context-param>
     4         <param-name>contextConfigLocation</param-name>
     5         <param-value>classpath:spring.xml,classpath:spring-mybatis.xml</param-value>
     6     </context-param>
     7 
     8     <filter>
     9         <filter-name>encodingFilter</filter-name>
    10         <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    11         <init-param>
    12             <param-name>encoding</param-name>
    13             <param-value>utf-8</param-value>
    14         </init-param>
    15         <init-param>
    16             <param-name>forceEncoding</param-name>
    17             <param-value>true</param-value>
    18         </init-param>
    19     </filter>
    20     <filter-mapping>
    21         <filter-name>encodingFilter</filter-name>
    22         <url-pattern>/*</url-pattern>
    23     </filter-mapping>
    24 
    25     <listener>
    26         <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    27     </listener>
    28 
    29     <!-- 防止spring内存溢出监听器 -->
    30     <listener>
    31         <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>
    32     </listener>
    33 
    34     <servlet>
    35         <description>spring mvc servlet</description>
    36         <servlet-name>rest</servlet-name>
    37         <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    38         <init-param>
    39             <param-name>contextConfigLocation</param-name>
    40             <param-value>
    41                 classpath:spring-mvc.xml
    42             </param-value>
    43         </init-param>
    44         <load-on-startup>1</load-on-startup>
    45     </servlet>
    46     <servlet-mapping>
    47         <servlet-name>rest</servlet-name>
    48         <url-pattern>/</url-pattern>
    49     </servlet-mapping>
    50 
    51     <servlet>
    52         <servlet-name>DruidStatView</servlet-name>
    53         <servlet-class>com.alibaba.druid.support.http.StatViewServlet</servlet-class>
    54     </servlet>
    55     <servlet-mapping>
    56         <servlet-name>DruidStatView</servlet-name>
    57         <url-pattern>/druid/*</url-pattern>
    58     </servlet-mapping>
    59 
    60     <!-- 配置session超时时间,单位分钟 -->
    61     <session-config>
    62         <session-timeout>30</session-timeout>
    63     </session-config>
    64 
    65     <welcome-file-list>
    66         <welcome-file>index.jsp</welcome-file>
    67     </welcome-file-list>
    View Code

    使用了druid的数据源,在web中的详细配置可以参看代码。

    do good things。
  • 相关阅读:
    [CLRS][CH 19]斐波那契堆
    [CLRS][CH 20] van Emde Boas 树
    [C++11] lambda函数
    常用网站整理
    词法分析原理 Lexical Analysis
    ie8开发人员工具无法使用,按f12任务栏里出现任务,但是窗体不弹出
    IE6下zindex犯癫不起作用bug的初步研究(转)
    ie8无法浏览png格式图片
    jquery.pngFix在最新的jquery1.7上无效的问题解决方法!
    用clearfix:after消除(DIV块因内部浮动而高度收缩的问题)(转)
  • 原文地址:https://www.cnblogs.com/huane/p/5874471.html
Copyright © 2011-2022 走看看