用二进制进行权限管理

用二进制进行权限管理

直接给例子吧!例子中将讲解 1.权限表示 2.权限判断 3.添加权限 4.取消权限

public class Test {  

    /** 

     * @param args 

     */  

    public static void main(String[] args) {  

  

        /** 

         * 四种权限 ,当前定义为int,以下二进制表示只取后四位作说明 

         */  

  

        // 添加  

        int c = 1;// ...0001  

        // 查询  

        int r = 2;// ...0010  

        // 修改  

        int u = 4;// ...0100  

        // 删除  

        int d = 8;// ...1000  

  

        /** 

         *  

         * 大家可以观察四种权限的二进制表示的规律 ,都是2的N次方, 

         * 就表示本身,添加权限有最后一位为其它为0,查询倒数第二位为1其它都为0,修改倒数第三个为1其它都为0,删除倒数第四个为1其它都为0 

         *  

         */  

  

        /** 

         *1111---- 这样表示有哪种权限时可以用 |(按位或) 操作 

         *  

         */  

  

        // 用户A有添加和修改权限  

        int usera = c | r | u;  

  

        // 用户B有添加和删除权限  

        int userb = c | d;  

  

        /** 

         * 2222---- 判断用户是否有某种权限用用户权限和要判断的权限进行 &(按位与) 操作,结果为要判断的权限值时表示用户有此权限,否则没有此权限 

         */  

  

        if ((usera & u) == u) {  

            System.out.println("用户a有更新权限");  

        } else {  

            System.out.println("用户a没有有更新权限");  

        }  

  

        /** 

         * 3333---- 给用户添加权限用用户权限和要添加的权限|(按位或) 操作再覆盖之前权限值 

         */  

  

        if ((userb & u) == u) {  

            System.out.println("用户b有更新权限");  

        } else {  

            System.out.println("用户b没有更新权限");  

        }  

  

        // 给用户b添加更新权限  

        userb = userb | u;  

  

        if ((userb & u) == u) {  

            System.out.println("用户b有更新权限");  

        } else {  

            System.out.println("用户b没有更新权限");  

        }  

  

        /** 

         * 4444---- 取消用户某种权限,用用户权限和要取消的权限按位取反后进行按位 操作,再覆盖之前权限值 

         */  

          

        if ((usera & r) == r) {  

            System.out.println("用户a有查询权限");  

        } else {  

            System.out.println("用户a没有查询权限");  

        }  

          

        //取消用户a的查询权限  

        usera = usera & (~r);  

          

        if ((usera & r) == r) {  

            System.out.println("用户a有查询权限");  

        } else {  

            System.out.println("用户a没有查询权限");  

        }  

    }  

  

 

转载于:https://www.cnblogs.com/caojinqin/p/tao310.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,针对给二进制安装的 MySQL,可以按照以下步骤进行配置: 1. 首先,进入 MySQL 的安装目录,例如:/usr/local/mysql/bin。 2. 使用以下命令进入 MySQL 的命令行界面: ``` ./mysql -u root -p ``` 这里的 -u 表示用户名,-p 表示需要输入密码登录。 3. 进入 MySQL 命令行后,可以进行一些基本的操作,例如创建数据库、创建用户等等。以下是一些常用的操作命令: - 创建数据库: ``` CREATE DATABASE database_name; ``` - 创建用户: ``` CREATE USER 'user_name'@'localhost' IDENTIFIED BY 'password'; ``` - 授予用户权限: ``` GRANT ALL PRIVILEGES ON database_name.* TO 'user_name'@'localhost'; ``` 4. 配置 MySQL 的相关参数,例如字符集、端口等等,可以在 MySQL 的配置文件中进行修改。配置文件的位置一般为 /etc/my.cnf。 例如,如果需要将 MySQL 监听的端口修改为 3307,可以在 [mysqld] 段添加以下配置: ``` port=3307 ``` 另外,如果需要修改 MySQL 的字符集为 UTF-8,可以在 [mysqld] 段添加以下配置: ``` character-set-server=utf8 ``` 修改完配置文件后,需要重启 MySQL 才能生效: ``` ./mysql.server restart ``` 注意,这里的 ./mysql.server 是 MySQL 的启动脚本,需要在 MySQL 的 bin 目录下执行。如果你的 MySQL 的启动脚本名称不同,需要相应地修改。 希望这些步骤可以帮助你进行 MySQL 的系统管理。如果你有其他问题,欢迎继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值