繁体   English   中英

更改用户权限时刷新 MySQL 连接 object

[英]Refresh MySQL connection object when privileges are changed for a user

我有一个 object 与用户名:'user'MySql中的数据库的连接,现在我已经明确更改了该'用户'的一些用户权限,但它没有对现有连接对象生效。 此权限更改仅适用于新连接 object。

例如:我有一个分配了所有权限的连接对象(conn),现在我更改了同一个连接对象(conn)的说(写/读)权限,但该对象(conn)仍然能够执行选择/插入操作.

当用户的任何权限发生更改时,是否有办法自动刷新连接 object。

我为你找到了这个 class,它可能会帮助https://www.codota.com/code/java/methods/android.database.DataSetObservable/notifyChanged但在你的地方我不会在 ZA2668CFFDE69ACBD1 中保存任何信息也许。 您可以尝试创建将包含用户信息的表,并在您需要仅为特权用户运行某些方法时检查此信息。 在我的旧项目中,我创建了这个表:

表用户

表访问权限

并创建检查 access_right 到管理员面板等功能的方法

function 示例:

public class Blog extends Initialization {
   private boolean stop;
   private Statement st;
   private ResultSet rs;
   private String login;
   private BufferedReader reader;
   private BufferedWriter writer;

   Blog(Statement st, String login, BufferedReader reader, BufferedWriter writer) {
    this.st = st;
    this.login = login;
    this.reader = reader;
    this.writer = writer;
}
private void checkRightsToCallAdministrationPanel() {
    try {
        String access_rightsString = "";

        rs = st.executeQuery("SELECT access_id FROM users WHERE login='" + login + "';");
        while (rs.next()) {
            access_rightsString = rs.getString(1);
        }

        if (Integer.parseInt(access_rightsString) < 3) {
            callAdministrationPanel();
        } else {
            writer.write("No such variant\n");
            writer.flush();
        }
    } catch (IOException | SQLException e) {
        e.printStackTrace();
    }
  }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM