能力值:
( LV5,RANK:60 )
2 楼
下载不了,怎么看???
能力值:
( LV8,RANK:130 )
3 楼
看看。。。。
能力值:
( LV2,RANK:10 )
4 楼
555,新人发不了附件,用的是看雪提供的网络硬盘。能下的,要等10秒。
能力值:
( LV12,RANK:1010 )
5 楼
等了10秒,也下不了. 带了驱动,什么都可以杀...
能力值:
( LV2,RANK:10 )
6 楼
没有带驱动的,加载驱动OUTPOST会提示的,麻烦大家去作者主页下载一下,就28KB。
5acK9s2c8@1M7q4)9K6b7g2)9J5c8W2)9J5c8Y4N6%4N6#2)9J5k6h3q4#2N6r3!0V1k6h3u0#2k6#2)9J5k6h3y4G2L8g2)9J5c8X3c8G2N6$3&6D9L8$3q4V1i4K6u0W2M7r3S2H3
最下面 KILLPROCESS,谢谢!!!
能力值:
( LV2,RANK:10 )
7 楼
我是作者,没有用什么技巧啊,就是用TerminateProcess杀进程啊。
能力值:
( LV12,RANK:1010 )
8 楼
被雷到了...
能力值:
( LV2,RANK:10 )
9 楼
昏迷,你没用OPENPROCESS吗?我试过很多杀进程软件,只要用到OPENPROCESS的都杀不掉那个软件。但是这个就可以,郁闷了!TerminateProcess都知道啊,但在OPENPROCESS时就已经失败了,如果这个只是简单的用OPENPROCESS和TerminateProcess怎么可能哦。
能力值:
( LV2,RANK:10 )
10 楼
用了OpenProcess啊。把你的东西share出来看看。
能力值:
( LV2,RANK:10 )
11 楼
不过,还用了一下提升权限的函数。
能力值:
( LV5,RANK:60 )
12 楼
貌似用了点特殊技巧
能力值:
( LV2,RANK:10 )
13 楼
谢谢,我马上试,不行UP上来~ 感谢~
能力值:
( LV2,RANK:10 )
14 楼
function UpgradePrivilege: Boolean;
var
TTokenHd: THandle;
TTokenPvg: TTokenPrivileges;
cbtpPrevious: DWORD;
rTTokenPvg: TTokenPrivileges;
pcbtpPreviousRequired: DWORD;
begin
Result := False;
if Win32Platform = VER_PLATFORM_WIN32_NT then
begin
if OpenProcessToken(GetCurrentProcess, TOKEN_ADJUST_PRIVILEGES or TOKEN_QUERY, TTokenHd) then
begin
if LookupPrivilegeValue(nil, 'SeDebug', TTokenPvg.Privileges[0].Luid) then
begin
TTokenPvg.PrivilegeCount := 1;
TTokenPvg.Privileges[0].Attributes := SE_PRIVILEGE_ENABLED;
cbtpPrevious := SizeOf(rTTokenPvg);
pcbtpPreviousRequired := 0;
Result := Windows.AdjustTokenPrivileges(TTokenHd, False, TTokenPvg, cbtpPrevious,
rTTokenPvg, pcbtpPreviousRequired);
end;
end;
end;
end;
function KillProcessByPID(PID : DWord): boolean;
begin
Result := TerminateProcess(OpenProcess(PROCESS_TERMINATE, False, PID), 0);
end;
先提升权限后再KILL,那个进程没关掉,自己进程反而关掉了,求教!那个是个客户端平台,对OPENPROCESS做了挂钩,整个不知道怎么整了。各位高人帮帮忙吧~
UpgradePrivilege;
KillProcessByPID(dPID);
能力值:
( LV2,RANK:10 )
15 楼
SeDebug是什么东西?我看到的是SeDebugPrivilege。
另外,不懂delphi.
能力值:
( LV2,RANK:10 )
16 楼
OK了,
原来错把SeDebugPrivilege写成SeDebug,非常感谢。
能力值:
( LV2,RANK:10 )
17 楼
不好意思,又来请大家帮助了,按楼上兄弟做法提升权限后时而成功时而失败,不知道为什么。但楼上兄弟写的那个KILLPROCESS.EXE 每次都是成功的。
请问除了提升权限外,是否还有什么细节需要处理?而且我发现如果关闭指定的程序失败,那个程序没关掉反而杀进程的程序莫名其妙的关闭。
能力值:
( LV5,RANK:60 )
18 楼
可能是把他的hand直接转成你得了吧
能力值:
( LV2,RANK:10 )
19 楼
是的,晕死,OPENPROCESS返回的HANDLE尽然和我自己GetCurrentProcess返回的一样。输出PID和KILLPROCESS得到的一样的,但OPENPROCESS后,返回的HANDLE难得正确一次,如果不正确那个HANDLE就是自己的HANDLE,所以变成杀自己了。真的不明白~~~ 求救。
能力值:
( LV2,RANK:10 )
20 楼
有现成的不用,为啥自己要重新写一个呢?
能力值:
( LV2,RANK:10 )
21 楼
因为是一个外部更新程序用到的,在更新前要杀掉进程才能更新,要更新的程序本身不是自己的程序,所以只好通过杀进程方式解决了,因为它做了一些保护,发送关闭消息、简单的关闭进程都不能用。楼上的兄弟,请问除了提升权限外是否还有其他的细节需要处理呢?你的KILLPROCESS每次杀都是成功的。
能力值:
( LV2,RANK:10 )
22 楼
没有其他的了。
能力值:
( LV2,RANK:10 )
23 楼
我早上又试了一下,感觉很郁闷,PID取得是正确的,但OPENPROCESS后的HANDLE返回就经常出问题了,经常返回的是自己的HANDLE,而不是要杀的进程的HANDLE,如果不用OPENPROCESS是否能够取得HANDLE呢?除了我要杀的那个程序总出问题外,杀其他例如计算器、记事本那些都没问题。
能力值:
( LV8,RANK:130 )
24 楼
在ring0中杀进程有很多种方法,不一定要openprocess
杀进程可以用以下方法:
把EPPROCESS中的object清零
把EPPROCESS从active链表中摘除
从ring0注入代码让进程自己退出等等,
反正ring0杀进程方法很多,
这个问题不用深究
能力值:
( LV12,RANK:1010 )
25 楼
这2个不是杀进程,是隐藏进程