gpt4 book ai didi

derby - 无法为我的嵌入式数据库设置身份验证和授权

转载 作者:行者123 更新时间:2023-12-02 09:46:12 25 4
gpt4 key购买 nike

我已经阅读了Derby文档,但找不到任何解决方案。
我想在应用程序中为数据库设置用户ID和密码。

我在连接URL中提供了用户和密码选项,但是当我尝试再次使用任何密码打开它时,它仍在打开。网址如下

DriverManager.getConnection(
"jdbc:derby:database;user=admin;password=1234;create=true;");

最佳答案

只有具有用户名和密码的数据库url无效。您必须先设置一个嵌入式数据库,然后设置不同的属性才能使用Derby的内置用户身份验证和用户授权来启用用户身份验证。

您可以在其文档中阅读有关derby授权的信息-
https://db.apache.org/derby/docs/10.4/devguide/cdevcsecure36595.html#cdevcsecure36595

创建嵌入式数据库后,必须启用身份验证。

您可以使用此方法来设置身份验证-

public static void turnOnBuiltInUsers(Connection conn) throws SQLException {
System.out.println("Turning on authentication.");
Statement s = conn.createStatement();

// Setting and Confirming requireAuthentication
s.executeUpdate("CALL SYSCS_UTIL.SYSCS_SET_DATABASE_PROPERTY(" +
"'derby.connection.requireAuthentication', 'true')");
ResultSet rs = s.executeQuery(
"VALUES SYSCS_UTIL.SYSCS_GET_DATABASE_PROPERTY(" +
"'derby.connection.requireAuthentication')");
rs.next();
System.out.println("Value of requireAuthentication is " +
rs.getString(1));
// Setting authentication scheme to Derby
s.executeUpdate("CALL SYSCS_UTIL.SYSCS_SET_DATABASE_PROPERTY(" +
"'derby.authentication.provider', 'BUILTIN')");

// Creating some sample users
s.executeUpdate("CALL SYSCS_UTIL.SYSCS_SET_DATABASE_PROPERTY(" +
"'derby.user.sa', 'ajaxj3x9')");
s.executeUpdate("CALL SYSCS_UTIL.SYSCS_SET_DATABASE_PROPERTY(" +
"'derby.user.guest', 'java5w6x')");
s.executeUpdate("CALL SYSCS_UTIL.SYSCS_SET_DATABASE_PROPERTY(" +
"'derby.user.mary', 'little7xylamb')");

// Setting default connection mode to no access
// (user authorization)
s.executeUpdate("CALL SYSCS_UTIL.SYSCS_SET_DATABASE_PROPERTY(" +
"'derby.database.defaultConnectionMode', 'noAccess')");
// Confirming default connection mode
rs = s.executeQuery (
"VALUES SYSCS_UTIL.SYSCS_GET_DATABASE_PROPERTY(" +
"'derby.database.defaultConnectionMode')");
rs.next();
System.out.println("Value of defaultConnectionMode is " +
rs.getString(1));

// Defining read-write users
s.executeUpdate("CALL SYSCS_UTIL.SYSCS_SET_DATABASE_PROPERTY(" +
"'derby.database.fullAccessUsers', 'sa,mary')");

// Defining read-only users
s.executeUpdate("CALL SYSCS_UTIL.SYSCS_SET_DATABASE_PROPERTY(" +
"'derby.database.readOnlyAccessUsers', 'guest')");

// Confirming full-access users
rs = s.executeQuery(
"VALUES SYSCS_UTIL.SYSCS_GET_DATABASE_PROPERTY(" +
"'derby.database.fullAccessUsers')");
rs.next();
System.out.println("Value of fullAccessUsers is " + rs.getString(1));

// Confirming read-only users
rs = s.executeQuery(
"VALUES SYSCS_UTIL.SYSCS_GET_DATABASE_PROPERTY(" +
"'derby.database.readOnlyAccessUsers')");
rs.next();
System.out.println("Value of readOnlyAccessUsers is " +
rs.getString(1));

// We would set the following property to TRUE only
// when we were ready to deploy.
s.executeUpdate("CALL SYSCS_UTIL.SYSCS_SET_DATABASE_PROPERTY(" +
"'derby.database.propertiesOnly', 'false')");
s.close();
}

您可以使用此链接来完成相同的快速示例。

关于derby - 无法为我的嵌入式数据库设置身份验证和授权,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48056633/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com