@username 问题,bug还是理解错误
写一个msgbox(0,"",@username),并编译为test.exe,若登陆账号用户为a,运行test.exe,msgbox(0,"",@username),则显示为a;
若登陆账号用户为a,RunAs(“b”, @ComputerName, $sPassword, 0, test.exe, @SystemDir),msgbox(0,"",@username),则显示为b;
问题,请问,怎样写才能真正显示当前的登陆名??@username似乎手到运行它的身份的用户名限制,不能真正的反映出当前的登录名
谢谢大家,不知道哪位哥们告知调用dll,怎么写,多谢 在论坛上搜索到gaoyuan22 的回答:
RegRead("Hkey_current_user\software\microsoft\windows\currentversion\explorer", "logon user name")
这种方法仅适用于winxp 还想到一个思路:比较c:\users 下面,哪个文件名最新修改时间即为最新的登陆名 本帖最后由 pusofalse 于 2011-10-17 18:40 编辑
不是BUG,理解错误。 @UserName表示的是当前线程所属的用户,在调用某些 模拟安全场景一类的系统函数之后,@UserName的值就会改变,变成模拟成功的用户的名称。测试以下代码便知,以下代码在模拟用户安全场景的过程中,输出的MsgBox对话框会有些卡,这是因为桌面没有开放 对指定用户读取桌面对象的权限。如果模拟用户之后,不涉及到与桌面进行交互的操作,完全可以把MsgBox改成ConsoleWrite一类的函数。
#include <lsasecur.au3>
MsgBox(0, "当前线程用户", "@UserName = " & @UserName)
If _SeIsUserAdmin() Then
; 模拟系统级安全场景
$hSystemToken = _SeImpersonateSystemContext( ProcessExists("lsass.exe"))
; 这里可以用 $hSystemToken 做某些事情,比如用它来创建一个系统级进程。
_SeCloseHandle($hSystemToken)
MsgBox(0, "模拟系统级安全场景", "@UserName = " & @UserName)
; 恢复模拟。
_SeRevertToSelf()
MsgBox(0, "恢复模拟", "@UserName = " & @UserName)
Local $sRandomName = String(Random(1000, 1000000, 1))
Local $sRandomPswd = String(Random(1000, 1000000, 1))
$sPrompt = StringFormat("是否创建一个账户名为 %s,密码为 %s 的本地用户,并模拟它的安全场景?", $sRandomName, $sRandomPswd)
If MsgBox(52, "确认", $sPrompt) = 6 Then
; 创建临时用户,用于测试模拟安全场景。
_SeCreateLocalUser($sRandomName, $sRandomPswd)
; 登录到 $sRandomName,并获取它的安全令牌。
$hUserToken = _SeLogonUser($sRandomName, $sRandomPswd, $SE_LOGON32_LOGON_INTERACTIVE)
; 模拟 $sRandomName 用户的安全场景。
_SeImpersonateLoggedOnUser($hUserToken)
; 这里可以用 $hUserToken 创建一个 $sRandomName 用户场景下的进程。
_SeCloseHandle($hUserToken)
MsgBox(0, "模拟 " & $sRandomName, "@Username = " & @UserName)
; 恢复模拟,@UserName 将恢复为原来的值。
_SeRevertToSelf()
; 删除临时测试用的本地用户。
_SeDeleteLocalUser($sRandomName)
EndIf
EndIf
; 枚举系统中的所有登录会话。
$aLogonSession = _SeEnumLogonSessions()
; __SeArrayDisplay($aLogonSession)
Local $sUserLogon
For $i = 1 To $aLogonSession
If $aLogonSession[$i] = $SE_LOGON_TYPE_INTERACTIVE Then
$sUserLogon &= $aLogonSession[$i] & @CRLF
EndIf
Next
If Not _SeIsUserAdmin() Then
$sUserLogon &= @CRLF & "本进程不具管理员权限,以上用户可能有遗漏。"
EndIf
MsgBox(0, "当前已登录到桌面的用户", $sUserLogon) 感谢p老大的解释
页:
[1]