这段百度问答,对我相关有对啊!!!----如何获取Windows系统登陆用户名

如何获取Windows系统登陆用户名

http://zhidao.baidu.com/link?url=Hva9PkVwYZv8KSEWftSqTWe8fqM1dhoq59BurnfADmcOvFjFgJUONb2kQ4KrJUF5KjOTXjCf5SQKYNLhcU_dBMzGGBxFxJCRfxCmamIjUji

=======================

一般用 GetUserName(或 GetUserNameEx )函数可得到当前登陆登陆用户名(但不总会得到,下面会分析),此系统函数在Win95、WinNT 及以后所有操作系统中都可用。代码如下:BOOL CSecurityTool::GetCurrProcessUser(CString& strName){		BOOL bRet(TRUE);	strName = _T("");

	DWORD dwSize = MAX_PATH;	TCHAR *pszName = new TCHAR[dwSize];	if (!GetUserName(pszName, &dwSize))	{		delete[] pszName;		pszName = new TCHAR[dwSize];		bRet = GetUserName(pszName, &dwSize);	}

	strName = pszName;	delete[] pszName;			return bRet;}        此函数目的准确来说是获取当前线程的用户名(MSDN语:retrieves the user name of the current thread)。如果是NT service(NT服务程序)将此进程启动,得到的结果是NT Service进程的用户名,即“SYSTEM”,而不是登陆用户名;同理,如果此进程是通过CreateProcessAsUser创建的,GetUserName获取的用户将是“AsUser”的用户名。另外,如果当前线程正impersonate其他用户环境(用函数ImpersonateLoggedOnUser可达到此目的),它获取的将是其他用户名。因此,此函数只能在特定环境中才可以获取登陆用户名。   那如何不因进程本身运行环境的不同,而准确地获取登陆用户名呢?   我们首先看看Windows XP操作系统,它提供了WTSQuerySessionInformation函数,这个函数可以获取会话(session)相关信息,其中一个用途是获取会话的登陆用户。代码如下:BOOL CSecurityTool::GetLogUserXP(CString& strName){	BOOL bRet = FALSE;	strName = _T("");

	//for xp or above	TCHAR *szLogName = NULL;	DWORD dwSize = 0;	if (WTSQuerySessionInformation(WTS_CURRENT_SERVER_HANDLE,	                               WTS_CURRENT_SESSION,	                               WTSUserName,	                               &szLogName,	                               &dwSize))	{					strName = szLogName;		WTSFreeMemory(szLogName);		bRet = TRUE;	}

	return bRet;}        如果用户还没有登陆,获取的用户名将为空(譬如在NT service程序中)。虽然MSDN中指明WTSQuerySessionInformation可以在win2000 pro 中使用,但由于安装win2000 professional时,terminal service是没有安装的(除非用特殊方法如第三方工具可以安装terminal service),所以调用此函数会失败,需要寻找其他方法。   再看Win2000:查阅了许多资料,未能发现在Win2000中直接获取登陆用户名的系统函数,看来只有曲线救国了。由于Explorer.exe进程的用户肯定是当前登陆用户,所以获取到它的用户名就等于获取到登陆用户名。具体实现:首先枚举系统所有进程,找到Explorer.exe进程ID,然后通过ID获取此进程的令牌(Token),再获取令牌的用户信息,即为登陆用户名。代码如下://获取win2000登陆用户      BOOL CSecurityTool::GetLogUser2K(CString& strName){	BOOL bRet = FALSE;	HANDLE hSnapshot = NULL;	strName = _T("");

    __try	{		// Get a snapshot of the processes in the system        hSnapshot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);        if (hSnapshot == NULL)		{            			__leave;		}

        PROCESSENTRY32 pe32;        pe32.dwSize = sizeof(pe32);

        // Find the "System" process        BOOL fProcess = Process32First(hSnapshot, &pe32);        while (fProcess)		{			if (lstrcmpi(pe32.szExeFile, TEXT("explorer.exe")) == 0)			{					TCHAR szUserName[MAX_PATH];				if (GetProcessUser(pe32.th32ProcessID, szUserName, MAX_PATH))				{					bRet = TRUE;					strName = szUserName;				}

				break;			}			fProcess = Process32Next(hSnapshot, &pe32);		}        if (!fProcess)		{			            __leave;    // Didn‘‘t find "System" process		}	}    __finally	{		// Cleanup the snapshot       if (hSnapshot != NULL)		   CloseHandle(hSnapshot);    }

	return bRet;	}

//获取进程的用户名BOOL CSecurityTool::GetProcessUser(DWORD dwProcessID, TCHAR *szUserName, DWORD nNameLen){	BOOL fResult  = FALSE;    HANDLE hProc  = NULL;	HANDLE hToken = NULL;	TOKEN_USER *pTokenUser = NULL;

	__try	{        // Open the process with PROCESS_QUERY_INFORMATION access        hProc = OpenProcess(PROCESS_QUERY_INFORMATION, FALSE, dwProcessID);        if (hProc == NULL)		{			__leave;		}        fResult = OpenProcessToken(hProc, TOKEN_QUERY, &hToken);        if(!fResult)  		{			__leave;		}

		DWORD dwNeedLen = 0;				fResult = GetTokenInformation(hToken,TokenUser, NULL, 0, &dwNeedLen);		if (dwNeedLen > 0)		{			pTokenUser = (TOKEN_USER*)new BYTE[dwNeedLen];			fResult = GetTokenInformation(hToken,			                              TokenUser,			                              pTokenUser,			                              dwNeedLen,			                              &dwNeedLen);			if (!fResult)			{				__leave;			}		}		else		{			__leave;		}

		SID_NAME_USE sn;		TCHAR szDomainName[MAX_PATH];		DWORD dwDmLen = MAX_PATH;		fResult = LookupAccountSid(NULL,		                           pTokenUser->User.Sid,		                           szUserName,		                           &nNameLen,                                   szDomainName,                                   &dwDmLen,                                   &sn);	}	__finally	{		if (hProc)			::CloseHandle(hProc);		if (hToken)			::CloseHandle(hToken);		if (pTokenUser)			delete[] (char*)pTokenUser;

		return fResult;	}}        熟悉win2000系统的同仁肯定会发现此方法存在缺陷:explorer.exe进程可能不存在(被用户kill掉或自己中断了),这时候这个方法就获取不到登陆用户名。但在没有更好方法前,只能将就。 

总结  因此,软件中如果需要获取登陆用户名,要根据具体情况选择不同的方法。如果确信自己的进程一定在登陆用户环境下启动,则GetUserName即可;否则,需要采用后面的两种方法,当然,在使用前需要判断一下操作系统的类型。
时间: 2024-10-13 09:17:57

这段百度问答,对我相关有对啊!!!----如何获取Windows系统登陆用户名的相关文章

怎样处理百度快照百度知道百度问答

百度知道里面永久处理我的提问的方法如下: 在电脑上登录百度知道账号, 进入百度知道首页, 在右上角找到自己的账号,然后点击我的提问, 找到自己有清除的问题,点击进入, 在问题页面点击关闭问题, 在弹出的提示框中点击确定即可. 联系在线qq821154632 快速清除百度知道,百度快照,百度问答等等.负面信息负面帖子都可以清除.

获取Java系统相关信息

1 package com.test; 2 3 import java.util.Properties; 4 import java.util.Map.Entry; 5 6 import org.junit.Test; 7 8 public class SystemTest { 9 10 /** 11 * 获取Java系统相关信息 12 * @throws Exception 13 */ 14 @Test 15 public void testSys() throws Exception { 1

[HOSTS相关]Windows系统-HOSTS文件-位置

如下,hosts文件在\etc这个目录里面: C:\Windows\System32\drivers\etc 还有一种方式找到hosts文件,如下: 在地址栏内输入%systemroot%\system32\drivers\etc,然后回车,就可以看到hosts文件了. 如果你经常会修改这个文件,那么右键发送到桌面快捷方式即可. [HOSTS相关]Windows系统-HOSTS文件-位置

段寄存器与逻辑地址的相关内容

寄存器操作数:(存放在CPU中) MOV AX,0FFFFH AX 即为寄存器操作数. 操作数本身存放于寄存器中,在指令中只是给出了几个位的代码来表示它具体存放在那个寄存器中. 内存中的数据经过寄存器读入CPU,进入数据的运算. 内存操作数:(存放在内存中) 其存储于某内存区域,因此叫内存操作数. mydata dw 1234H 或 mydata db 12H等 上述中mydata这样的变量 xx db 0FFH,0 mov bx, OFFSET xx //用offset运算符计算出xx单元的偏

[百度空间] [转]将程序移植到64位Windows

from : http://goooder.bokee.com/2000373.html (雷立辉 整理) 简介:本文对如何将32位Windows程序平滑的支持和过渡到64位Windows操作系统做出了一个简单而系统的介绍.包括对于64位操作系统的版本,编程模型,一些移植原则甚至包括对驱动程序的移植原则的介绍. 作者介绍:系统分析员,现在在北京工作.作者的blog:http://goooder.blogchina.com. 前言: 或许大家还对32位的CPU及操作系统使用还是觉得非常的合乎日常需

Vue中使用百度地图——根据输入框输入的内容,获取详细地址

知识点:在Vue.js项目中调用百度地图API,实现input框,输入地址,在百度地图上定位到准确地址,获得到经纬度 参考博客:  百度地图的引用,初步了解参考博客:http://blog.csdn.net/docallen/article/details/70877925 详细功能修改参考博客: https://www.cnblogs.com/NearTheSea/p/6808093.html 效果图:在input输入框中,输入要查询的地址,搜索出相关的名字 选中详细地址,地图定位到详细地址

百度链接主动推送代码对在织梦系统中的添加方法

百度站长推出的一个链接提交的工具,支持网站链接的主动推送,在这里面我们有一段织梦系统的测试代码分享给大家,让大家可以在不用谢代码的直接复制皆可以解决.在dede后台的article_add.php文件进行简单的修改,在259行加入如下代码(代码进行简单修改,$url[]=之后单引号内的网址改成自己的站点,$api后引号内的链接修改成,自己站长平台里的主东推送链接). else{$urls[]='https://www.jianzhumuju.com/'.$artUrl;$api = 'http:

百度地图_根据地图上标记位置获取街道信息,以及经纬度信息

Class:服务类/Geocoder Class:服务类/GeocoderResult <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>百度地图Demo</title> <script type="text/jav

windows 系统相关配置

1. 外接显示器分辨率调节:连接上外接下显示器,在本机空白处,右键,分辨率.然后选择显示器,设置显示相关配置. 详见:http://zhidao.baidu.com/question/134948066.html?qbl=relate_question_1&optimi=4