Tomcat 7.0.22を実行していて、SQLAnywhere12.0データベースに接続する単純なサーブレットを作成しました。サーブレットを実行すると、java.lang.ClassCastExceptionが発生します。org.apache.tomcat.dbcp.dbcp.BasicDataSourceをorg.apache.tomcat.jdbc.pool.DataSourceにキャストできません。私の./META-INF/content.xmlファイルは次のようになります。
<Context> <Resource name="jdbc/FUDB" auth="Container" type="javax.sql.DataSource" username="dba" password="sql" driverClassName="sybase.jdbc.sqlanywhere.IDriver" factory="org.apache.tomcat.jdbc.pool.DataSourceFactory"
url = "jdbc:sqlanywhere:uid = dba; pwd = sql; eng = BTH476331A_FedUtilization;" accessToUnderlyingConnectionAllowed = "true" maxActive = "8" maxIdle = "4" />
私のwebappweb.xmlは次のようになります。
<?xml version="1.0" encoding="ISO-8859-1"?> <web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0" metadata-complete="true"> <display-name>FedUtilization</display-name> <servlet> <servlet-name>Report1</servlet-name> <display-name>Report1</display-name> <servlet-class>com.sapgss.ps.servlet.Report1</servlet-class>
Report1 / Report1
SQLAnywhere12.0.1サーバーjdbc3jdbc/FUDBjavax.sql.DataSourceコンテナ
サーブレットコードは次のとおりです。
import java.io.*; import java.sql.*; import javax.servlet.*; import javax.servlet.http.*; import javax.naming.*; import org.apache.catalina.core.StandardContext.*; import org.apache.tomcat.jdbc.pool.*; import com.sapgss.ps.dbutil.*; import org.apache.tomcat.dbcp.dbcp.BasicDataSource; public class Report1 extends HttpServlet { public void doGet(HttpServletRequest request,
HttpServletResponse response)throws IOException、ServletException {try {response.setContentType( "text / html"); PrintWriter out = response.getWriter(); out.println( ""); out.println( ""); out.println( "Hello Elaine!"); out.println( ""); out.println( ""); out.println( "
こんにちはエレイン!
");
//これは、Javaでデータベースへのアクセスをコーディングする方法です。ContextinitCtx = new InitialContext(); Context envCtx =(Context)initCtx.lookup(" java:comp / env "); DataSource ds =(DataSource)envCtx .lookup( "jdbc / FUDB");接続conn = ds.getConnection();。。。
}}}
次の行でデータソースを取得しようとすると、エラーが発生します。DataSource ds =(DataSource)envCtx.lookup( "jdbc / FUDB");
よろしくお願いします。髪を抜いています。