• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

如何利用139端口来远程重起NT服务器

发布: 2007-7-13 15:18 | 作者: korn | 来源: ccidnet | 查看: 57次 | 进入软件测试论坛讨论

领测软件测试网

最近很多朋友问我:NT的机器如果远程管理软件坏了,怎么重起呢?其实,如果服务器的139端口开着,重起是很简单的,步骤如下:

 

1、net use \\xxx.xxx.xxx.xxx\ipc$ password /user:username

建立一个IPC会话

 

2、net use H: \\xxx.xxx.xxx.xxx\c$

将对方的C盘映射为自己的H盘

 

3、copy con h:\reboot.bat

iisreset /reboot

CTRL+Z

在对方的C盘上生成了一个能重启计算机的文件

 

4、net time \\xxx.xxx.xxx.xxx

得到对方的时间

 

5、at \\xxx.xxx.xxx.xxx 重起的时间 c:\reboot.bat

重起的时间等于对方的时间加几分钟

 

6、at \\xxx.xxx.xxx.xxx

看看任务加上没有

 

7、等......

上面的第三步是only for WIN2K的,如果是NT,你需要用一个特定的重起程序,我们可以自己编写一个reboot.exe来取代reboot.bat,原理很简单,代码如下:

#include "stdio.h"

#include "windows.h"

int main()

{

//定义重起的时候发送给所有用户的消息

LPSTR msg="Reboot Tool By Lion Hook\nhttp://www.xici.net";

//尝试用最简单的API函数重起

if(ExitWindowsEx(EWX_REBOOT, 0))return TRUE;

if(ExitWindowsEx(EWX_REBOOT   EWX_FORCE, 0))return TRUE;

//因为上面的重起不成功,所以需要调整本进程的特权

HANDLE hToken;

TOKEN_PRIVILEGES tkp;

if (!OpenProcessToken(GetCurrentProcess(),TOKEN_ADJUST_PRIVILEGES   TOKEN_QUERY, &hToken)) return FALSE;

//获取重起的特权SE_SHUTDOWN_NAME

LookupPrivilegeValue(NULL, SE_SHUTDOWN_NAME, &tkp.Privileges[0].Luid);

tkp.PrivilegeCount = 1;

tkp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;

AdjustTokenPrivileges(hToken, FALSE, &tkp, 0, (PTOKEN_PRIVILEGES)NULL, 0);

//判断是NT内核还是9x内核,选择用不同的方式

if(!(GetVersion() & 0x80000000))

InitiateSystemShutdown(NULL, msg, 20, TRUE, TRUE);

else if (!ExitWindowsEx(EWX_REBOOT, 0))

if(!ExitWindowsEx(EWX_REBOOT   EWX_FORCE, 0))

return FALSE;

return TRUE;

}

延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备2023014753号-2
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网