Есть ли способ для MS Access захватить текущего пользователя Active Directory?

Я работаю над спецификацией для программного обеспечения для моей компании и, как часть системы аудита, думаю, было бы неплохо, если бы был способ получить текущего пользователя Active Directory.

Надеюсь, что-то вроде:

Dim strUser as String
strUser = ActiveDirectory.User()
MsgBox "Welcome back, " & strUser
12.08.2008 17:03:28
4 ОТВЕТА
РЕШЕНИЕ

Попробуйте эту статью - у меня есть код на работе, который будет ... работает, если это не так ...

Соответствующая цитата:

Private Declare Function GetUserName Lib "advapi32.dll" Alias "GetUserNameA" _
                    (ByVal IpBuffer As String, nSize As Long) As Long
Private Declare Function GetComputerName Lib "kernel32" Alias "GetComputerNameA" _
                    (ByVal lpBuffer As String, nSize As Long) As Long

Function ThisUserName() As String
    Dim LngBufLen As Long
    Dim strUser As String

    strUser = String$(15, " ")
    LngBufLen = 15

    If GetUserName(strUser, LngBufLen) = 1 Then
        ThisUserName = Left(strUser, LngBufLen - 1)
    Else
        ThisUserName = "Unknown"
    End If
End Function

Function ThisComputerID() As String
    Dim LngBufLen As Long
    Dim strUser As String

    strUser = String$(15, " ")
    LngBufLen = 15

    If GetComputerName(strUser, LngBufLen) = 1 Then
        ThisComputerID = Left(strUser, LngBufLen)
    Else
        ThisComputerID = 0
    End If
End Function
6
7.04.2017 06:09:33
Я
Tobias Kienzler 7.04.2017 06:10:09
Все хорошо. Был довольно дерьмовый ответ на размышления. Были первые дни, но не просто связать ответы, вещи не были такими жесткими, как сегодня, в мою защиту;) В любом случае, спасибо за редактирование.
JamesSugrue 9.04.2017 21:15:13

В зависимости от переменных среды оставаться действительными - плохая идея, поскольку их можно легко изменить в пользовательском сеансе.

2
10.03.2009 04:15:35

Дэвид очень хорошо высказался по поводу риска использования переменных среды. Я могу только добавить, что могут быть другие проблемы с переменными среды. Просто посмотрите на этот фрагмент кода из нашего 5-летнего проекта:

Public Function CurrentWorkbenchUser() As String

    ' 2004-01-05, YM: Using Application.CurrentUser for identification of 
    ' current user is very problematic (more specifically, extremely 
    ' cumbersome to set up and administer for all users). 
    ' Therefore, as a quick fix, let's use the OS-level user's 
    ' identity instead (NB: the environment variables used below must work fine
    ' on Windows NT/2000/2003 but may not work on Windows 98/ME)
    ' CurrentWorkbenchUser = Application.CurrentUser
    '
    ' 2005-06-13, YM: Environment variables do not work in Windows 2003. 
    ' Use Windows Scripting Host (WSH) Networking object instead.
    ' CurrentWorkbenchUser = Environ("UserDomain") & "\" & Environ("UserName")
    '
    ' 2007-01-23, YM: Somewhere between 2007-01-09 and 2007-01-20, 
    ' the WshNetwork object stopped working on CONTROLLER3. 
    ' We could not find any easy way to fix that.
    ' At the same time, it turns out that environment variables 
    ' do work on Windows 2003.
    ' (Apparently, it was some weird configuration problem back in 2005: 
    ' we had only one Windows 2003 computer at that time and it was 
    ' Will's workstation).
    '
    ' In any case, at the time of this writing, 
    ' returning to environment variables 
    ' appears to be the simplest solution to the problem on CONTROLLER3.
    ' Dim wshn As New WshNetwork
    ' CurrentWorkbenchUser = wshn.UserDomain & "\" & wshn.UserName

    CurrentWorkbenchUser = Environ("USERDOMAIN") & "\" & Environ("USERNAME")

End Function
2
3.04.2015 16:12:36
В CurrentUser () нет ничего плохого, если вы на самом деле используете безопасность уровня пользователя Jet. С другой стороны, если у вас нет необходимости в Jet ULS, то вход в Windows является отличной альтернативой (хотя вам все еще может потребоваться поддерживать некоторую таблицу членства в группах в вашем приложении).
David-W-Fenton 31.10.2008 01:04:09

Вот моя версия: она будет загружать все что угодно:

'gets firstname, lastname, fullname or username
Public Function GetUser(Optional whatpart = "username")
    Dim returnthis As String
    If whatpart = "username" Then GetUser = Environ("USERNAME"): Exit Function
    Set objSysInfo = CreateObject("ADSystemInfo")
    Set objUser = GetObject("LDAP://" & objSysInfo.USERNAME)
    Select Case whatpart
        Case "fullname": returnthis = objUser.FullName
        Case "firstname", "givenname": returnthis = objUser.givenName
        Case "lastname": returnthis = objUser.LastName
        Case Else: returnthis = Environ("USERNAME")
    End Select
    GetUser = returnthis
End Function

Я получил оригинальную идею от Spiceworks .

4
7.04.2017 06:10:57