我想用数据源来连接sqlserver2000,数据源配置无误,驱动也没错,怎么会出这样的错误呢?
我的jsp文件为:
 <!--测试数据源-->
 <%@ page contentType="text/html; charset=gb2312" %>
 <%@ page import="javax.naming.Context" %> 
 <%@ page import="javax.sql.DataSource"%> 
 <%@ page import="javax.naming.InitialContext"%> 
 <%@ page import="java.sql.*"%>  <% 
   DataSource ds = null; 
   try{ 
     Context initCtx = new InitialContext(); 
     Context envCtx = (Context) initCtx.lookup("java:comp/env"); 
    //从Context中lookup数据源。
     ds = (DataSource)envCtx.lookup("jdbc/bn"); 
if(ds!=null) 
{
out.println("已经获得DataSource!"); 
out.println("<br>");
Connection conn = ds.getConnection();
Statement stmt=conn.createStatement();
ResultSet rst=stmt.executeQuery("select * from StrutsUser");
out.println("以下是从数据库中读取出来的数据");
while(rst.next())
{
out.println("userName:"+rst.getString("userName"));
out.println("<br>");
}
}
else 
 out.println("连接失败!"); 
}
catch(Exception ne)
{
 out.println(ne);

 %> 
浏览器错误为:
已经获得DataSource! 
org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of class '' for connect URL 'null' 不知这是什么原因?

解决方案 »

  1.   

    我搞定了,同时谢谢下面这篇文档的作者:
        配置tomcat下的连接池说实话是个即简单又复杂的过程,我在配置过程中先后遇到了至少3种以上奇怪的错误,现总结经验,把配置过程总结如下:1、配置%tomcat_home%\conf\Catalina\localhost\xxx.xml文件,其中xx代表你的web应用目录,缺省是ROOT5.0.x<?xml version='1.0' encoding='utf-8'?>
    <Context displayName="Welcome to Tomcat" docBase="D:\JAVA\ROOT" path="" workDir="work\Catalina\localhost\_">
      <Resource auth="Container" description="DB Connection" name="jdbc/WebDB" type="javax.sql.DataSource"/>
      <ResourceParams name="jdbc/WebDB">
        <parameter>
          <name>factory</name>
          <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
        </parameter>    <parameter>
          <name>maxActive</name>
          <value>100</value>
        </parameter>       <parameter>
          <name>maxIdle</name>
          <value>30</value>
        </parameter>    <parameter>
          <name>maxWait</name>
          <value>10000</value>
        </parameter>    <!-- MySQL dB username and password for dB connections  -->
        <parameter>
         <name>username</name>
         <value>sa</value>
        </parameter>
        <parameter>
         <name>password</name>
         <value>asdfgyuiop</value>
        </parameter>    <parameter>
           <name>driverClassName</name>
           <value>org.gjt.mm.mysql.Driver</value>
        </parameter>
         -->
        <parameter>
           <name>driverClassName</name>
           <value>com.microsoft.jdbc.sqlserver.SQLServerDriver</value>
        </parameter>
        
        <parameter>
          <name>url</name>
          <value>jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=WebDB</value>
        </parameter>
      </ResourceParams>
    </Context>5.5.x <Resource
        name="jdbc/XXX"
        type="javax.sql.DataSource"
        password="password"
        driverClassName="oracle.jdbc.driver.OracleDriver"
        maxIdle="2"
        maxWait="5000"
        username="username"
        url="jdbc:oracle:thin:@localhost:1521:SID"
        maxActive="4"/>如果版本有所不同,请参阅%tomcat_home%\webapps\tomcat-docs\目录下的文档jndi-datasource-examples-howto.html注意,我们不是去修改%tomcat%\conf\server.xml(通过admin加的连接池会自动把配置加到这个全局文件下),而是把配置单独加到对应的应用中;另外,如果你不是缺省的ROOT应用,应该修改path属性的值,使之与docBase匹配,例如如果docBase="D:\JAVA\haina",则path应为 path="/haina"2、配置%app_base%\WEB-INF\web.xml(此步骤为大多数文章推荐,经过测试证明可以不用)在</web-app>前加上这样一段<resource-ref>
       <description>DB Connection</description>
       <res-ref-name>jdbc/WebDB</res-ref-name>
       <res-type>javax.sql.DataSource</res-type>
       <res-auth>Container</res-auth>
     </resource-ref>3、访问的程序中要有"java:comp/env"前缀源码如下:  Context initCtx = new InitialContext(); 
      ctx = (Context) initCtx.lookup("java:comp/env"); 
      ds = (DataSource)ctx.lookup("jdbc/WebDB");
      cn = ds.getConnection();4、数据库如果是MS SQL Server 2000,而操作系统是Windows XP或Windows 2003的话,需要给MS SQL Server 2000打上sp3以上的补丁总结:以上步骤均十分关键,如果有误对应错误如下1、第一步错误,报错org.apache.commons.dbcp.SQLNestedException: Cannot create JDBC driver of class '' for connect URL 'null' 2、第三步错误,报错javax.naming.NameNotFoundException: Name jdbc is not bound in this Context 3、第四步错误,报错java.sql.SQLException: [Microsoft][SQLServer 2000 Driver for JDBC]Error establishing socket如果有上述错误,请检查对应步骤是否正确实施http://tb.blog.csdn.net/TrackBack.aspx?PostId=532870