分享
 
 
 

JSP用连接池连数据库的问题

王朝java/jsp·作者佚名  2006-01-10
窄屏简体版  字體: |||超大  

各位高手麻烦帮我看下面这三个文件(一个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>

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有