0

我在 HTML 页面中嵌入了一个小程序。该小程序还使用 MySQL jar 文件。

没有 MySQL jar 文件,它工作得很好。从本地网络服务器或托管网络服务器执行它时,会出现以下错误:

Exception in thread "AWT-EventQueue-2" java.lang.ExceptionInInitializerError
at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:286)
at java.sql.DriverManager.getConnection(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)

我的文件列表:

/appletTest.html
/mysql-connector-java-5.1.18-bin.jar
/applet/testApplet.class

测试Applet.class:

package applet;

import java.applet.Applet;
import java.awt.Graphics;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class HelloWorldApplet extends Applet {

@Override
public void paint(Graphics g) {
    g.drawString("Hello World", 25, 50);

    Connection con = null;
    Statement st = null;
    ResultSet rs = null;

    String url = "jdbc:mysql://localhost:3306/testdb";

    try {
        con = DriverManager.getConnection(url, "root", ""); // <= here fails
        st = con.createStatement();
        rs = st.executeQuery("SELECT VERSION()");

        if (rs.next()) {
            g.drawString(rs.getString(1), 25, 50);
        }

    } catch (SQLException ex) {
        System.out.println(ex);
    } 
  }
}

小程序测试.html:

<html>
  <head>
  <title>Applet Test</title>
  </head>
   <body>
      <applet code="applet.testApplet.class" width="500" height="300" archive="mysql-connector-java-5.1.18-bin.jar">
      </applet>
   </body>
</html>

我假设出现此安全错误是因为小程序无法访问本地资源,除非您“签名”或“更改本地安全策略”。但是我所有的文件都位于网络服务器上,并且小程序请求也位于网络服务器上的 jar 文件。

所以,我在这里看不到本地文件请求,但仍然收到此错误。你能给我一些建议吗?

4

1 回答 1

1

“通常,未签名的 Java 小程序或应用程序只能连接回它们所源自的 Web 服务器。此限制可防止小程序通过快速连接到 Internet 上的任意机器而导致拒绝服务攻击。”

测试时,请确保您与网络服务器位于同一域中。 file:///.../appletTest.html即使您正在访问本地主机也不会工作。

那行:String url = "jdbc:mysql://localhost:3306/testdb";将需要更改为您的网络服务器的地址。

[编辑] 每次paint()调用都打开一个新连接不是很傻吗?

[编辑] 我更仔细地阅读了您的帖子。问题是您无法访问 jar 文件。最简单的方法是将驱动程序打包在与小程序相同的 jar 中。

于 2013-02-25T18:43:32.933 回答