0

我正在制作一个使用 SQL 数据库的简单小程序。
当我在 Netbeans 上本地使用这个小程序时,它运行良好,没有问题,但是当我将它部署到 Web 时,我遇到了一个奇怪的错误。
我在本地使用 Java 1.6,而我部署的服务器正在运行 Java 1.6
我使用的是 J2BC 5.1.22。
这是我得到的错误:

java.lang.ExceptionInInitializerError
at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:315)
at java.sql.DriverManager.getConnection(Unknown Source)
at java.sql.DriverManager.getConnection(Unknown Source)
at FinalProject.DBConnect.<init>(DBConnect.java:29)
at FinalProject.TriviaApplet.init(TriviaApplet.java:61)
at com.sun.deploy.uitoolkit.impl.awt.AWTAppletAdapter.init(Unknown Source)
at sun.plugin2.applet.Plugin2Manager$AppletExecutionRunnable.run(Unknown Source)
at java.lang.Thread.run(Unknown Source)
    Caused by: java.security.AccessControlException: access denied
    ("java.util.PropertyPermission" "file.encoding" "read")
at java.security.AccessControlContext.checkPermission(Unknown Source)
at java.security.AccessController.checkPermission(Unknown Source)
at java.lang.SecurityManager.checkPermission(Unknown Source)
at java.lang.SecurityManager.checkPropertyAccess(Unknown Source)
at java.lang.System.getProperty(Unknown Source)
at com.mysql.jdbc.StringUtils.<clinit>(StringUtils.java:70)

我用来初始化驱动程序的代码是:

        Class.forName("com.mysql.jdbc.Driver");
        connection = DriverManager.getConnection(connectionURL, "db", "pw");

有没有人知道为什么会发生这种情况?

补充一点,我的小程序从另一个类中获取所有信息。^ 以上来自 DBConnect 类。创建了这个类的一个实例,这个类完成了所有的数据库工作。这是作为小程序完成的要求。我已经签署了我的 jar 和包含 JDBC 驱动程序的 lib jar。

4

1 回答 1

0

这是由于网络安全问题。您的 JDBC 驱动程序如何部署到客户端?你给他们足够的许可吗?实际上,在applet中使用JDBC来访问数据库是无值的。

  1. 它要求所有客户端都必须安装 JRE 和 CLASSPATH 中的 JDBC 驱动程序,您可以尝试将 JDBC 驱动程序与您的小程序打包在同一个 JAR 中。

  2. 它需要通过在每个本地 JRE 中授予套接字连接来修改策略。

permission java.net.SocketPermission "10.6.1.16:1521", "connect, resolve";

这使得这个解决方案几乎没用..

于 2012-12-17T02:40:59.100 回答