1、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_2_5.xsd" id="WebApp_ID" version="2.5">
  <display-name>mgr</display-name>
  <welcome-file-list>
    <welcome-file>index.html</welcome-file>
    <welcome-file>index.htm</welcome-file>
    <welcome-file>index.jsp</welcome-file>
    <welcome-file>default.html</welcome-file>
    <welcome-file>default.htm</welcome-file>
    <welcome-file>default.jsp</welcome-file>
  </welcome-file-list>

   <context-param>
  <param-name>contextConfigLocation</param-name>
  <param-value>
   classpath:config/spring_config.xml<!-- spring整合配置 -->
   classpath:config/spring_quartz.xml<!-- 配置定时任务时使用 -->
  </param-value>
 </context-param>
 <!-- 设置由Sprng载入的Log4j配置文件位置,默认为src下,如果修改配置文件路径则需要修改 -->
<!--  <context-param>
  <param-name>log4jConfigLocation</param-name>
  <param-value>classpath:config/log4j.properties</param-value>
 </context-param>
 Spring刷新Log4j配置文件变动的间隔,单位为毫秒
 <context-param>
  <param-name>log4jRefreshInterval</param-name>
  <param-value>10000</param-value>
 </context-param>
 <listener>
  <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
 </listener> -->

 <!-- Spring监听器 -->
 <listener>
  <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
 </listener>
 <listener>
  <listener-class>org.springframework.web.context.request.RequestContextListener</listener-class>
 </listener>

 <!-- Struts2 -->
 <filter>
  <filter-name>struts2</filter-name>
  <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
  <!-- 默认strut.xml放在src目录下,如需修改,需要增加init配置 -->
 </filter>
 <filter-mapping>
  <filter-name>struts2</filter-name>
  <url-pattern>/*</url-pattern>
 </filter-mapping>

 <session-config>
  <session-timeout>30</session-timeout>
 </session-config>

</web-app>

2、spring_config.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:aop="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:mybatis-spring="http://mybatis.org/schema/mybatis-spring" xsi:schemaLocation="http://mybatis.org/schema/mybatis-spring http://mybatis.org/schema/mybatis-spring-1.2.xsd
        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.1.xsd
        http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.1.xsd
        http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.1.xsd">

    <!-- 加载配置文件 -->
    <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="locations">
            <list>
                <value>classpath:config/jdbc.properties</value>
                <value>classpath:config/mail.properties</value>
            </list>
        </property>
    </bean>

    <!-- 1、配置数据源 -->
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">

        <!-- 配置基本属性 -->
        <property name="driverClassName" value="${jdbc.mysql.driverclassname}" />
        <property name="url" value="${jdbc.mysql.url}" />
        <property name="username" value="${jdbc.mysql.username}" />
        <property name="password" value="${jdbc.mysql.password}" />

        <!-- 配置连接初始化大小、最小、最大 -->
        <property name="initialSize" value="5" />
        <property name="minIdle" value="5" />
        <property name="maxActive" value="20" />

        <!-- 配置获取连接等待超时的时间 -->
        <property name="maxWait" value="60000" />

        <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
        <property name="timeBetweenEvictionRunsMillis" value="3600000" />

        <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
        <property name="minEvictableIdleTimeMillis" value="3600000" />

        <!-- 在每次空闲连接回收器线程(如果有)运行时检查的连接数量-->
        <property name="numTestsPerEvictionRun" value="3" />

        <!-- 打开PSCache,并且指定每个连接上PSCache的大小 -->
        <property name="poolPreparedStatements" value="true" />

        <!-- 用来检测连接是否有效的sql,要求是一个查询语句。如果validationQuery为null,testOnBorrow、testOnReturn、testWhileIdle都不会其作用 -->
        <property name="validationQuery" value="SELECT 1" />

        <!-- 申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效 -->
        <property name="testWhileIdle" value="true" />

        <!-- 申请连接时执行validationQuery检测连接是否有效,设置为false,默认是true,value值为true时候配置会降低性能7-10倍 -->
        <property name="testOnBorrow" value="false" />

        <!-- 归还连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能 -->
        <property name="testOnReturn" value="false" />

        <!-- 连接泄漏回收参数,当可用连接数少于3个时才执行 -->
        <property name="removeAbandoned" value="true" />

        <!-- 连接泄漏回收参数,180秒,泄露的连接可以被删除的超时值 -->
        <property name="removeAbandonedTimeout" value="180" />

        <!-- 配置监控统计拦截的filters -->
<!--         <property name="filters" value="slf4j" /> -->
    </bean>

    <!-- 2、配置sqlSessionFactory -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean" scope="prototype" >
        <!-- 加载数据源 -->
        <property name="dataSource" ref="dataSource"></property>
        <!-- 加载MyBatis配置文件 -->
        <property name="configLocation" value="classpath:config/mybatis_config.xml"></property>
        <!-- 加载mapper,存放sql的xml的路径-->
        <property name="mapperLocations" value="classpath*:com/develop/**/dao/mapper/*Mapper.xml" /><!-- Mapper.xml文件中的namespace的值是dao接口的全路径类  -->

        <property name="plugins">
            <array>
                <bean class="com.develop.core.page.github.pagehelper.PageHelper">
                    <property name="properties">
                        <value>
                            dialect=mysql
                            reasonable=true
                        </value>
                    </property>
                </bean>
            </array>
        </property>
    </bean>

    <!-- 3、通过模板定制mybatis的行为 -->
    <bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate">
        <constructor-arg index="0" ref="sqlSessionFactory" />
        <!--更新采用单个模式 -->
        <constructor-arg index="1" value="SIMPLE"/>
        <!--更新采用批量模式 -->
        <!-- <constructor-arg index="1" value="BATCH"/> -->
    </bean>

    <!-- 4、采用自动扫描方式创建mapper(dao) bean -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.develop.*.*.dao" />
        <property name="sqlSessionTemplateBeanName" value="sqlSessionTemplate" />
    </bean> 

    <!-- 5、加载Service组件 ,需要在Service的实现类Impl上方添加注解@Service,否则会报异常-->
    <context:component-scan  base-package="com.develop.*.*.service.impl"></context:component-scan>

    <!-- 6、配置事务管理器 -->
    <!-- MyBatis默认使用Spring JDBC的事务管理器 -->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"></property>
    </bean>

    <!-- 7、拦截器方式配置事物 -->
    <tx:advice id="transactionAdvice" transaction-manager="transactionManager">
        <tx:attributes>
            <tx:method name="insert*" propagation="REQUIRED"  rollback-for="Exception" />
            <tx:method name="update*" propagation="REQUIRED"  rollback-for="Exception" />
            <tx:method name="delete*" propagation="REQUIRED"  rollback-for="Exception" />
            <tx:method name="save*" propagation="REQUIRED"  rollback-for="Exception" />
            <tx:method name="add*" propagation="REQUIRED"  rollback-for="Exception" />
            <tx:method name="append*" propagation="REQUIRED"  rollback-for="Exception" />
            <tx:method name="modify*" propagation="REQUIRED"  rollback-for="Exception" />
            <tx:method name="edit*" propagation="REQUIRED"  rollback-for="Exception" />
            <tx:method name="remove*" propagation="REQUIRED"  rollback-for="Exception" />
            <tx:method name="init" propagation="REQUIRED"  rollback-for="Exception" />
            <tx:method name="delAndInit" propagation="REQUIRED"  rollback-for="Exception" />

            <tx:method name="select*" propagation="SUPPORTS" read-only="true" />
            <tx:method name="get*" propagation="SUPPORTS" read-only="true" />
            <tx:method name="find*" propagation="SUPPORTS" read-only="true" />
            <tx:method name="load*" propagation="SUPPORTS" read-only="true" />
            <tx:method name="search*" propagation="SUPPORTS" read-only="true" />
            <tx:method name="datagrid*" propagation="SUPPORTS" read-only="true" />

            <tx:method name="*" propagation="REQUIRED"  rollback-for="Exception" />
        </tx:attributes>
    </tx:advice>
    <aop:config>
        <aop:pointcut id="transactionPointcut" expression="execution(* com.develop.*.*.service..*.*(..))" />
        <aop:advisor pointcut-ref="transactionPointcut" advice-ref="transactionAdvice" />
    </aop:config>

    <!-- 邮件 -->
    <bean id="mailSender" class="org.springframework.mail.javamail.JavaMailSenderImpl">
        <property name="host" value="${mail.host}" />
        <property name="defaultEncoding" value="UTF-8" />
        <!-- Uncomment if you need to authenticate with your SMTP Server -->
        <property name="username" value="${mail.username}" />
        <property name="password" value="${mail.password}" />
        <property name="javaMailProperties">
            <value>
                mail.smtp.auth=true
                mail.smtp.socketFactory.class=javax.net.ssl.SSLSocketFactory
                mail.smtp.socketFactory.fallback=false
                mail.smtp.port=465
                mail.smtp.socketFactory.port=465
            </value>
        </property>
    </bean>

    <!-- Configure Velocity for sending e-mail -->
    <bean id="velocityEngine"
        class="org.springframework.ui.velocity.VelocityEngineFactoryBean">
        <property name="velocityProperties">
            <props>
                <prop key="resource.loader">class</prop>

                <prop key="class.resource.loader.class">
                    org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader
                </prop>
                <prop key="velocimacro.library"></prop>
                <prop key="velocimacro.library.autoreload">true</prop>
                <prop key="file.resource.loader.cache">false</prop>

                  <prop key="input.encoding">UTF-8</prop>
                  <prop key="output.encoding">UTF-8</prop>
                  <prop key="default.contentType">text/html; charset=UTF-8</prop>
            </props>
        </property>
    </bean>

    <bean id="mailMessage" class="org.springframework.mail.SimpleMailMessage"
        scope="prototype">
        <property name="from" value="${mail.default.from}" />
    </bean>

    <bean id="mailEngine" class="com.develop.core.controller.MailEngine">
        <property name="mailSender" ref="mailSender" />
        <property name="velocityEngine" ref="velocityEngine" />
        <property name="from" value="${mail.default.from}" />
    </bean>

    <!-- SimpleUrlHandlerMapping -->
    <bean id="urlMapping"
        class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
        <property name="mappings">
            <value>
                /baseadmin/flushCache.html=filenameController
                /mainMenu.html=filenameController
                /index.html=filenameController
            </value>
        </property>
        <property name="order" value="0" />
    </bean>

    <!-- /baseadmin/planeModel.html=planeModelController /baseadmin/flightCourse.html=flightCourseController -->

    <!-- BeanNameUrlHandlerMapping -->
    <bean id="handlerMapping"
        class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping">
    </bean>
    <!-- 一个Controller多个方法请求映射配置 -->
    <bean name="methodNameResolver"
        class="org.springframework.web.servlet.mvc.multiaction.ParameterMethodNameResolver">
        <property name="paramName">
            <value>method</value>
        </property>
    </bean>

    <bean
        class="org.springframework.web.servlet.mvc.support.ControllerClassNameHandlerMapping">
        <property name="order" value="1" />
    </bean>

    <!-- View Resolver for JSPs -->
    <bean id="viewResolver"
        class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="requestContextAttribute" value="rc" />
        <property name="viewClass"
            value="org.springframework.web.servlet.view.JstlView" />
        <property name="prefix" value="/WEB-INF/pages/" />
        <property name="suffix" value=".jsp" />
    </bean>

    <bean id="messageSource"
        class="org.springframework.context.support.ResourceBundleMessageSource">
        <property name="useCodeAsDefaultMessage" value="true" />
    </bean>

    <bean id="filenameController"
        class="org.springframework.web.servlet.mvc.UrlFilenameViewController" />
    <!-- Add additional controller beans here -->

    <bean id="multipartResolver"
        class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
        <property name="maxUploadSize" value="20971520" />
    </bean>

    <!-- 异常处理模块 -->
    <bean id="exceptionHandler" class="com.develop.core.controller.ApplicationExceptionHandler" />

</beans>

3、mybatis_config.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>        

    <!-- 全局的参数配置,如开启二级缓存等 -->    

    <settings>

        <!-- 配置延迟加载,按需加载对象属性 -->

        <setting name="lazyLoadingEnabled" value="true"/>  

        <setting name="aggressiveLazyLoading" value="false"/> 

    </settings>

    <!-- 使用别名 -->

    <typeAliases>

        <!-- 为包下的所有文件设置别名,别名为类名,不分大小写 -->

        <package name="com.develop.**.model"/>

    </typeAliases>

</configuration>

4、struts.xml配置,默认放在src下,如果修改需要修改web.xml中配置

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
 "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
 "http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
<!--  <constant name="struts.action.extension" value="action" />
 <constant name="struts.i18n.encoding" value="UTF-8" />
 <constant name="struts.devMode" value="true" />
 <constant name="struts.multipart.maxSize" value="52428800" />
 <constant name="struts.enable.SlashesInActionNames" value="true" />
 <constant name="struts.enable.DynamicMethodInvocation" value="false" />
 <constant name="struts.custom.i18n.resources" value="resource/message_zh_CN" /> -->

 <!-- 请求格式:namespace/action
  package:包
   * name:包名,唯一的,必选项
   * namespace:命名空间,唯一的,相当于房间号。可选项,省略情况下是"/"。页面中请求连接的前半部分
   * extends:继承
   * extends="struts-default":struts2框架底层提供的核心包struts2-core-2.3.3.jar下的struts-default.xml文件
   * 为什么要继承这个struts-default.xml文件?
   * 因为struts2框架底层提供的struts-default.xml声明了所有的拦截器和拦截器栈,
    知道在struts2框架运行时执行struts-default.xml文件中的拦截器栈。
   * 如果不继承struts-default.xml文件,就没有办法使用struts2框架提供的所有拦截器
  -->
 <package name="core" namespace="/core" extends="struts-default">
<!--   <interceptors>
   <interceptor name="trimInterceptor" class="com.ym.crm.interceptor.TrimInterceptor" />
   <interceptor name="applicationInterceptor" class="com.ym.crm.interceptor.ApplicationInterceptor" />
   <interceptor name="loginInterceptor" class="com.ym.crm.interceptor.LoginInterceptor" />
   <interceptor-stack name="baseStack">
    <interceptor-ref name="defaultStack" />
    <interceptor-ref name="trimInterceptor" />
   </interceptor-stack>
  </interceptors> -->
<!--   <global-results>
   <result name="root" type="redirectAction">/common/error.action</result>
   <result name="rootRuntime" type="redirectAction">/common/error.action</result>
  </global-results> -->
<!--   <action name="*/*" method="{1}" class="com.develop.core.{2}Action">
   <exception-mapping result="root" exception="java.lang.Exception" />
   <exception-mapping result="rootRuntime" exception="java.lang.RuntimeException" />
   <interceptor-ref name="baseStack"></interceptor-ref>
   <result name="success" >/WEB-INF/core/{1}.jsp</result>
   <result name="error" >/WEB-INF/error.jsp</result>
  </action> -->

  <action name="*_*" class="com.develop.core.action.{1}Action" method="{2}">
   <result name="success" >/WEB-INF/page/core/{1}_{2}.jsp</result>
   <result name="error" >/WEB-INF/page/common/error.jsp</result>
  </action>

 </package>
</struts>

搭建spring+mybatis+struts2环境的配置文件的更多相关文章

  1. 利用Intellij+MAVEN搭建Spring+Mybatis+MySql+SpringMVC项目详解

    http://blog.csdn.net/noaman_wgs/article/details/53893948 利用Intellij+MAVEN搭建Spring+Mybatis+MySql+Spri ...

  2. 项目SpringMVC+Spring+Mybatis 整合环境搭建(2)-> 测试Spring+Mybatis 环境

    测试前期准备 第一步:创建easybuy数据库,设置utf-8格式 第二步:创建表test_tb CREATE TABLE `test_tb` ( `id` int(11) NOT NULL AUTO ...

  3. web项目环境搭建(3):搭建Spring+MyBatis

    spring 4.1.7 + MyBatis 3.3 正式开始配置关键内容,这是硬货 一. 新建spring配置文件,起名为 applicationContext.xml,放在src/main/res ...

  4. 使用IntelliJ IDEA 搭建 spring mvc开发环境

    填好GroupId.ArtifactId,一路Next创建工程,在main 目录创建 java文件夹并转换为Sources Root,创建好工程目录结构如下: 配置工程 配置 pom.xml,引入相关 ...

  5. Eclipse上搭建Spring的开发环境

    一.安装Spring Tool Suite插件 如图: 点击Finish之后等待安装,安装完之后弹窗点击yes重启Eclipse,重启后显示如下界面: 二.搭建Spring开发环境 1.导入jar包到 ...

  6. spring mvc多环境下配置文件的设置

    在实际开发时经常需要把一些配置信息写在配置文件,比如mysql的主机地址.端口号.用户名和密码等.另外,在开发代码时可能用一套配置参数,而部署到测试环境时又会用另一套配置参数,测试完毕再部署到线上环境 ...

  7. Spring Boot实战一:搭建Spring Boot开发环境

    一开始接触Spring Boot就感到它非常强大,也非常简单实用,遂想将其记录下来. 搭建Spring Boot工程非常简单,到:http://start.spring.io/ 下载Spring Bo ...

  8. 在web项目中搭建一个spring mvc + spring + mybatis的环境

    介绍:本文中示范搭建一个ssm环境的框架:使用流程就是客户端通过http请求访问指定的接口,然后由服务器接受到请求处理完成后将结果返回. 本项目请求流程细节介绍:由客户端请求到指定的接口,这个接口是个 ...

  9. 项目SpringMVC+Spring+Mybatis 整合环境搭建(1)-> Spring+Mybatis搭建

    目录结构 第一步:web.xml 先配置contextConfigLocation 对应的application-context.xml文件 打开webapp\WEB-INF\web.xml, 配置s ...

随机推荐

  1. codeforces-Glass Carving(527C)std::set用法

    C. Glass Carving time limit per test 2 seconds memory limit per test 256 megabytes input standard in ...

  2. sql语句中的 inner join 、 left join 、 right join、 full join 的区别

    简单明了地说,连接分内连接和外链接 假设有A和B两张表 内连接:inner join   表示把AB表的记录相符都显示出来,把AB表不符合条件的都排除 外连接分三种,即左连接(LEFT OUTER J ...

  3. 一个标准的ECharts代码

    <!DOCTYPE html> <head> <meta charset="utf-8"> <title>ECharts</t ...

  4. java正则表达式练习

    package shb.java.demo3; import java.util.regex.Matcher; import java.util.regex.Pattern; /** * 正则表达式简 ...

  5. JAVA通过poi对Excel数据在(jsp+ssh)环境下导入导出

    POI的下载与安装  请到网站http://www.apache.org/dyn/closer.cgi/poi/右击超链接2.5.1.zip下载压缩包poi-bin-2.5.1-final-20040 ...

  6. Java中的数组操作进阶

    package com.mi.array; import java.util.Arrays; /** * System.arraycopy(i, 0, j, 0, i.length);这种复制会覆盖目 ...

  7. java 网络编程(三)---TCP的基础级示例

    下面是TCP java网络编程的基础示例: tcp传输:客户端建立过程的思路:1.创建TCP客户端的Socket服务,使用的是socket对象,建议在创建的过程中,就明确了目的地和要连接的主机2.如果 ...

  8. 【ruby】ruby基础知识

    Install Ruby(安装) For windows you can download Ruby from http://rubyforge.org/frs/?group_id=167 for L ...

  9. Yii增删改查操作

    增: 1 第一种 $post=new Post; $post->title='sample post'; $post->content='content for the sample po ...

  10. Native OR WebApp ?

    前两天刚好和一帮产品同学聊过,特指一个APP里面的各页面应该怎么做,大家的总结如下,原理一样,关键是了解Native和Web各自的优劣势:1. 偏交互的Native,偏浏览的Web:交互指复杂操作,输 ...