SpringMVC配置文件

本文介绍了一个基于Spring MVC框架和Hibernate ORM技术的整合配置案例,涵盖了数据源配置、会话工厂设置、事务管理及AOP配置等内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<?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:context="http://www.springframework.org/schema/context"
    xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:aop="http://www.springframework.org/schema/aop"
    xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd
        http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd
        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/context http://www.springframework.org/schema/context/spring-context-3.0.xsd">


    <!-- 配置databaseSource -->
    <!-- ====================================== -->
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
        <property name="url"
            value="jdbc:mysql://localhost:3306/storemanager?characterEncoding=utf-8"></property>
        <property name="username" value="root"></property>
        <property name="password" value="123456"></property>
        <!-- 连接池初始化连接个数 -->
        <property name="initialSize" value="3" />
        <!-- 连接池的最大值 -->
        <property name="maxActive" value="10" />
        <!-- 最大空闲值.当经过一个高峰时间后,连接池可以慢慢将已经用不到的连接慢慢释放一部分,一直减少到maxIdle为止 -->
        <property name="maxIdle" value="5" />
        <!-- 最小空闲值.当空闲的连接数少于阀值时,连接池就会预申请去一些连接,以免洪峰来时来不及申请 -->
        <property name="minIdle" value="2" />
        <!-- 获取连接最大等待时间 -->
        <!-- <property name="maxWait" value="60000" /> -->


        <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
        <property name="timeBetweenEvictionRunsMillis" value="60000" />
        <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
        <property name="minEvictableIdleTimeMillis" value="25200000" />
        <!-- 打开removeAbandoned功能 -->
        <property name="removeAbandoned" value="true" />
        <!-- 1800秒,也就是30分钟 -->
        <property name="removeAbandonedTimeout" value="1800" />
        <!-- 关闭abanded连接时输出错误日志 -->
        <property name="logAbandoned" value="true" />
        <!-- 监控数据库 -->
        <!-- <property name="filters" value="mergeStat" /> -->
        <!-- <property name="filters" value="stat" /> -->
    </bean>


    <!-- 配置sessionFactory,用于获取session -->
    <!-- ====================================== -->
    <bean id="sessionFactory"
        class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="dataSource">
            <ref bean="dataSource" />
        </property>
        <property name="mappingResources">
            <list>
                <value>com/kl/napchen/store/bean/User.hbm.xml</value>
                <value>com/kl/napchen/store/bean/ProductIn.hbm.xml</value>
                <value>com/kl/napchen/store/bean/ProductOut.hbm.xml</value>
                <value>com/kl/napchen/store/bean/ProductType.hbm.xml</value>
            </list>
        </property>
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">
                    org.hibernate.dialect.MySQL5Dialect
                </prop>
                <prop key="hibernate.hbm2ddl.auto">update</prop>
                <prop key="hibernate.format_sql">true</prop>
                <prop key="hibernate.show_sql">true</prop>
                <prop key="current_session_context_class">thread</prop>
            </props>
        </property>


        <!-- 自动扫描注解方式配置的hibernate类文件 -->
        <!-- <property name="packagesToScan"> -->
        <!-- <list> -->
        <!-- <value>light.mvc.model</value> -->
        <!-- </list> -->
        <!-- </property> -->
    </bean>


    <!-- 配置事务管理器 -->
    <!-- ====================================== -->
    <bean id="transactionManager"
        class="org.springframework.orm.hibernate4.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory" />
        <!-- <property name="rollbackOnCommitFailure" value="true" /> -->
    </bean>


    <!-- 注解方式配置事物 -->
    <!-- ====================================== -->
    <!-- <tx:annotation-driven transaction-manager="transactionManager" /> -->


    <!-- AOP方式配置事物 -->
    <!-- ====================================== -->
    <tx:advice id="transactionAdvice" transaction-manager="transactionManager">
        <tx:attributes>
            <!-- <tx:method name="get*" propagation="REQUIRED" read-only="true" /> -->
            <!-- <tx:method name="add*" propagation="REQUIRED" /> -->
            <tx:method name="delete" propagation="REQUIRED" />
            <tx:method name="*" propagation="REQUIRED" />
        </tx:attributes>
    </tx:advice>


    <aop:config>
        <aop:pointcut id="transactionPointcut"
            expression="execution(* com.kl.napchen.store.impl..*.*(..))" />
        <aop:advisor pointcut-ref="transactionPointcut"
            advice-ref="transactionAdvice" />
    </aop:config>


    <!-- 启用aspectj注解自动代理 -->
    <!-- ====================================== -->
    <aop:aspectj-autoproxy />


    <!-- 配置代理bean -->
    <!-- ====================================== -->
    <bean id="adviceLog" class="com.kl.napchen.store.annotation.AdviceLog"></bean>
    <bean id="adviceUserLog" class="com.kl.napchen.store.annotation.AdviceUserLog"></bean>


    <!-- 配置Bean -->
    <!-- ====================================== -->
    <bean id="user" class="com.kl.napchen.store.bean.User"></bean>
    <bean id="productIn" class="com.kl.napchen.store.bean.ProductIn"></bean>
    <bean id="productOut" class="com.kl.napchen.store.bean.ProductOut"></bean>
    <bean id="productType" class="com.kl.napchen.store.bean.ProductType"></bean>
    <bean id="sessionInfo" class="com.kl.napchen.store.global.SessionInfo"></bean>
    <bean id="pageGrid" class="com.kl.napchen.store.page.PageGrid"></bean>


    <!-- 配置操作数据的Dao -->
    <!-- ====================================== -->
    <bean id="userDao" class="com.kl.napchen.store.dao.UserDao"></bean>
    <bean id="productInDao" class="com.kl.napchen.store.dao.ProductInDao"></bean>
    <bean id="productOutDao" class="com.kl.napchen.store.dao.ProductOutDao"></bean>
    <bean id="productTypeDao" class="com.kl.napchen.store.dao.ProductTypeDao"></bean>


    <!-- 配置业务处理的service -->
    <!-- ====================================== -->
    <bean id="userImpl" class="com.kl.napchen.store.impl.UserImpl"></bean>
    <bean id="productInImpl" class="com.kl.napchen.store.impl.ProductInImpl"></bean>
    <bean id="productOutImpl" class="com.kl.napchen.store.impl.ProductOutImpl"></bean>
    <bean id="productTypeImpl" class="com.kl.napchen.store.impl.ProductTypeImpl"></bean>


    <!-- 配置控制流程的controller -->
    <!-- ====================================== -->
    <!-- <bean id="userController" class="com.kl.napchen.store.controller.UserController"></bean> -->
    <!-- <bean id="productInController" class="com.kl.napchen.store.controller.ProductInController"></bean> -->
    <!-- <bean id="productOutController" class="com.kl.napchen.store.controller.ProductOutController"></bean> -->
    <!-- <bean id="productTypeController" class="com.kl.napchen.store.controller.ProductTypeController"></bean> -->




    <!-- 配置获取spring容器中Bean的工具Bean -->
    <!-- 由于持有ApplicationContext, -->
    <!-- 可以使用SpringContextHolder.getBean('xx')的静态方法得到spring bean对象 -->
    <!-- ====================================== -->
    <!-- <bean class="com.kl.napchen.storeManagerSystem.contextHolder.SpringContextHolder" 
        lazy-init="false" /> -->


    <!-- 对静态资源文件的访问 方案一 (二选一) -->
    <!-- 使用"*.do"配置DispatcherServlet时不存在静态资源访问问题 ,拦截器将不会拦截静态资源的URL -->
    <!-- 使用"/"配置DispatcherServlet时存在静态资源访问问题,采用以下两种方案解决 -->
    <!-- ====================================== -->
    <mvc:default-servlet-handler />


    <!-- 对静态资源文件的访问 方案二 (二选一) -->
    <!-- ====================================== -->
    <!-- 静态资源映射 -->
    <!-- <mvc:resources mapping="/js/**" location="/WEB-INF/js/" /> -->
    <!-- <mvc:resources mapping="/css/**" location="/WEB-INF/css/" /> -->
    <!-- <mvc:resources mapping="/fonts/**" location="/WEB-INF/fonts/" /> -->
    <!-- <mvc:resources mapping="/plugins/**" location="/WEB-INF/plugins/" /> -->
    <!-- <mvc:resources mapping="images/**" location="/WEB-INF/images/" /> -->


    <!-- 默认的注解映射的支持 -->
    <!-- 采用这下面种方式将自动装配DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter -->
    <!-- 采用这下面种方式将无法在 DefaultAnnotationHandlerMapping配置拦截器 -->
    <!-- ====================================== -->
    <mvc:annotation-driven />


    <!-- 配置 DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter -->
    <!-- ====================================== -->
    <!-- <bean -->
    <!-- class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping"> -->
    <!-- 配置拦截器 -->
    <!-- <property name="interceptors"> -->
    <!-- <list> -->
    <!-- <bean class="com/kl/napchen/storeManagerSystem/interceptor/MyInterceptor"></bean> -->
    <!-- </list> -->
    <!-- </property> -->
    <!-- </bean> -->
    <!-- <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"> 
        </bean> -->


    <!-- 隐式地向 Spring容器注册这4个BeanPostProcessor -->
    <!-- AutowiredAnnotationBeanPostProcessor、 -->
    <!-- RequiredAnnotationBeanPostProcessor、 -->
    <!-- CommonAnnotationBeanPostProcessor、 -->
    <!-- PersistenceAnnotationBeanPostProcessor -->
    <!-- ====================================== -->
    <!-- <context:annotation-config /> -->




    <!-- 设置使用注解的类所在的jar包 ,使用这种即可省去上面的声明 -->
    <!-- ====================================== -->
    <context:component-scan base-package="com.kl.napchen.store.controller" />
    <context:component-scan base-package="com.kl.napchen.store.impl" />
    <context:component-scan base-package="com.kl.napchen.store.baseService" />




    <!-- 映射“/”的url -->
    <!-- ====================================== -->
    <!-- <mvc:view-controller path="/" view-name="forward:/index2" /> -->


    <!-- configure the InternalResourceViewResolver -->
    <bean
        class="org.springframework.web.servlet.view.InternalResourceViewResolver"
        id="internalResourceViewResolver">
        <!-- <property name="viewClass" value="org.springframework.web.servlet.view.JstlView" 
            /> -->
        <!-- 前缀 -->
        <property name="prefix" value="/WEB-INF/jsp/" />
        <!-- 后缀 -->
        <property name="suffix" value=".jsp" />
    </bean>


    <!-- 自定义拦截器 (近似-总拦截器) -->
    <!-- ====================================== -->
    <mvc:interceptors>
        <!-- 使用bean定义一个Interceptor,直接定义在mvc:interceptors根下面的Interceptor将拦截所有的请求 -->
        <bean class="com.kl.napchen.store.interceptor.MyInterceptor" />
    </mvc:interceptors>




    <!-- 总错误处理 -->
    <!-- ====================================== -->
    <bean id="exceptionResolver"
        class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
        <!-- 配置不同类别的错误对应的view和状态码 -->
        <property name="exceptionMappings">
            <props>
                <prop key="java.lang.Exception">errors/error</prop>
                <prop key="java.lang.Throwable">errors/error</prop>
                <!-- 上传文件大于最大尺寸后转向出错页面 -->
                <!-- ====================================== -->
                <prop
                    key="org.springframework.web.multipart.MaxUploadSizeExceededException">errors/uploadError
                </prop>
            </props>
        </property>
        <property name="statusCodes">
            <props>
                <prop key="errors/error">500</prop>
                <prop key="errors/404">404</prop>
            </props>
        </property>
        <!-- 设置日志输出级别,不定义则默认不输出警告等错误日志信息 -->
        <property name="warnLogCategory">
            <value>org.springframework.web.servlet.handler.SimpleMappingExceptionResolver
            </value>
        </property>
        <!-- 默认错误页面,当找不到上面mappings中指定的异常对应视图时,使用本默认配置 -->
        <property name="defaultErrorView" value="errors/error"></property>
        <!-- 默认HTTP状态码 -->
        <property name="defaultStatusCode" value="500"></property>
    </bean>




</beans>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值