SpringMVC数据库链接池,以及其他相关配置详解编程语言

1.applicationContext.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:p="http://www.springframework.org/schema/p" 
    xmlns:mvc="http://www.springframework.org/schema/mvc" 
    xmlns:context="http://www.springframework.org/schema/context" 
    xsi:schemaLocation=" 
        http://www.springframework.org/schema/beans 
        http://www.springframework.org/schema/beans/spring-beans.xsd 
        http://www.springframework.org/schema/mvc 
        http://www.springframework.org/schema/mvc/spring-mvc.xsd      
        http://www.springframework.org/schema/context 
        http://www.springframework.org/schema/context/spring-context.xsd"> 
    <!-- 扫描的包 --> 
    <!-- <context:component-scan base-package="app04"/> --> 
    <!-- 使用转换器 --> 
    <!--<mvc:annotation-driven conversion-service="conversionService"/>--> 
    <!-- 使用格式化 --> 
    <!-- conversionService2 --> 
   <!--  <mvc:annotation-driven conversion-service="conversionService2"/> --> 
    
    <!-- 使用注册器替代格式化 --> 
    <!-- <mvc:annotation-driven />意思是开启使用注释的功能--> 
    <!-- conversionService3是格式化或者转换器 --> 
    <!-- <mvc:annotation-driven conversion-service="conversionService3"/> --> 
    
    <!-- 扫描的包 --> 
    <context:component-scan base-package="sfk.bbs.test.testSpringMVCConfig.action"/> 
    <!-- 这个的作用是让DispatcherServlet不将下列路径理解为一个request请求, 
    在项目中,这个是必须的,如果没有加这些就可能造成上述问题 --> 
    <mvc:annotation-driven /> 
    <mvc:resources mapping="/css/**" location="/css/"/> 
    <mvc:resources mapping="/js/**" location="/js/"/> 
    <mvc:resources mapping="/*.html" location="/"/> 
     
    <!-- 视图解析器 -->    
    <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> 
        <property name="prefix" value="/WEB-INF/pages/"/> 
        <property name="suffix" value=".jsp"/> 
    </bean> 
    <!-- 读取配置文件信息,在Spring的配置文件中使用EL表达式填充值 --> 
    <context:property-placeholder location="classpath:jdbc.properties"/> 
    <!-- 配置数据库连接池 --> 
    <bean id="dataSourceLocal" name="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"> 
<!-- 指定连接数据库的驱动--> 
<property name="driverClass" value="${jdbc.driverClassName}"/> 
<!-- 指定连接数据库的URL--> 
<property name="jdbcUrl" value="${jdbc.url}"/> 
<!-- 指定连接数据库的用户名--> 
<property name="user" value="${jdbc.username}"/> 
<!-- 指定连接数据库的密码--> 
<property name="password" value="${jdbc.password}"/> 
<!-- 指定连接池中保留的最大连接数. Default:15--> 
<property name="maxPoolSize" value="${jdbc.maxPoolSize}"/> 
<!-- 指定连接池中保留的最小连接数--> 
<property name="minPoolSize" value="${jdbc.minPoolSize}"/> 
<!-- 指定连接池的初始化连接数 取值应在minPoolSize 与 maxPoolSize 之间.Default:3--> 
<property name="initialPoolSize" value="${jdbc.initialPoolSize}"/> 
<!-- 最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。 Default:0--> 
<property name="maxIdleTime" value="${jdbc.maxIdleTime}"/> 
<!-- 当连接池中的连接耗尽的时候c3p0一次同时获取的连接数. Default:3--> 
<property name="acquireIncrement" value="${jdbc.acquireIncrement}"/> 
<!-- JDBC的标准,用以控制数据源内加载的PreparedStatements数量。 
但由于预缓存的statements属于单个connection而不是整个连接池所以设置这个参数需要考虑到多方面的因数.如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default:0--> 
<property name="maxStatements" value="${jdbc.maxStatements}"/> 
<!-- 每60秒检查所有连接池中的空闲连接.Default:0 --> 
<property name="idleConnectionTestPeriod" value="${jdbc.idleConnectionTestPeriod}"/> 
</bean> 
     
     
     
    <!-- <bean id="dataSourceLocal" name="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"> 
        制定连接数据库的驱动 
        <property name="driverClass" value="${jdbc.driverClassName}" /> 
        制定连接数据库的URL 
        <property name="jdbcUrl" value="${jdbc.url}" /> 
        指定连接数据库的用户名 
        <property name="user" value="${jdbc.username}" /> 
        指定数据库的密码 
        <property name="password" value="${jdbc.password}"/> 
        指定连接池中保留的最大连接数 default:15 
        <property name="maxPoolSize" value="${jdbc.maxPoolSize}"/> 
        指定连接池中保留的最小连接数  
        <property name="minPoolSize" value="${jdbc.minPoolSize}" /> 
        指定连接池的初始化连接数 取值应在minPoolSize 与MaxPoolSize之间,Default:3 
        <property name="initialPoolSize" value="${jdbc.initialPoolSize}"/> 
        最大空闲时间,60秒内未使用连接被丢弃,若为0则永不丢弃,Default:0 
        <property name="maxIdleTime" value="${jdbc.maxIdleTime}"/> 
        当连接池中的连接耗尽的时候c3p0一次同时获取的连接数. default: 3 
        <property name="acquireIncrement" value="${jdbc.acquireIncrement}" /> 
        JDBC的标准,用以控制数据源内加载的prepareedStatement数量.但是由于预缓存的statements 
        属于单个connection而不是整个连接池所以色绘制这个参数需要考虑到多方面的因素,如果maxStatements 
        与maxStatementsPerConnection均为0,则缓存被关闭,Default:0  
        <property name="maxStatements" value="${jdbc.maxStatements}"/> 
        每60秒检查所有连接池中的空闲连接default:0 
        <property name="idleConnectionTestPeriod" value="${jdbc.idleConnectionTestPeriod}" /> 
    </bean> --> 
    <!-- 错误提示信息配置,用配置文件管理错误信息 --> 
    <!-- <bean id="messageSource" class="org.springframework.context.support.ReloadableResourceBundleMessageSource"> 
        <property name="basename" value="/WEB-INF/resource/messages" /> 
    </bean> --> 
    <!-- org.springframework.context.support.ConversionServiceFactoryBean.class --> 
    <!-- 使用转换器的bean --> 
<!--     <bean id="conversionService" class="org.springframework.context.support.ConversionServiceFactoryBean"> 
        <property name="converters"> 
            <list> 
                <bean class="app06a.converter.StringToDateConverter" > 
                    <constructor-arg type="java.lang.String" value="MM-dd-yyyy"/> 
                </bean> 
            </list> 
        </property> 
    </bean> 
     --> 
    <!-- 使用Formatter的格式化 --> 
<!--     <bean id="conversionService2" class="org.springframework.format.support.FormattingConversionServiceFactoryBean"> 
        <property name="formatters"> 
            <set> 
             
            /springMVC/src/app06a/formatter/DateFormatter.java 
                <bean class="app06a.formatter.DateFormatter"> 
                    <constructor-arg type="java.lang.String" value="MM-dd-yyyy"/> 
                </bean> 
            </set> 
        </property> 
    </bean> --> 
     
        <!-- 使用注册器替代Formatter的格式化 --> 
<!--     <bean id="conversionService3" class="org.springframework.format.support.FormattingConversionServiceFactoryBean"> 
        <property name="formatterRegistrars"> 
            <set> 
            /springMVC/src/app06a/formatter/DateFormatter.java 
                <bean class="app06a.formatter.MyFormatterRigistrar"> 
                    <constructor-arg type="java.lang.String" value="MM-dd-yyyy"/> 
                </bean> 
            </set> 
        </property> 
    </bean> --> 
     
     
</beans>

web.xml

<?xml version="1.0" encoding="UTF-8"?> 
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1"> 
  <display-name>sfk_BBS02</display-name> 
  
          <!-- <context-param> 
            <param-name>contextConfigLocation</param-name> 
             <param-value>classpath:applicationContext.xml</param-value> 
        </context-param> --> 
<!--   <context-param> 
        <param-name>contextConfigLocation</param-name> 
        <param-value>/WEB-INF/resource/applicationContext.xml</param-value> 
    </context-param> --> 
     
    <!-- config log4j  first Part --> 
     <context-param> 
        <param-name>log4jConfigLocation</param-name> 
        <param-value>classpath:log4j.properties</param-value> 
    </context-param>   
    <!-- /WEB-INF/classes/applicationContext-*.xml --> 
    <context-param> 
        <param-name>contextConfigLocation</param-name> 
         <param-value>/WEB-INF/classes/applicationContext.xml</param-value> 
    </context-param>  
        <!-- Srping监听器 --> 
    <listener> 
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> 
    </listener>  
    <!-- config log4j  second Part --> 
    <!-- 加载log4j配置文件 --> 
    <listener> 
        <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class> 
    </listener> 
    <servlet> 
        <servlet-name>springMVC</servlet-name> 
        <servlet-class> 
            org.springframework.web.servlet.DispatcherServlet 
        </servlet-class> 
         <init-param> 
             <param-name>contextConfigLocation</param-name> 
             <param-value>classpath:applicationContext.xml</param-value> 
     
         </init-param> 
     
        <load-on-startup>1</load-on-startup> 
    </servlet> 
    <!-- 有的项目中这里写的是.do,这样分发器只会分发带有.do的请求, 
         就可以规避将js.css,.png等文件的路径当作一个请求,当前没有写.do,就要用到 
          <mvc:annotation-driven /> 
          <mvc:resources mapping="/css/**" location="/css/"/> 
          将.css等文件不当作一个请求 --> 
    <servlet-mapping> 
        <servlet-name>springMVC</servlet-name> 
        <url-pattern>/</url-pattern> 
    </servlet-mapping> 
 
     <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> 
   
</web-app>

log4j.properties

#log4j.rootLogger=INFO,C,F 
#first way log All 
########## 
# C,System.out 
#log4j.appender.C.Threshold=INFO print info or above 
########## 
log4j.logger.sfk.bbs=INFO,C,F 
#second way set log package  
log4j.appender.C=org.apache.log4j.ConsoleAppender 
log4j.appender.C.Threshold=INFO  
log4j.appender.C.layout=org.apache.log4j.PatternLayout 
log4j.appender.C.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %L %p %C{1} - %m%n 
 
########### 
#save in file 
#log4j.appender.F.Threshold=INFO ,info or above 
########### 
log4j.appender.F=org.apache.log4j.DailyRollingFileAppender 
# save file path 
log4j.appender.F.File=/home/rocky/develop/luna/eclipse/logInfo/SpringMVC_log 
log4j.appender.F.Append=true 
log4j.appender.F.Threshold=INFO 
log4j.appender.F.layout=org.apache.log4j.PatternLayout 
log4j.appender.F.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %L %p %C{1} - %m%n

项目的结构图

SpringMVC数据库链接池,以及其他相关配置详解编程语言

工具类

package sfk.bbs.common.SpringUtil; 
 
import org.springframework.beans.BeansException; 
import org.springframework.context.ApplicationContext; 
import org.springframework.context.ApplicationContextAware; 
import org.springframework.context.support.ClassPathXmlApplicationContext; 
 
/** 
 * 1.Spring的工具类,现在主要用来获取Spring配置文件中的bean 
 * 2.这个方法里比较遗憾的是没有用到implements ApplicationContextAware 
 * 原因是在web.xml文件中没有配置正确 
 * @author rocky 
 * 
 */ 
public class SpringHelper 
{ 
    private static  ApplicationContext applicationContext; 
 
     
    @SuppressWarnings("static-access") 
    public SpringHelper() 
    { 
        this.applicationContext =new ClassPathXmlApplicationContext("classpath:applicationContext.xml"); 
    } 
 
   /* @Override 
    public void setApplicationContext(ApplicationContext applicationContext) 
            throws BeansException 
    { 
        System.out.println("setApplicationContext : "+this.applicationContext); 
        this.applicationContext = applicationContext; 
 
    }*/ 
     
    public Object getBean(String beanId) 
    { 
        System.out.println("applicationContext : "+applicationContext); 
        System.out.println("getBean : " + beanId); 
        return applicationContext.getBean(beanId); 
    } 
 
}

测试类

package sfk.bbs.test.testSpringMVCConfig.action; 
 
 
import java.sql.Connection; 
import java.sql.SQLException; 
 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
import javax.sql.DataSource; 
 
import org.apache.log4j.Logger; 
import org.springframework.context.ApplicationContext; 
import org.springframework.context.support.ClassPathXmlApplicationContext; 
import org.springframework.stereotype.Controller; 
import org.springframework.ui.Model; 
import org.springframework.web.bind.annotation.RequestMapping; 
 
import com.mchange.v2.c3p0.ComboPooledDataSource; 
 
import sfk.bbs.common.SpringUtil.SpringHelper; 
import sfk.bbs.common.constance.ActionURL; 
import sfk.bbs.common.constance.PagePath; 
 
@Controller 
public class StudentAction 
{ 
    private static Logger log = Logger.getLogger(StudentAction.class); 
    /** 
     * 1.现在的想法是把pages文件夹写在SpringMVC的配置文件中,将后缀.jsp也写在SpringMVC的配置文件中 
     * 在Controller中page页面写成这样"testPage/studentList 
     * 斜杠左边的pages文件夹下面的下一层文件夹,斜杠右边的是jsp文件 
     * 2.jsp文件名和requestMapping中的value相同 
     * 3.注意:requestMapping不写.do,页面不写.jsp 
     *  
     * 查找所有的student列表 
     * @param request request 
     * @param response response 
     * @param model model 
     * @return studentList 
     */ 
    @RequestMapping(value=ActionURL.STUDENT_LIST) 
    public String findAllStudent(HttpServletRequest request, 
            HttpServletResponse response,Model model) 
    { 
       SpringHelper springHelper = new SpringHelper(); 
        DataSource  datasource = (ComboPooledDataSource) springHelper.getBean("dataSourceLocal"); 
        Connection conn = null; 
        try 
        { 
            conn = datasource.getConnection(); 
        } catch (SQLException e) 
        { 
            // TODO Auto-generated catch block 
            e.printStackTrace(); 
        } 
        finally 
        { 
            try 
            { 
                conn.close(); 
            } catch (SQLException e) 
            { 
                // TODO Auto-generated catch block 
                e.printStackTrace(); 
            } 
        } 
        System.out.println(conn); 
         
         //ctx = new ("classpath:applicationContext.xml"); 
       // ApplicationContext ctx = new ClassPathXmlApplicationContext("classpath:applicationContext.xml"); 
        //System.out.println("ctx : " + ctx); 
        log.info("into findAllStudent"); 
        return PagePath.STUDENT_LIST; 
    } 
     
}

 

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/15387.html

(0)
上一篇 2021年7月19日 17:44
下一篇 2021年7月19日 17:44

相关推荐

发表回复

登录后才能评论