用户、用户权限等如何用程序定义?-钱玉炜
Access软件网QQ交流学习群(群号码198465573),欢迎您的加入!
首页 >技术文章> 综合其它


用户、用户权限等如何用程序定义?

发表时间:2007/11/7 8:44:38 评论(0) 浏览(8662)  评论 | 加入收藏 | 复制
   
摘 要:用户、用户权限等如何用程序定义?
正 文:
转自 Access911

在Access中添加用户,定义权限的方法很多,基本有以下几种

DAO方面有:
Group对象
User对象
Permissions属性
AllPermissions属性

ADO(ADOX)方面有:
Catalog对象
User对象
Group对象
SetPermissions方法
GetPermissions方法

Jet SQL(DDL)方面有:
Add User语句
Create Group语句
Create User语句
Drop User语句
Drop Group语句
Alter User语句
Alter Database语句

上述几方面在Access的帮助中都有详细的代码示例以及叙述。


Function Test()
    Debug.Print GetCurrentUserGroups
    Debug.Print GetAllUserGroups
End Function


Function GetCurrentUserGroups()
'请到 Alt + F11 到 VBE 界面下
'菜单 -> 工具 -> 引用
'Microsoft ADO Ext. 2.? for DDL and Security

'本函数获取当前用户所属的用户组的名称

    Dim catDB As New ADOX.Catalog
    Set catDB.ActiveConnection = CurrentProject.Connection
    Dim i As Long
    Dim i1 As Long
    Dim u As ADOX.User
    Dim g As ADOX.Groups
   
    For i = 0 To catDB.Users.Count - 1
        If catDB.Users(i).Name = Application.CurrentUser Then
            Set u = catDB.Users(i)
            For i1 = 0 To u.Groups.Count - 1
                Debug.Print u.Groups(i).Name
                GetCurrentUserGroups = GetCurrentUserGroups & u.Groups(i).Name & ","
            Next
        End If
    Next
End Function


Function GetAllUserGroups()
'请到 Alt + F11 到 VBE 界面下
'菜单 -> 工具 -> 引用
'Microsoft ADO Ext. 2.? for DDL and Security

'本函数获取所有用户所属的用户组的名称

    Dim catDB As New ADOX.Catalog
    Set catDB.ActiveConnection = CurrentProject.Connection
    Dim i As Long
    Dim i1 As Long
    Dim u As ADOX.User
    Dim g As ADOX.Groups
   
    For i = 0 To catDB.Users.Count - 1
        
            Set u = catDB.Users(i)
            GetAllUserGroups = GetAllUserGroups & "UserName:" & u.Name & vbCrLf & Chr(9) & " @ Groups:"
            For i1 = 0 To u.Groups.Count - 1
                Debug.Print u.Groups(i).Name
                GetAllUserGroups = GetAllUserGroups & u.Groups(i).Name & ","
            Next
            GetAllUserGroups = GetAllUserGroups & vbCrLf
    Next
End Function

'===================================

'该函数用来判断用户是否存在于指定的安全组
'
'当用户属于指定的安全组时,返回 True ,否则返回 False
'注:当用户属于“管理员组(Admins)”时,函数始终返回 True
'
'参数:  UsrName  - 指定的用户名(为""时,取当前用户)
'        UsrGroup - 指定的安全组
'-----------------------------------------------------------

Function UserInGroup(UsrName As String, UsrGroup As String) As Boolean

    UserInGroup = False
Dim UsrNameStr As String
    Dim wrkDefault As Workspace
    Dim usrLoop As User
    Dim grpLoop As Group

    If UsrName = "" Then
        UsrNameStr = CurrentUser()
    Else
        UsrNameStr = UsrName
    End If

    Set wrkDefault = DBEngine.Workspaces(0)

    With wrkDefault

        For Each grpLoop In .Groups

            If grpLoop.Users.Count <> 0 Then

                For Each usrLoop In grpLoop.Users

                    If usrLoop.Name = UsrNameStr Then
                        If (grpLoop.Name = UsrGroup) Or (grpLoop.Name = "Admins") Then
                        'If grpLoop.Name = UsrGroup Then
                            'Debug.Print grpLoop.Name
                            UserInGroup = True
                        End If
                    End If

                Next usrLoop

            End If

        Next grpLoop

    End With

End Function

这是根据 MS Access 帮助中的例子改的,希望大家能有帮助。更希望有高人能帮我把这个函数再优化一下,将不胜感激!!


Access软件网交流QQ群(群号:198465573)
 
 相关文章
【Access小品】权限麻雀  【todaynew  2010/3/11】
用户权限管理之窗体级及字段级权限管理的实现  【小魏  2011/2/2】
【access小品】通用菜单权限设置  【煮江品茶  2011/8/20】
SQL Server 2005 控制用户权限访问表  【风行  2012/8/7】
快速开发平台用户角色\权限管理功能中权限列表管理  【一杯绿茶  2013/6/1】
【快速平台】关于1.7.0和1.7.1版本没有使用权限的解决办法  【123木头人  2013/11/27】
常见问答
技术分类
相关资源
文章搜索
关于作者

钱玉炜

文章分类

文章存档

友情链接