Tomcat6.0 :

 在$CATALINA_HOME/conf/server.xml文件中的<Host></Host>标签之间加入如下的Context代码
    <Context path="/articlesystem" docBase="articlesystem" debug="5" reloadable="true" crossContext="true">
       
<Resource name="jdbc/StrutsArticle" auth="Container" type="javax.sql.DataSource"
          maxActive
="100" maxIdle="30" maxWait="10000"
          username
="root" password="root" driverClassName="com.mysql.jdbc.Driver"
          url
="jdbc:mysql://localhost:3306/strutsaritclecharacterEncoding=GBK&amp;useUnicode=TRUE&amp;autoReconnect=true"/>
    
</Context>
注意要把这段代码配置到Host></Host>标签之间。

完成以上工作后,数据库就配置成功了。。也不必像官方文档说的那样在、在web应用的web.xml中配置<resource-ref>标签的属性了。

另. Context元素代表一个web应用,运行在某个特定的虚拟主机上。你可以在一个Host元素中嵌套任意多的Context元素。每个Context的路径必须是惟一的,由path属性定义。

所有Context的实现支持如下属性:

属性 描述
backgroundProcessorDelay 这个值代表在context及其子容器(包括所有的wrappers)上调用backgroundProcess方法的延时,以秒为单位。如果延时值非负,子容器不会被调用,也就是说子容器使用自己的处理线程。如果该值为正,会创建一个新的线程。在等待指定的时间以后,该线程在主机及其 子容器上调用backgroundProcess方法。context利用后台处理session过期,监测类的变化用于重新载入。如果没有指定,该属性的缺省值是-1,说明context依赖其所属的Host的后台处理。
className 实现的Java类名。该类必须实现org.apache.catalina.Context接口。如果没有指定,使用标准实现(在下面定义)。
cookies

如果想利用cookies来传递session identifier(需要客户端支持cookies),设为ture。否则为false,这种情况下只能依靠URL Rewriting传递session identifier。

 

crossContext

如果想在应用内调用ServletContext.getContext()来返回在该虚拟主机上运行的其他web application的request dispatcher,设为true。在安全性很重要的环境中,设为false,使得getContext()总是返回null。缺省值为false。

docBase

该web应用的文档基准目录(Document Base,也称为Context Root),或者是WAR文件的路径。可以使用绝对路径,也可以使用相对于context所属的Host的appBase路径。

 

override

如果想利用该Context元素中的设置覆盖DefaultContext中相应的设置,设为true。缺省情况下使用DefaultContext中的设置。

privileged

设为true,允许context使用container servlets,比如manager servlet。

 

path

web应用的context路径。catalina将每个URL的起始和context path进行比较,选择合适的web应用处理该请求。特定Host下的context path必须是惟一的。如果context path为空字符串(""),这个context是所属Host的缺省web应用,用来处理不能匹配任何context path的请求。

 

reloadable 如果希望Catalina监视/WEB-INF/classes/和/WEB-INF/lib下面的类是否发生变化,在发生变化的时候自动重载web application,设为true。这个特征在开发阶段很有用,但也大大增加了服务器的开销。因此,在发布以后,不推荐使用。但是,你可以使用Manager应用在必要的时候触发应用的重载。
wrapperClass

org.apache.catalina.Wrapper实现类的名称,用于该Context管理的servlets。如果没有指定,使用标准的缺省值。




 java代码得到连接:

 Context initCtx = new InitialContext();
         Context ctx 
= (Context)initCtx.lookup("java:comp/env");
         Object obj 
= (Object) ctx.lookup("jdbc/sqlserver");
         javax.sql.DataSource ds 
= (javax.sql.DataSource)obj;
         conn 
= ds.getConnection();


 Hibernate得到连接:

在hibernate-cfg.xml中
<property name="connection.datasource">java:comp/env/jdbc/sqlserver</property>


 Spring中得到连接:
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
               
<property name="jndiName"><value>java:comp/env/jdbc/dermis</value></property>
 
</bean>

 如果你用的是jboss服务器:
           把java:comp/env 改成java:就足够了

           如果你用的是apache的dbcp包:
           1.type="org.apache.commons.dbcp.BasicDataSouce"
           2.driverClassName="net.sourceforge.jtds.jdbc.Driver"
           3.url="jdbc:jtds:sqlserver://127.0.0.1:1433/dataBasename"

 如果你用的是MySQL:
            1.driverClassName="com.mysql.jdbc.Driver"
            2.url="jdbc:mysql://127.0.0.1:3306/dbname"
 如果是Oracle:
    
            1.driverClassName="oracel.jdbc.driver.OracleDriver"
            2.url="jdbc:oracle:thin://127.0.0.1:1521/dbname" 

Tomcat 5.5

首先编辑Server.xml,添加数据源代码

<Context path="/StudentManager" docbase="StudentManager" debug="5" reload="true" crossContext="true">
         
<Resource name="jdbc/StudentManager" auth="Container" type="javax.sql.DataSource"/>
            
<ResourceParams name="jdbc/StudentManager">
                
<parameter>
                  
<name>factory</name>
                  
<values>org.apache.commons.dbcp.BasicDataSourceFactory</values> 
                
</parameter>
                
<parameter>
                  
<name>url</name>
                  
<values>jdbc:mysql://localhost:3306/studentmanager</values>
                
</parameter>
                
<parameter>
                  
<name>driverclassname</name>
                  
<values>com.mysql.jdbc.Driver</values>
                
</parameter> 
                
<parameter>
                  
<name>username</name>
                  
<values>root</values> 
                
</parameter>
                
<parameter>
                  
<name>password</name>
                  
<values>root</values>
                
</parameter>
                
<parameter>
                  
<name>maxWait</name>
                  
<values>3000</values>
                
</parameter>
                
<parameter>
                  
<name>maxIdle</name>
                  
<values>10</values>
                
</parameter>
                
<parameter>
                  
<name>maxActive</name>
                  
<values>100</values>
                
</parameter>

            
</ResourceParams>                    
      
</Context>

在Web.xml中加入对jndi的引用

<resource-ref>   
      
<description>SqlServer   Datasource   example</description>   
      
<res-ref-name>jdbc/StudentManager</res-ref-name>   
      
<res-type>javax.sql.DataSource</res-type>   
      
<res-auth>Container</res-auth>   
  
</resource-ref>

 

测试代码:


 

<%
    
String jndi="java:comp/env/jdbc/StudentManager";
    DataSource ds
=null
     try{  
          
          Context initCtx
=new InitialContext();   //初始化上下文,可以读配置文件如:web.xml   
          
if(initCtx==null)   
                  throw 
new Exception("Initial   Failed!");       
          Context ctx
=(Context)initCtx.lookup("java:comp/env");   
          
if(ctx!=null)   
               ds
=(DataSource)ctx.lookup("jdbc/StudentManager"); 
          
if(ds==null)   
                  throw 
new Exception("Look   up   DataSource   Failed!");   
  }   
  catch(Exception e){   
          System.out.println(e.getMessage());   
  }
    System.out.println(ds);
 
%>