簡體   English   中英

Tomcat 9 / JNDI 數據源 - 無法為連接 URL 'null' 創建類 '' 的 JDBC 驅動程序

[英]Tomcat 9 / JNDI DataSource - Cannot create JDBC driver of class '' for connect URL 'null'

  • Java 版本:10.0.1
  • Tomcat 版本:9.0.10
  • Postgres 驅動程序版本:42.2.4

我在 stackoverflow 上看到過一個類似的問題,但它與我的有點不同,那里的解決方案似乎都不適合我: 無法為連接 URL 'null' 創建類 ' ' 的 JDBC 驅動程序:我不明白這個異常

這是我第一次使用 Tomcat 9,也是我第一次嘗試將 JNDI 用於數據源。

使用 doc 作為參考: https : //tomcat.apache.org/tomcat-9.0-doc/jndi-datasource-examples-howto.html

它似乎無法從 <Resource> 讀取驅動程序/url/etc 屬性......盡管我終生無法弄清楚原因。

錯誤:

javax.servlet.ServletException: org.glassfish.jersey.server.ContainerException: java.sql.SQLException: Cannot create JDBC driver of class '' for connect URL 'null'
org.glassfish.jersey.servlet.WebComponent.serviceImpl(WebComponent.java:432)
org.glassfish.jersey.servlet.WebComponent.service(WebComponent.java:370)
org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:389)
org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:342)
org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:229)
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)

設置/配置:

tomcat 庫中的 postgresql-42.2.4.jar。

server.xml 片段:

<GlobalNamingResources>
. . .
<Resource name="jdbc/xxxx" auth="Container"
        type="javax.sql.DataSource"
        driverClassName="org.postgresql.Driver"
        url="jdbc:postgresql://127.0.0.1:5432/xxxx"
        username="xxxx"
        password="xxxx"
        maxTotal="20"
        maxIdle="10"
        maxWaitMillis="15000" />
</GlobalNamingResources>

網絡應用程序 web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" 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_2_5.xsd">

    <resource-ref>
        <description>xxxx Connection</description>
        <res-ref-name>jdbc/xxxx</res-ref-name>
        <res-type>javax.sql.DataSource</res-type>
        <res-auth>Container</res-auth>
    </resource-ref>

    <servlet>
        <servlet-name>Anwinity Test App</servlet-name>
        <servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
        <init-param>
            <param-name>jersey.config.server.provider.packages</param-name>
            <param-value>com.anwinity.webapps.test</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>Anwinity Test App</servlet-name>
        <url-pattern>/api/*</url-pattern>
    </servlet-mapping>
</web-app>

Java資源類:

package com.anwinity.webapps.test;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
import javax.naming.InitialContext;
import javax.sql.DataSource;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;

@Path("test")
public class TestResource {

    @GET
    @Produces(MediaType.APPLICATION_JSON)
    public Response test() throws Exception {

        // InitialContext ctx = new InitialContext();
        // DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/xxxx");
        Context initContext = new InitialContext();
        Context envContext = (Context)initContext.lookup("java:/comp/env");
        DataSource ds = (DataSource)envContext.lookup("jdbc/xxxx");
        if(ds == null) {
            System.out.println(":(");
            return Response.noContent().build();
        }
        else {
            try(Connection conn = ds.getConnection()) {
                String sql = "select * from test";
                try(Statement stmt = conn.createStatement()) {
                    List<Integer> list = new ArrayList<>();
                    try(ResultSet rs = stmt.executeQuery(sql)) {
                        while(rs.next()) {
                            int i = rs.getInt(1);
                            System.out.println(i);
                            list.add(i);
                        }
                        TestResponse resp = new TestResponse();
                        resp.setN(list.stream().mapToInt(i -> i).toArray());
                        return Response.ok(resp).build();
                    }
                }
            }
        }

    }
}

您正在 web.xml 文件中定義資源引用,請嘗試使用 context.xml 文件

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM