![](/img/trans.png)
[英]Active Directory Authentication of Logged-in User using ADODB/ADSDSOObject
[英]Getting the currently logged-in windows user
我通过谷歌找到了这个: http : //www.mvps.org/access/api/api0008.htm
'******************** Code Start **************************
' This code was originally written by Dev Ashish.
' It is not to be altered or distributed,
' except as part of an application.
' You are free to use it in any application,
' provided the copyright notice is left unchanged.
'
' Code Courtesy of
' Dev Ashish
'
Private Declare Function apiGetUserName Lib "advapi32.dll" Alias _
"GetUserNameA" (ByVal lpBuffer As String, nSize As Long) As Long
Function fOSUserName() As String
' Returns the network login name
Dim lngLen As Long, lngX As Long
Dim strUserName As String
strUserName = String$(254, 0)
lngLen = 255
lngX = apiGetUserName(strUserName, lngLen)
If ( lngX > 0 ) Then
fOSUserName = Left$(strUserName, lngLen - 1)
Else
fOSUserName = vbNullString
End If
End Function
'******************** Code End **************************
这是最好的方法吗?
你也可以这样做:
Set WshNetwork = CreateObject("WScript.Network")
Print WshNetwork.UserName
它还有一个 UserDomain 属性和其他一些东西:
http://msdn.microsoft.com/en-us/library/907chf30(VS.85).aspx
您也可以使用 Environ$ 但问题指定的方法更好。 用户/应用程序可以更改环境变量。
我通常使用 VBA 中的环境,如下所示。 我没有遇到 Ken 提到的可能性问题。
Function UserNameWindows() As String
UserNameWindows = VBA.Environ("USERNAME") & "@" & VBA.Environ("USERDOMAIN")
End Function
替代方法- 您提到的 API 可能是获取用户名的更好方法。
For Each strComputer In arrComputers
Set objWMIService = GetObject("winmgmts:\\" & strComputer & "\root\cimv2")
Set colItems = objWMIService.ExecQuery("Select * from Win32_ComputerSystem",,48)
For Each objItem in colItems
Wscript.Echo "UserName: " & objItem.UserName & " is logged in at computer " & strComputer
Next
其他帖子中有很多替代方法,但要回答这个问题:是的,这是最好的方法。 如果您只需要用户名,则比创建 COM 对象或 WMI 更快,并且在从 Win95 起的所有 Windows 版本中都可用。
有很多方法可以在 WMI 中获取当前登录的用户名。 我的方法是通过'explorer.exe'进程中的用户名获取它,因为当用户登录窗口时,根据当前用户访问该文件。
WMI 脚本如下所示:
Set objWMIService = GetObject("winmgmts:" & "{impersonationLevel=impersonate}!\\" & strIP & "\root\cimv2")
Set colProcessList = objWMIService.ExecQuery("Select * from Win32_Process")
For Each objprocess In colProcessList
colProperties = objprocess.GetOwner(strNameOfUser, strUserDomain)
If objprocess.Name = "explorer.exe" Then
UsrName = strNameOfUser
DmnName = strUserDomain
End If
Next
有关更多详细信息,请查看以下链接:
http://msdn.microsoft.com/en-us/library/aa394599%28v=vs.85%29.aspx
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.