win10 vbs调用handle.exe handle64.exe killhandle以D2R为例

代码目标:杀掉暗黑2R的多开验证handle (DiabloII Check For Other Instances)

环境:win10 64位

资料来源:凯恩之角,原出处不详。

需要把handle64.exe放入系统盘的Windows\System32文件夹,如C:\Windows\System32

hanle64获取:Handle - Windows Sysinternals | Microsoft Learn

32位系统则调用handle.exe ,代码做相迎修改即可。无环境,未亲测。

使用方法:代码复制到文本文档,另存为.VBS格式,双击运行

getfolder = left(wscript.scriptfullname,instrrev(wscript.scriptfullname,"")) 
Set shell = CreateObject("WScript.Shell")
Set exec = shell.Exec( "C:\Windows\System32\handle64.exe -a -p D2R.exe Instances") '获取包含Instances的句柄
strText = exec.StdOut.ReadAll()
'msgbox  strText,1,"handle"

s = split(strText, chr(10))
'msgbox UBound(s)
for i = 0 to UBoun
freepdb.cmd文件解读 说明:@字符后面的是注释 if "%1"=="" ( @如果"%1"表示输入的参数如果为空,则进行如下处理 echo Usage: freepdb filename echo This will free all handles of VS2003 on filename.pdb echo Requires the Handle utility from Windows Sysinternals goto :eof ) cd /d "%~dp0" @进入freepdb.cmd文件所在的目录,因为需要使用的handle.exe和 @freepdb.cmd在同一个目录下 @以下部分说明:阅读时,请先查询dos命令 for的使用,第一个for循环来获取指定pdb文件的信息。 for /f "tokens=2,3 skip=5 delims=:" %%a in ('handle.exe -p devenv.exe "%1.pdb"') do ( for /f "tokens=1,4" %%c in ("%%a %%b") do ( handle -p %%c -c %%d -y >a.txt ) ) exit /b 0 @第一个for循环的含义是:运行in后面的括号里的命令语句,将结果按照/f 后面的命令来筛选出来, @@将到的结果分别放入了%%a, %%b中 @运行in后面括号中的语句后,得到的结果如下(调试我自己的程序打印出来的信息): @devenv.exe pid: 8960 type: File B70:E:\work\MainClient\new_src\Release\3DStock.pdb @然后取第2个字符串和第3个字符串,分别是(因为是通过“:”号来分割字符串的): @8960 type @File B70 @执行第2个循环语句 @第2个for循环,是从%%c(由%%a, %%b所合成的)中,取第一个字符串(默认通过空格来分割字符串)和第 @4个字符串 @运行in后面括号中的语句结果如下: @ 8960 type File B70 @然后取第1个字符串和第4个字符串,分别放入%%c, %%d中(8960是进程的id,B70是文件的句柄) @8960 @B70 @然后执行handle -p %%c -c %%d -y >a.txt命令 @即执行:handle -p 8960 -c B70 -y, 并将处理的结果存入a.txt ,存入文件是为了看到处理结果 @此命令是,杀掉指定进程ID的使用的文件句柄
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值