Доступ к локальной клиентской базе данных с помощью Java-апплета
Я пытаюсь создать Java-апплет, который подключается к базе данных на стороне клиента и выполняет какой-то запрос.
Апплет должен использовать JDBC... поэтому я реализовал очень простое соединение JDBC с файлом базы данных, расположенным на моем диске C:/.
После подписания приложения (без подписи приложения, множества предупреждений и стен безопасности) я застрял в этой ошибке: "В этом экземпляре JVM запрещен вызов Liveconnect для Applet ID 1 в этом экземпляре"
Кто-нибудь знает более простой способ потоковой передачи и получения результатов из клиентской базы данных через веб-браузер? Или кто-нибудь знает, почему это происходит?
Мои коды: AppletStart.java (Клиентская сторона - Апплет)
public class AppletStart extends Applet {
private static final long serialVersionUID = -2032951133100677643L;
public void queryDatabase(final String databaseFilePath, final String databaseQuery) {
AccessController.doPrivileged(new PrivilegedAction<Object>() {
public Object run() {
JDBCBean jdbcTest = new JDBCBean();
jdbcTest.setDatabaseFilePath(databaseFilePath);
jdbcTest.setDatabaseQuery(databaseQuery);
try {
buildResult(jdbcTest.queryDatabase());
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
});
}
public void buildResult(ResultSet resultSet) throws SQLException {
ResultSetMetaData metaData = resultSet.getMetaData();
int columns = metaData.getColumnCount();
String text = "";
while (resultSet.next()) {
for (int i = 1; i <= columns; ++i) {
text += "" + metaData.getColumnName(i) + ":\t";
text += resultSet.getString(i);
text += "\n";
}
text += "\n";
}
alert(text);
}
public void alert(String text) {
try {
JSObject window = JSObject.getWindow(this);
window.call("showAlert", new Object[] { text });
} catch (JSException jse) {
jse.printStackTrace();
}
}
}
JDBCBean.java (сторона клиента - апплет):
public class JDBCBean {
private static String JDBC_DRIVER = "sun.jdbc.odbc.JdbcOdbcDriver";
private static String CONN_STRING_FRAGMENT = "jdbc:odbc:Driver={Microsoft Access Driver (*.mdb)};DBQ=";
private Connection connection;
private Statement statement;
private String databaseFilePath;
private String databaseQuery;
public void setDatabaseFilePath(String databaseFilePath) {
this.databaseFilePath = databaseFilePath;
}
public void setDatabaseQuery(String databaseQuery) {
this.databaseQuery = databaseQuery;
}
public ResultSet queryDatabase() {
try {
Class.forName(JDBC_DRIVER).newInstance();
String connectionString = CONN_STRING_FRAGMENT + databaseFilePath;
connection = DriverManager.getConnection(connectionString, "", "");
buildStatement();
return executeQuery();
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
public void buildStatement() throws SQLException {
statement = connection.createStatement();
}
public ResultSet executeQuery() throws SQLException {
boolean foundResults = statement.execute(databaseQuery);
if (foundResults) {
ResultSet set = statement.getResultSet();
if (set != null)
return set;
}
connection.close();
return null;
}
}
HTML (на стороне сервера):
<body onload="queryDatabase()">
<script>
var databaseFilePath = "C:/test_db.mde";
var databaseQuery = "SELECT * FROM test_table";
function showAlert(text) {
alert(text);
}
function queryDatabase() {
document.dbApplet.queryDatabase(databaseFilePath, databaseQuery);
}
</script>
<applet id="dbApplet" code="br.com.applet.AppletStart" archive="../resources/applet/dbapplet.jar" style="width: 1px; height: 1px; float: left;" mayscript="mayscript"></applet>
</body>
1 ответ
Если вы пытаетесь создать соединение jdbc с локальным хостом из апплета: поскольку подключение к локальной базе данных такое же, как и у удаленного доступа к апплетам (из-за ограничений безопасности), вы должны использовать общие правила:
http://www.oracle.com/technetwork/java/dba-140353.html
Что касается разрешения хоста базы данных - если он не получит доступ через 'localhost' или '127.0.0.1', то вам, вероятно, следует найти другой способ определения пути соединения с локальным хостом.
Если вы пытаетесь получить доступ к файлу для чтения и затем работаете с jdbc, вы должны предоставить права и для этой операции:
http://www.coderanch.com/how-to/java/HowCanAnAppletReadFilesOnTheLocalFileSystem