1

我的要求是在以嵌入式模式部署我的战争文件时应该启动 H2 数据库。为此,我在我的 java 项目中创建了 class(DbSetup)。我在 web.xml 中提到了同一个类。然后我实现了 contextInitialized(ServletContextEvent sce) 方法。在这种方法中,我正在连接到在部署战争时建立连接的 h2 db。在获取战争文件时,我得到了类似“没有为 jdbc:h2:~/test1 找到合适的类。请问如何解决这个问题?我正在将 h2-1.4.192.jar 与我的战争绑定。我还复制了相同的 jar 到类路径。

网页.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns="http://java.sun.com/xml/ns/javaee"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
    id="WebApp_ID" version="3.0">

    <display-name>CEMDBWS</display-name>
    <welcome-file-list>
        <welcome-file>index.html</welcome-file>
    </welcome-file-list>
            <listener>
    <listener-class>org.h2.server.web.DbStarter</listener-class>
</listener>

<context-param>
    <param-name>db.url</param-name>
    <param-value>"jdbc:h2:~/test1"</param-value>
</context-param>
<context-param>
    <param-name>db.user</param-name>
    <param-value>sa</param-value>
</context-param>
<context-param>
    <param-name>db.password</param-name>
    <param-value>sa</param-value>
</context-param>

    <listener>
  <listener-class>DbSetup</listener-class>
</listener>
    <servlet>
        <servlet-name>JSON TO SQL Rest API</servlet-name>
        <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
        <load-on-startup>1</load-on-startup>


    </servlet>


    <servlet-mapping>
        <servlet-name>JSON TO SQL Rest API</servlet-name>
        <url-pattern>/Request/*</url-pattern>
    </servlet-mapping>

    <session-config>
        <session-timeout>-1</session-timeout>
        <tracking-mode>COOKIE</tracking-mode>
    </session-config>

    <mime-mapping>
        <extension>json</extension>
        <mime-type>application/json</mime-type>
    </mime-mapping>

我的课:

try 
{

        Connection connection = null;
        final String DB_CONNECTION = "jdbc:h2:~/test1";

        final String DB_USER = "sa";
                 Class.forName(org.h2.Driver);

        final String DB_PASSWORD = "sa";
        connection = DriverManager.getConnection(DB_CONNECTION, DB_USER, DB_PASSWORD);
        return connection;
    } catch (SQLException e) {
        LOGGER.error("Error while getting DB connection", e);
        return connection;
    } catch (ClassNotFoundException e) {
        LOGGER.error("Error while loading Driver", e.getMessage());
    }
    return connection
4

0 回答 0