手机
当前位置:查字典教程网 >编程开发 >asp.net教程 >.net 运用二进制位运算进行数据库权限管理
.net 运用二进制位运算进行数据库权限管理
摘要:权限分为增、删、改、查,数据库插入拥有权限的数值的和。比如拥有增加和修改功能,就是:Permissions.Add+Permissions....

权限分为增、删、改、查,数据库插入拥有权限的数值的和。比如拥有增加和修改功能,就是:Permissions.Add+Permissions.Mod,结果值为:5。

那么判断是否有此权限时,就可以调用IsPermission(value, per)方法。假设结果值为:5,那么如果“添加权限”调用就是:IsPermission(5, Permissions.Add),

返回结果为true;如果“删除权限”调用就是:IsPermission(5, Permissions.Del),返回结果为false。

公用类:

复制代码 代码如下:

/// <summary>

/// 权限设置二进制

/// </summary>

[Flags]

public enum Permissions

{

Add = 1,

Del = 2,

Mod = 4,

Select = 8

}

/// <summary>

/// 判断是否拥有此权限,false=不存在,true=存在

/// </summary>

/// <param name="value">权限类型值</param>

/// <param name="per">操作类型:增删改查</param>

/// <returns>判断是否拥有此权限,false=不存在,true=存在</returns>

public static bool IsPermission(int value, Permissions per)

{

bool bo = false;//默认不存在

switch (per)

{

case Permissions.Add:

if ((value & Convert.ToInt32(Permissions.Add)) == Convert.ToInt32(Permissions.Add))//运算 (value & 1)==1

bo = true;

break;

case Permissions.Del:

if ((value & Convert.ToInt32(Permissions.Del)) == Convert.ToInt32(Permissions.Del))//

bo = true;

break;

case Permissions.Mod:

if ((value & Convert.ToInt32(Permissions.Mod)) == Convert.ToInt32(Permissions.Mod))//

bo = true;

break;

case Permissions.Select:

if ((value & Convert.ToInt32(Permissions.Select)) == Convert.ToInt32(Permissions.Select))//

bo = true;

break;

}

return bo;

}

【.net 运用二进制位运算进行数据库权限管理】相关文章:

上传图片后使用数据库保存图片的示例分享

如何在asp.net中用加密数据库联接字符串保证数据安全?

.net下实现Word动态填加数据打印

asp.net中使用cookie传递参数的方法

常用的在数据库中建立无限级树形菜单的asp.net代码

asp.net 因为数据库正在使用的解决方法

asp.net ListView 数据绑定

Asp.net在线备份、压缩和修复Access数据库示例代码

.Net连接Oracle数据库的实现代码

asp.net连接数据库读取数据示例分享

精品推荐
分类导航