电信主站 网通分站
购买流程 付款方式 常见问题 在线提问 续租服务 购物车
用户名: 密 码: 忘记密码?
首 页
域名注册
虚拟主机
双线主机
服务器租用
VPS主机
企业邮局
代理专区
客服中心
虚拟主机行业资讯 虚拟主机评测对比 互联网最新动态 技术学院 站长资讯 在线教程 网站运营
搜索优化 服务器 网络编程 图形图象 站长之家 网页制作 操作系统
冲浪宝典 软件教学 视频通信 办公软件 邮件系统 网络安全 认证考试
您当前位置:西部数码->资讯中心-> 在线教程-> JSP教程
JSP用连接池连数据库的问题-JSP教程,Jsp/Servlet
作者:网友供稿 点击:95
  西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!虚拟主机可在线rar解压,自动数据恢复设置虚拟目录等.虚拟主机免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金!
文章页数:[1] 
 

各位高手麻烦帮我看下面这三个文件(一个jsp,两个.java),我在ie输入地址时,提示如下错误(代码应该没有错,不知是不是设置的问题),望高手指教,不胜感激:

d:\program files\apache group\tomcat 4.1\work\standalone\localhost\_\shopping\index_jsp.java:44: package mybean does not exist
      mybean.dbconnmanager connmanager = null;
            ^



an error occurred at line: 2 in the jsp file: /shopping/index.jsp

generated servlet error:
d:\program files\apache group\tomcat 4.1\work\standalone\localhost\_\shopping\index_jsp.java:46: package mybean does not exist
        connmanager = (mybean.dbconnmanager) pagecontext.getattribute("connmanager", pagecontext.application_scope);
                             ^



an error occurred at line: 2 in the jsp file: /shopping/index.jsp

generated servlet error:
d:\program files\apache group\tomcat 4.1\work\standalone\localhost\_\shopping\index_jsp.java:49: package mybean does not exist
            connmanager = (mybean.dbconnmanager) java.beans.beans.instantiate(this.getclass().getclassloader(), "mybean.dbconnmanager");
                                 ^

//下面这两个是连接池,下面两个文件都放在一个mybean的包里.

package mybean;
import java.sql.*;
import java.util.*;

public class dbconnpool {
  //正在使用连接的数量
  private int using;
  //目前可用的连接数,即空闲连接
  private vector connections=new vector();
  //最大连接数
  private int maxconn;
  //连接池名
  private string poolname;
  //数据库标识
  private string dbid;
  //驱动程序名
  private string drivername;
  //数据库帐号
  private string username;
  //数据库密码
  private string passwd;

  public dbconnpool(string poolname,string dbid,string drivername,
                    string username,string passwd,int maxconn){
    this.poolname=poolname;
    this.drivername=drivername;
    this.dbid =dbid;
    this.username =username;
    this.passwd=passwd;
    this.maxconn=maxconn;
  }

  /*将空闲连接返回给连接池*/
  public synchronized void returnconnection(connection conn){
    //将指定连接加到向量末尾
    connections.addelement(conn);
    //连接用户减一
    using--;
  }

  /*从连接池得到一个连接*/
  public synchronized connection getconnection(){
    connection conn = null; //connection是一个类,
    //connections是一个向量,用于存储连接对象,它所存储是的所有空闲状态的可用连接
    if (connections.size() > 0) {

      //获取连接列表的第一个连接
      conn = (connection) connections.elementat(0);
      connections.removeelementat(0);//获得一个连接,并将此连接从队列中删除.

      //如果此连接已关闭,刚继续获取,
      try {
        if (conn.isclosed())
          conn = getconnection();
      }
      catch (exception e) {
        e.printstacktrace();
      }
    }
      //如果实际使用的连接数小于最大连接数即有可用连接),就新增加一个连接
    else if (maxconn == 0 || using < maxconn){
      //如此时无可用连接(maxconn == 0)且连接数又未达到上限(using < maxconn)),就创建一个新连接
        conn=newconnection();
      }
      //如果连接数已达到上限就返回空指针
      if (conn!=null){
        using++;
      }
    return conn;
  }

/*创建新的连接*/
  public connection newconnection(){
    connection conn=null;
    try{
      //加载驱动
      class.forname(drivername);
      conn=drivermanager.getconnection(dbid,username,passwd);
    }catch(exception e){
      e.printstacktrace();
      return null;
    }
    return conn;
  }

 /*关闭所有连接*/
 public synchronized void closeconn(){
   enumeration allconnections=connections.elements();
   while (allconnections.hasmoreelements()){
     connection conn=(connection) allconnections.nextelement();
     try{
       conn.close();
     }catch(sqlexception e){
       e.printstacktrace();
     }
   }
   connections.removeallelements();
 }
}

package mybean;
import java.sql.*;
import java.util.*;

public class dbconnmanager {
  //连接池名列表
  private vector poolnames =new vector();
  //驱动程序名列表
  private vector drivernames=new vector();
  //数据库标识列表
  private vector dbids=new vector();
  //用户名列表
  private vector usernames=new vector();
  //用户密码列表
  private vector passwds=new vector();
  //最大连接数列表
  private vector maxconns=new vector();
  //连接池队列
  private hashtable connpools=new hashtable();

  public dbconnmanager() {
    //添加access数据库的连接信息
    poolnames.addelement("access");
    drivernames.addelement("sun.jdbc.odbc.jdbcodbcdriver");
    dbids.addelement("jdbc:odbc:shopping");
    usernames.addelement("");
    passwds.addelement("");
    maxconns.addelement("5");

    //添加sql server2000数据库的连接信息
    poolnames.addelement("sqlserver2000");
    drivernames.addelement("com.microsoft.jdbc.sqlserver.sqlserverdriver");
    dbids.addelement("jdbc:microsoft:sqlserver://localhost:1433;databsername=shopping");
    usernames.addelement("");
    passwds.addelement("");
    maxconns.addelement("5");

    //连接mysql数据库信息
    poolnames.addelement("mysql");
    drivernames.addelement("org.gjt.mm.mysql.driver");
    dbids.addelement("jdbc:mysql://localhost/shopping");
    usernames.addelement("");
    passwds.addelement("");
    maxconns.addelement("5");

    //连接oracle8i/9i数据库
    poolnames.addelement("oracle");
    drivernames.addelement("oracle.jdbc.driver.oracledriver");
    dbids.addelement("jdbc:oracle:thin:@localhost:1521:shopping");
    usernames.addelement("");
    passwds.addelement("");
    maxconns.addelement("5");


    //创建连接池
    createpools();
  }

  /*将连接返回给由指定的连接池*/
  public void returnconnection(string name,connection conn){
    dbconnpool pool=(dbconnpool) connpools.get(name);
    if (pool!=null)
    {
      pool.returnconnection(conn);
    }
  }

  /*得到一个指定连接池中的连接*/
  public connection getconnection(string name){
    dbconnpool pool=(dbconnpool) connpools.get(name);
    if (pool!=null)
    {
      return pool.getconnection();
    }
    return null;
  }

  /*关闭所有连接*/
  public synchronized void closeconns(){
    enumeration allpools=connpools.elements();
    while (allpools.hasmoreelements()){
      dbconnpool pool=(dbconnpool) allpools.nextelement();
      pool.closeconn();
    }
  }

  /*创建连接池*/
  private void createpools(){
    for (int i=0;i<poolnames.size();i++)
    {
      string poolname=poolnames.elementat(i).tostring();
      string drivername=drivernames.elementat(i).tostring();
      string dbid=dbids.elementat(i).tostring();
      string username=usernames.elementat(i).tostring();
      string passwd=passwds.elementat(i).tostring();
      int maxconn=0;
      try{
        maxconn=integer.parseint(maxconns.elementat(i).tostring());
      }catch (numberformatexception e){
        e.printstacktrace();
      }
      dbconnpool pool=new dbconnpool(poolname,drivername,dbid,username,
                                     passwd,maxconn);
      connpools.put(poolname,pool);
    }
  }
}


下面这个是主页面.jsp文件

<%@ page contenttype="text/html; charset=gbk" %>
<%@ page import ="java.sql.*" %>
<jsp:usebean id="connmanager" scope="application" class="mybean.dbconnmanager" />
<html>
<head>
<title>
购物商城首页
</title>
</head>
<body bgcolor="#b0c4de">
<center><h1>欢迎访问本购物商城</h1></center>
<%
//connection conna=connmanager.getconnection("access");
connection conns=connmanager.getconnection("sqlserver2000");
if (conns==null)
{
%>
  数据库正忙,请稍后再访问
<%
}
//statement stmta=conna.createstatement();
statement stmts=conns.createstatement();
%>

<%
string sql="select * from userinfo";
resultset rs=stmts.executequery(sql);
while (rs.next())
{
%>
<tr>
<td><%=rs.getstring("username")%></td>
<td><%=rs.getstring("userpass")%></td>
</tr>
<%
}
rs.close();
stmts.close();
connmanager.returnconnection("sqlserver2000",conns);
%>

</body>
</html>



文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!
相关主题
文章页数:[1] 
Google
热门文章
·IReport与JasperReport开发详解一-JSP教程,Java技巧及代码
·JSTL(JSP标准标签库)介绍-JSP教程,资料/其它
·格式化输入日期时间控件 JieFormattedDateBox-JSP教程,Java技巧及代码
·JSTL简化JSP编码-JSP教程,Jsp/Servlet
·JUnit和单元测试入门简介-JSP教程,Java技巧及代码
·从数据库中读取一个图片并保存为一个图片文件-JSP教程,数据库相关
·Java Swing入门基础-JSP教程,Java技巧及代码
·IntelliJ IDEA培训-JSP教程,Java技巧及代码
·通过JSP的预编译消除性能瓶颈-JSP教程,Jsp/Servlet
·Java中利用JMF编写摄像头拍照程序-JSP教程,Java技巧及代码

最新文章
·J2ME中的时间处理方法
·J2ME播放声音流程简介
·J2ME开发之手机键盘使用注意问题
·J2ME 记录管理存储
·MVC模式在j2me项目中的应用(二)
·MVC模式在j2me项目中的应用(一)
·J2ME中使用记录存储系统(RMS)存储信息
·J2ME与MIDP开发(1)
·用简单的J2ME程序测试MIDlet的生命周期
·JAVA基础:提升JSP应用程序的七大绝招


 
 


版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!

特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
  打印  刷新  关闭
返回首页 |关于我们 | 联系我们 | 付款方式 | 创业联盟 | 虚拟主机 | 资讯中心 | 友情链接 | 网站地图

版权所有 西部数码(www.west263.com)
CopyRight (c) 2002~2006 west263.com all right reserved.
公司地址:四川成都市万和路90号天象大厦4楼 邮编:610031
电话总机:028-86262244 86263048 86263408 86263960 86264018 86267838
售前咨询:总机转201 202 203 204 206 208
售后服务:总机转211 212 213 214
财务咨询:总机转224 223 传真:028-86264041 财务QQ:点击发送消息给对方635483282
售前咨询QQ:点击发送消息给对方2182518 点击发送消息给对方241975952 点击发送消息给对方275026793 点击发送消息给对方408235859
售后服务QQ:点击发送消息给对方17708515 点击发送消息给对方307742704 点击发送消息给对方287976517 点击发送消息给对方363783715
《中华人民共和国增值电信业务经营许可证》编号:川B2-20030065号