在这个文件上单击右键选择运行方式,然后输入用户名和密码就可以了。选专业的可以用System用户的身份运行任何应用程序,运行后程序将具有更高的权限。
其实这个都是系统system权限都是相对的,不过可以用CreateService创建服务来实现哈!新建一个空的,名为CreateService 控制台工程,再新建一个CreateService.cpp文件,下面代码粘贴进去。。。
#include "Windows.h"
#include "Winsvc.h"
#include "time.h"
#include "stdio.h"
SERVICE_STATUS m_ServiceStatus
SERVICE_STATUS_HANDLE m_ServiceStatusHandle
BOOL bRunning=true
void WINAPI ServiceMain(DWORD argc, LPTSTR *argv)
void WINAPI ServiceCtrlHandler(DWORD Opcode)
BOOL InstallService()
BOOL DeleteService()
void DoTask()
{
//do something here
}
void WINAPI ServiceMain(DWORD argc, LPTSTR *argv)
{
// DWORD status
// DWORD specificError
m_ServiceStatus.dwServiceType = SERVICE_WIN32
m_ServiceStatus.dwCurrentState = SERVICE_START_PENDING
m_ServiceStatus.dwControlsAccepted = SERVICE_ACCEPT_STOP
m_ServiceStatus.dwWin32ExitCode= 0
m_ServiceStatus.dwServiceSpecificExitCode = 0
m_ServiceStatus.dwCheckPoint = 0
m_ServiceStatus.dwWaitHint = 0
//m_ServiceStatus.dwServiceType = SERVICE_AUTO_START
m_ServiceStatusHandle = RegisterServiceCtrlHandler("Service2",ServiceCtrlHandler)
if (m_ServiceStatusHandle == (SERVICE_STATUS_HANDLE)0)
{
return
}
m_ServiceStatus.dwCurrentState = SERVICE_RUNNING
m_ServiceStatus.dwCheckPoint = 0
m_ServiceStatus.dwWaitHint = 0
if (!SetServiceStatus (m_ServiceStatusHandle, &m_ServiceStatus))
{
}
bRunning=true
while(bRunning)
{
Sleep(3000)
//Place Your Code for processing here....
DoTask()
//Sleep(60*1000)
}
return
}
void WINAPI ServiceCtrlHandler(DWORD Opcode)
{
switch(Opcode)
{
case SERVICE_CONTROL_PAUSE:
m_ServiceStatus.dwCurrentState = SERVICE_PAUSED
break
case SERVICE_CONTROL_CONTINUE:
m_ServiceStatus.dwCurrentState = SERVICE_RUNNING
break
case SERVICE_CONTROL_STOP:
m_ServiceStatus.dwWin32ExitCode = 0
m_ServiceStatus.dwCurrentState= SERVICE_STOPPED
m_ServiceStatus.dwCheckPoint = 0
m_ServiceStatus.dwWaitHint= 0
SetServiceStatus (m_ServiceStatusHandle,&m_ServiceStatus)
bRunning=false
break
case SERVICE_CONTROL_INTERROGATE:
break
}
return
}
BOOL InstallService()
{
char strDir[1024]
HANDLE schSCManager,schService
GetCurrentDirectory(1024,strDir)
strcat(strDir,"\\CreateService.exe")
schSCManager = OpenSCManager(NULL,NULL,SC_MANAGER_ALL_ACCESS)
if (schSCManager == NULL)
return false
LPCTSTR lpszBinaryPathName=strDir
schService = CreateService((struct SC_HANDLE__ *)schSCManager,"Service2","MB Service", // service name to display
SERVICE_ALL_ACCESS, // desired access
SERVICE_WIN32_OWN_PROCESS, // service type
SERVICE_DEMAND_START,// start type
SERVICE_ERROR_NORMAL,// error control type
lpszBinaryPathName, // service's binary
NULL,// no load ordering group
NULL,// no tag identifier
NULL,// no dependencies
NULL,// LocalSystem account
NULL) // no password
if (schService == NULL)
return false
CloseServiceHandle((struct SC_HANDLE__ *)schService)
return true
}
BOOL DeleteService()
{
HANDLE schSCManager
SC_HANDLE hService
schSCManager = OpenSCManager(NULL,NULL,SC_MANAGER_ALL_ACCESS)
if (schSCManager == NULL)
return false
hService=OpenService((struct SC_HANDLE__ *)schSCManager,"Service2",SERVICE_ALL_ACCESS)
if (hService == NULL)
return false
if(DeleteService(hService)==0)
return false
if(CloseServiceHandle(hService)==0)
return false
else
return true
}
int main(int argc, char* argv[])
{
if(argc>1)
{
if(strcmp(argv[1],"-i")==0) {
if(InstallService())
printf("\nMB Service Installed Sucessfully\n")
else
printf("\nMB Service has been installed\n")
} else if(strcmp(argv[1],"-d")==0) {
if(DeleteService())
printf("\nMB Service UnInstalled Sucessfully\n")
else
printf("\nInstalled Easin Central Service Not Found\n")
} else {
printf("\nUnknown Switch Usage\nFor Install use Servicetest -i\nFor UnInstall use Servicetest -d\n")
}
}
else
{
SERVICE_TABLE_ENTRY DispatchTable[]={{"Service2",ServiceMain},{NULL,NULL}}
StartServiceCtrlDispatcher(DispatchTable)
}
return 0
}
成功编译后,生成一个CreateService.exe,使用cmd-cd CreateService.exe目录下面,输入CreateService.exe -i安装服务
CreateService.exe -d 删除服务
有点繁琐,然后开始 - 运行 - service.msc 找到,MB Service ,右键启动。
现在到任务管理器里面去看,是不是有个CreateService.exe 【System进程的权限】
默认情况下,我们无法直接在登录对话框上以SYSTEM帐户的身份登录到Windows桌面环境。实际上SYSTEM帐户早就已经“盘踞”在系统中了。想想也是,连负责用户验证的Winlogon、Lsass等进程都是以SYSTEM身份运行的,谁还能有资格检验SYSTEM呢?既然SYSTEM帐户早就已经出现在系统中,所以只需以SYSTEM帐户的身份启动Windows的Shell程序Explorer,就相当于用SYSTEM身份登录Windows了。以SYSTEM帐户的身份启动Explorer
打开命令提示符,输入命令“taskkill /f /im explorer.exe” 并回车,这个命令是结束当前账户explorer即图形用户界面的Shell。然后在命令提示符下继续输入“at time /interactive %systemroot%explorer.exe”并回车。其中“time”为当前系统时间稍后的一个时间,比如间隔一秒,当前系统时间可以在命令提示符下输入“time”命令获得。一秒钟后会重新加载用户配置,以SYSTEM身份启动Windows的shell进程Explorer.exe。
验证exeplorer.exe是否以system权限运行
如何知道exeplorer.exe是以system权限运行呢?
通过“开始”菜单可以看到最上面显示的是system账户。另外,打开注册表编辑器,只要证明HKCU就是HKUS-1-5-18的链接就可以了(S-1-5-18就是SYSTEM帐户的SID)。证明方法很简单:在HKCU下随便新建一个Test子项,然后刷新,再看看HKUS-1-5-18下是否同步出现了Test子项,如果是,就说明系统当前加载的就是SYSTEM帐户的用户配置单元。当然最简单的是在命令提示符号下输入命令“whoami”进行验证,如图所示显示为“NT AUTHORITYSYSTEM”这就证明当前exeplorer.exe是System权限。
System权限的实际用处
System权限的Explorer.exe在实际中有什么用呢?下面笔者随意列举几个使用实例。
(1).注册表访问
我们知道在非SYSTEM权限下,用户是没有权限访问某些注册表项的,比如“HKEY_LOCAL_MACHINESAM”、“HKEY_LOCAL_MACHINESECURITY”等。这些项记录的是系统的核心数据,某些病毒或者木马会光顾这里。比如在SAM项目下建立具有管理员权限的隐藏账户,这样的帐户在命令及“本地用户和组”管理器(lusrmgr.msc)中是无法看到的,造成了很大的安全隐患。在“SYSTEM”权限下,注册表的访问就没有任何障碍,我们打开注册表定位到“HKEY_LOCAL_MACHINESAMSAMDomainsAccount”项下所有的隐藏帐户就都暴露了。
(2)访问系统还原文件
系统还原是windows系统的一种自我保护措施,它在每个磁盘根目录下建立“System Colume Information”文件夹,保存一些系统信息以备系统恢复是使用。该文件具有系统、隐藏属性管理员用户是没有 *** 作权限的。正因为如此,它成了病毒、木马的栖身之地,我们就可以在System权限下进入该文件夹删除病毒。当然,你也可以关闭“系统还原”预防此类病毒,但这样未免显得被动,有些因噎废食。
(3)更换系统文件
Windows系统为系统文件做了保护机制,一般情况下你是不可能更换系统文件的,因为系统中都有系统文件的备份,它存在于c:WINDOWSsystem32dllcache(假设你的系统装在C盘)。当你更换了系统文件后,系统自动就会从这个目录中恢复相应的系统文件。当目录中没有相应的系统文件的时候会d出提示让你插入安装盘。
在实际应用中如果有时你需要Diy自己的系统修改一些系统文件,或者用高版本的系统文件更换低版本的系统文件,让系统功能提升。比如Window XP系统只支持一个用户远程登录,如果你要让它支持多用户的远程登录。要用Windows 2003的远程登录文件替换Window XP的相应文件。这在非SYSTEM权限下很难实现,但是在SYSTEM权限下就可以很容易实现。
从Windows 2003的系统中提取termsrv.dll文件,用该文件替换Windows XP的C:WINDOWSsystem32下的同名文件。(对于Windows XP SP2还必须替换C:WINDOWS$NtServicePackUninstall$和C:WINDOWSServicePackFilesi386目录下的同名文件)。再进行相应的系统设置即可让Windows XP支持多用户远程登录。
(4)手工杀毒
用户在使用电脑的过程中一般都是用Administrator或者其它的管理员用户登录的,中毒或者中马后,病毒、木马大都是以管理员权限运行的。我们在系统中毒后一般都是用杀毒软件来杀毒,如果杀软瘫痪了,或者杀毒软件只能查出来,但无法清除,这时候就只能赤膊上阵,手工杀毒了。
在Adinistrator权限下,如果手工查杀对于有些病毒无能为力,一般要启动到安全模式下,有时就算到了安全模式下也无法清除干净。如果以SYSTEM权限登录,查杀病毒就容易得多。
以一次手工杀毒为例,(为了截图在虚拟机上模拟了前段时间的一次手工杀毒。)打“Windows 任务管理器”,发现有个可疑进程“86a01.exe”,在Administrator管理员下无法结束进程,当然更无法删除在系统目录下的病毒原文件“86a01.exe”。
以System权限登录系统,进程被顺利结束,然后删除病毒原文件,清除注册表中的相关选项,病毒被彻底清理出系统。
总结
System权限是比Administrator权限还高的系统最高权限,利用它可以完成很多常规情况下无法完成的任务。当然,最大的权限也就意味着更大的危险,就好比手握“尚方宝剑”,可不要滥杀无辜呀!在使用过程中建议大家用“系统管理员权限”或者“一般用户权限”,只有在特殊情况下才用System权限
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)