Spring+Springmvc+SpringJDBC+freemaker+Logback配置

1、Spring配置如下:

<?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:context="http://www.springframework.org/schema/context"
    xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:tx="http://www.springframework.org/schema/tx"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd
        http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.1.xsd
        http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.1.xsd">
    
    <context:component-scan base-package="com.mengyao">
        <context:include-filter type="regex" expression="com.mengyao.*.controller"/>
        <context:include-filter type="regex" expression="com.mengyao.*.service"/>
        <context:include-filter type="regex" expression="com.mengyao.*.dao"/>
    </context:component-scan>
    
    <context:property-placeholder location="classpath:jdbc.properties"/>
    
    <!-- Spring容器启动完成后初始化此监听,用于启动Kafka消费者 -->
    <!-- <bean class="com.lefuyun.front.listener.InitListener"/> -->
    
    <bean id="dataSource" class="org.logicalcobwebs.proxool.ProxoolDataSource">
        <property name="alias" value="proxoolDataSource"/>
        <property name="driver" value="${driver}"/>
        <property name="driverUrl" value="${url}"/>
        <property name="user" value="${user}"/>
        <property name="password" value="${password}"/>
    </bean>
    
    <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
        <property name="dataSource" ref="dataSource"></property>
    </bean>
    
    <!-- 声明事务管理器 -->
    <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
          <property name="dataSource" ref="dataSource"/>
      </bean>

    <!-- 配置基于注解方式的声明式事务对@Transactional这个注解进行驱动 -->
    <tx:annotation-driven transaction-manager="txManager"/> 
    
</beans>

2、SpringMVC配置如下:

<?xml version="1.0" encoding="UTF-8"?>
<beans
    xmlns="http://www.springframework.org/schema/beans"
    xmlns:p="http://www.springframework.org/schema/p"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:mvc="http://www.springframework.org/schema/mvc"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
       http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd
       http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd"
       default-lazy-init="true">

    <!-- 是对包进行扫描,实现注释驱动Bean定义,同时将bean自动注入容器中使用。即解决了@Controller标识的类的bean的注入和使用。 -->
    <mvc:annotation-driven />
    
    <!-- 组件扫描注解:注入带有@Component(@Repository、@Service和、@Controller是@Component的子类)注解的类 -->
    <context:component-scan base-package="com.mengyao.shops.*.controller" />
    
    <!-- 开启spring mvc的注解功能,完成请求和注解POJO的映射 -->
    <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"></bean>
    
    <!-- 注册自定义拦截器,多个拦截器顺序执行 -->
    <mvc:interceptors>
        <bean class="com.mengyao.shops.interceptor.ShopInterceptor"/>
    </mvc:interceptors>
     
    <!-- 静态访问 不拦截 -->
    <mvc:resources location="/resources/pimg/"  mapping="/resources/pimg/**"/>
    <mvc:resources location="/resources/js/"  mapping="/resources/js/**"/>
    <mvc:resources location="/resources/css/"  mapping="/resources/css/**"/>
    
    <bean id="viewResolver" class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver">
      <property name="allowSessionOverride" value="true" />
      <property name="allowRequestOverride" value="true" />
      <property name="cache" value="true"/>
      <property name="prefix" value="/"/>
      <property name="suffix" value=".ftl"/>
      <property name="contentType" value="text/html;charset=UTF-8"></property>
      <property name="requestContextAttribute" value="request" />
      <property name="exposeSpringMacroHelpers" value="true" />
      <property name="exposeRequestAttributes" value="true" />
      <property name="exposeSessionAttributes" value="true" />      
    </bean>
     
    <bean id="freemarkerConfig"
        class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer">
       <property name="templateLoaderPath">
            <value>WEB-INF/pages/</value>
        </property>
        <property name="freemarkerSettings">
            <props>
                <prop key="template_update_delay">0</prop>
                <prop key="default_encoding">UTF-8</prop>
                <prop key="number_format">0.##########</prop>
                <prop key="datetime_format">yyyy-MM-dd HH:mm:ss</prop>
                <prop key="classic_compatible">true</prop>
                <prop key="template_exception_handler">ignore</prop>
            </props>
        </property>
    </bean>
    
    <!-- 视图解析器:InternalResourceViewResolver为UrlBasedViewResolver的子类,支持缓存;支持redirect:xx和forward:xx;添加前后缀并向view中添加必须的属性设置 -->
    <!-- 
    <bean id="viewResolver"    class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
        <property name="prefix" value="/pages/" />
        <property name="suffix" value=".jsp"/>
    </bean>
     -->
    <!-- JSON解析器:1:使用@responseBody来设置输出内容为context body 2:返回值设置为ResponseEntity<?>类型,以返回context body  -->
    <bean id="defaultJsonView" class="org.springframework.web.servlet.view.json.MappingJacksonJsonView"/>
    
    <!-- 文件解析器:CommonsMultipartResolver为CommonsFileUploadSupport的子类,支持多文件上传 -->
    <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver" >
         <property name="resolveLazily" value="true"/> 
         <property name="defaultEncoding" value="utf-8"/>
         <property name="maxUploadSize" value="10485760000" />
         <property name="maxInMemorySize" value="40960" />
    </bean>
      
</beans>  

3、Logback配置如下:

<?xml version="1.0" encoding="UTF-8" ?>
<configuration>
  <jmxConfigurator />
  
  <!-- 控制台输出日志 -->
  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
    <layout class="ch.qos.logback.classic.PatternLayout">
      <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
    </layout>
  </appender>
  
  <!-- 文件输出日志 (文件大小策略进行文件输出,超过指定大小对文件备份)-->
  <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <File>../logs/shops.log</File>
    <rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">
      <FileNamePattern>shops.log.%i.bak</FileNamePattern>
      <MinIndex>1</MinIndex>
      <MaxIndex>12</MaxIndex>
    </rollingPolicy>
    <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
      <MaxFileSize>100MB</MaxFileSize>
    </triggeringPolicy>
    <layout class="ch.qos.logback.classic.PatternLayout">
      <Pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</Pattern>
    </layout>
  </appender>
  
  <!--这里指定logger name 是为jmx设置日志级别做铺垫 -->
  <logger name="com.mengyao">
    <level value="INFO" />
    <appender-ref ref="STDOUT" />
    <appender-ref ref="FILE" />
  </logger>
</configuration>

 

posted @ 2012-07-15 11:40  孟尧  阅读(365)  评论(0编辑  收藏  举报