【问题标题】:Birt 4.2 JDBCException: Cannot load JDBC Driver class: com.mysql.jdbc.Driver (Tomcat 6.0)Birt 4.2 JDBCException:无法加载 JDBC 驱动程序类:com.mysql.jdbc.Driver (Tomcat 6.0)
【发布时间】:2012-08-29 21:38:56
【问题描述】:

我试图让 Birt 4.2.0 在 Tomcat 6.0 服务器上运行,但我根本无法让它加载 mySql JDBC 驱动程序。我的报告在 Eclipse 的预览版中运行良好,当我将它提供给 ReportEngine 时它​​运行良好,但网络查看器不断吐出这个异常:

SEVERE: DriverClassLoader failed to load class: com.mysql.jdbc.Driver
java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
    at org.eclipse.birt.core.framework.URLClassLoader.findClass1(URLClassLoader.java:188)
    at org.eclipse.birt.core.framework.URLClassLoader$1.run(URLClassLoader.java:156)
    at org.eclipse.birt.core.framework.URLClassLoader$1.run(URLClassLoader.java:1)
    at java.security.AccessController.doPrivileged(Native Method)
    at org.eclipse.birt.core.framework.URLClassLoader.findClass(URLClassLoader.java:151)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:321)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:266)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:264)
    at org.eclipse.birt.report.data.oda.jdbc.JDBCDriverManager.loadExtraDriver(JDBCDriverManager.java:1024)
    at org.eclipse.birt.report.data.oda.jdbc.JDBCDriverManager.findDriver(JDBCDriverManager.java:819)
    at org.eclipse.birt.report.data.oda.jdbc.JDBCDriverManager.loadAndRegisterDriver(JDBCDriverManager.java:946)

(接下来是大约 80 行堆栈跟踪,为简洁起见,我省略了)

我有 mysql-connector-java-5.1.21-bin.jar,我已将它放在 /usr/local/apache-tomcat-6.0.33/webapps/birt/WEB-INF/lib 中。经过大量的谷歌搜索,我也尝试将它放在许多其他地方,包括 /usr/local/apache-tomcat-6.0.33/lib、/usr/local/apache-tomcat-6.0.33/common/lib , 和 /usr/local/apache-tomcat-6.0.33/webapps/birt/WEB-INF/platform/plugins/org.eclipse.birt.report.data.oda.jdbc_5.1.21/drivers。没有任何影响。 我的 .rptdesign 文件中的数据源如下:

<data-sources>
    <oda-data-source extensionID="org.eclipse.birt.report.data.oda.jdbc" name="Playrific live" id="49">
        <list-property name="privateDriverProperties">
            <ex-property>
                <name>metadataBidiFormatStr</name>
                <value>ILYNN</value>
            </ex-property>
            <ex-property>
                <name>disabledMetadataBidiFormatStr</name>
            </ex-property>
            <ex-property>
                <name>contentBidiFormatStr</name>
                <value>ILYNN</value>
            </ex-property>
            <ex-property>
                <name>disabledContentBidiFormatStr</name>
            </ex-property>
        </list-property>
        <property name="odaDriverClass">com.mysql.jdbc.Driver</property>
        <property name="odaURL">jdbc:mysql://10.177.134.242:3406/db_playsmrt</property>
        <property name="odaUser">[redacted]</property>
        <encrypted-property name="odaPassword" encryptionID="base64">[redacted]</encrypted-property>
    </oda-data-source>
</data-sources>

此时,我唯一能想到的是 mysql-connector-java-5.1.21-bin.jar 属于我尚未尝试过的另一个位置,或者某处有一些环境变量需要设置,但我找不到任何关于它可能是什么的信息。有人知道发生了什么吗?

更新

Annnd 重新启动修复它。我现在觉得自己很傻。

【问题讨论】:

  • 我遇到了同样的问题。我正在尝试修复朋友的服务器,他正在运行一些 birt 报告。很难从命令行运行它,并且不通过 eclipse 运行所有内容。

标签: tomcat jdbc birt classnotfoundexception


【解决方案1】:

我尝试在 jboss eap 6.1 中运行我的 BIRT 报告时遇到了非常相似的情况,其中我的 mysql 驱动程序配置为 jboss 模块。我的应用程序按预期工作,但 BIRT 找不到 com.mysql.jdbc.Driver。为了解决它,我添加了

 <module name="com.mysql" export="true"/>

到我的 jboss-deployment-structure.xml 文件,以便容器导出 com.mysql 依赖项并且 BIRT 的 JDBCDriverManager 可以看到它。我重新部署了我的应用程序并且它工作了。

【讨论】:

    猜你喜欢
    • 2012-03-28
    • 2016-07-07
    • 2016-08-18
    • 2012-04-23
    • 2012-08-24
    • 1970-01-01
    • 2016-02-15
    • 1970-01-01
    • 2016-01-12
    相关资源
    最近更新 更多