吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 5307|回复: 8
收起左侧

[其他转载] WIN32汇编列进程

 关闭 [复制链接]
netknight 发表于 2009-6-30 19:51



;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
;made by netknight
;Email:netknight@163.com
;QQ:175943462
;Blog:http://hi.baidu.com/netknight
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
.386
.model flat,stdcall
option casemap:none
include  Windows.inc
include  user32.inc
include  gdi32.inc
include  kernel32.inc
include  shell32.inc
include psapi.inc
include shlwapi.inc
include macros.inc
include advapi32.inc
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
includelib  user32.lib
includelib  gdi32.lib
includelib  kernel32.lib
includelib  shell32.lib
includelib psapi.lib
includelib shlwapi.lib
includelib advapi32.lib
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
; Equ 等值定义
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
ICO_MAIN  equ 1000h ;图标
DLG_MAIN  equ 1
IDB_List  equ 1001
IDC_COUNT equ 1002
IDC_UPDATE equ 1003
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
; 数据段
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
.data?
hInstance  HINSTANCE ?
hwndListView dd ?
hOK    dd ?
hCount   dd ?
hUpdate   dd ?
;hModule   dd ?
hImageList  dd ?
szName         db 256 dup(?)
lpBuffer   db 256 DUP (?)
plUserName db 256 DUP (?)
szBuffer       db 1024 dup(?)
.data
TestSw dd 0
show  db "%8d",0
szFmtStrSys  db '%d-------System--------N/A',13,10,0
szFmtStrIdle   db '%d-------System Idle Process--------N/A',13,10,0
szFmtStrProc db '是否要结束进程:%s',13,10,0
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
; 代码段
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
.code
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
GetProcName proc uses edi _hProcess:HANDLE
  local hToken:HANDLE
  local dwBytesRead:DWORD
  local dwBytesRead2:DWORD
  local dwSidType:DWORD
  local pData:DWORD
  local szDomainBuffer[256]:BYTE
  ;local plUserName[256]:BYTE
  invoke RtlZeroMemory,addr plUserName,sizeof plUserName
  invoke OpenProcessToken, _hProcess, TOKEN_QUERY, addr hToken
  invoke GetTokenInformation, hToken, TokenUser, NULL, NULL, addr dwBytesRead
  invoke GlobalAlloc, GPTR, dwBytesRead
  mov pData, eax
  invoke GetTokenInformation, hToken,TokenUser, pData, dwBytesRead, addr dwBytesRead
  mov edi, pData
  invoke LookupAccountSid, NULL, [edi][TOKEN_USER.User.Sid], addr plUserName, \
                            addr dwBytesRead, addr szDomainBuffer,\
                              addr dwBytesRead2, addr dwSidType
   .if !eax
   invoke lstrcpy,addr plUserName,CTXT("Unknown")
  .endif
  invoke FreeSid,[edi][TOKEN_USER.User.Sid]
  invoke GlobalFree, pData
  ret
GetProcName endp
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
LoadListView proc uses edi row:DWORD,lpFind:DWORD
  local    lvi:LV_ITEM
  local    sfi:SHFILEINFO
  local    DirSw:DWORD,@_hProcess,hModule
  local    szBuff0[20]:BYTE, szBuff1[256],szPath[MAX_PATH]
  mov edi,lpFind
  assume edi:ptr PROCESSENTRY32
  invoke RtlZeroMemory,addr szBuff0,sizeof szBuff0
  invoke RtlZeroMemory,addr szBuff1,sizeof szBuff1
  invoke RtlZeroMemory,addr  szPath,sizeof  szPath
  mov lvi.imask, LVIF_TEXT or LVIF_IMAGE
  push row
  pop lvi.iItem
  mov lvi.iSubItem, 0
  lea eax,[edi].szExeFile;这个是进程名
  mov lvi.pszText,eax
  mov lvi.iImage, 0
  invoke wsprintf,addr lpBuffer,addr show,[edi].th32ProcessID
  invoke OpenProcess,PROCESS_QUERY_INFORMATION or PROCESS_VM_READ, FALSE, [edi].th32ProcessID
  mov @_hProcess,eax
  .if @_hProcess
   ;invoke EnumProcessModules,@_hProcess, addr hModule, sizeof hModule, 1024
   invoke GetModuleFileNameEx,@_hProcess,0,addr szPath, sizeof szPath
   ;invoke GetModuleBaseName,@_hProcess,addr hModule,offset szName,sizeof szName
   mov eax,[edi].th32ProcessID
   .if eax == 4;判断是否System进程
    ;invoke wsprintf,addr szBuffer,addr szFmtStrSys,[edi].th32ProcessID
    ;invoke MessageBox,NULL,addr szBuffer,CTXT("11"),MB_APPLMODAL
   .else
    ;invoke wsprintf,addr szBuffer,addr szFmtStrFull,[edi].th32ProcessID,addr szName,addr szPath
    ;invoke MessageBox,NULL,addr szBuffer,CTXT("22"),MB_OK or MB_ICONINFORMATION
   .endif
  .else
   ;invoke wsprintf,addr szBuffer,addr szFmtStrIdle,[edi].th32ProcessID
   ;invoke MessageBox,NULL,addr szBuffer,addr szBuffer,MB_OK or MB_ICONINFORMATION
  .endif
  .if !TestSw
   invoke SHGetFileInfo,addr szPath, 0, addr sfi, sizeof SHFILEINFO,SHGFI_SYSICONINDEX or SHGFI_SMALLICON
   mov eax, sfi.iIcon
   mov lvi.iImage, eax
  .endif
  invoke SendMessage,hwndListView, LVM_INSERTITEM, 0, addr lvi
  ;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
  mov lvi.imask,LVIF_TEXT or LVCF_SUBITEM
  inc lvi.iSubItem
  lea eax,lpBuffer ;这个是进程PID
  mov lvi.pszText,eax
  ;invoke MessageBox,NULL,addr lpBuffer,lvi.pszText,MB_APPLMODAL
  invoke SendMessage,hwndListView,LVM_SETITEM, 0,addr lvi
  ;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
  mov lvi.imask,LVIF_TEXT or LVCF_SUBITEM
  inc lvi.iSubItem
  invoke GetProcName,@_hProcess
  lea eax,plUserName ;这个是进程用户名
  mov lvi.pszText,eax
  invoke SendMessage,hwndListView,LVM_SETITEM, 0,addr lvi
  ;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
  mov lvi.imask,LVIF_TEXT or LVCF_SUBITEM
  inc lvi.iSubItem
  invoke lstrcmp,addr plUserName,CTXT("Unknown")
  .if !eax
   invoke lstrcpy,addr szPath,CTXT("FAIL!!!!")
  .endif
  lea eax,szPath  ;这个是进程路径
  mov lvi.pszText,eax
  invoke SendMessage,hwndListView,LVM_SETITEM, 0,addr lvi
  ;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
  assume edi:nothing
  invoke CloseHandle,@_hProcess
  invoke CloseHandle,hModule
  ret
LoadListView endp
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
FillProcInfo proc _buff
  local @stProcess:PROCESSENTRY32
  local @hSnapShot,@dwProcNum
  invoke RtlZeroMemory,addr @stProcess,sizeof @stProcess
  mov @stProcess.dwSize,sizeof @stProcess
  invoke CreateToolhelp32Snapshot,TH32CS_SNAPPROCESS,0
  mov @hSnapShot,eax
  invoke Process32First,@hSnapShot,addr @stProcess
  xor edi,edi
  .while eax
   invoke LoadListView,edi,addr @stProcess
   inc edi
   invoke  Process32Next,@hSnapShot,addr @stProcess
  .endw
  mov @dwProcNum,edi
  invoke CloseHandle,@hSnapShot
  invoke wsprintf,addr szBuffer,CTXT("%d"),@dwProcNum;进程数
  ret
FillProcInfo endp
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
InitListView  proc
  local sfi:SHFILEINFO
  local lvc:LV_COLUMN
  local lpidl:DWORD
  mov     eax, LVS_EX_FULLROWSELECT or LVS_EX_HEADERDRAGDROP or\
                 LVS_EX_SUBITEMIMAGES or LVS_EX_GRIDLINES
  invoke     SendMessage,hwndListView, LVM_SETEXTENDEDLISTVIEWSTYLE, 0, eax
  invoke     SHGetFileInfo,CTXT("C:\"),0,addr sfi,sizeof SHFILEINFO,SHGFI_SYSICONINDEX or SHGFI_SMALLICON
  invoke     SendMessage,hwndListView,LVM_SETIMAGELIST,LVSIL_SMALL,eax
  ;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
  mov     lvc.imask, LVCF_TEXT or LVCF_WIDTH
  mov     lvc.pszText,CTXT("ProcName")
  mov     lvc.lx, 150
  invoke     SendMessage,hwndListView, LVM_INSERTCOLUMN, 0, addr lvc   
  ;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
  mov     lvc.imask, LVCF_TEXT or LVCF_WIDTH
  mov     lvc.pszText,CTXT("PID")
  mov     lvc.lx, 80
  invoke     SendMessage,hwndListView, LVM_INSERTCOLUMN, 1, addr lvc
  ;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
  mov     lvc.imask, LVCF_TEXT or LVCF_WIDTH
  mov     lvc.pszText,CTXT("ProcUseName")
  mov     lvc.lx, 120
  invoke     SendMessage,hwndListView, LVM_INSERTCOLUMN, 2, addr lvc
  ;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
  mov     lvc.imask, LVCF_TEXT or LVCF_WIDTH
  mov     lvc.pszText,CTXT("ProcPath")
  mov     lvc.lx, 400
  invoke     SendMessage,hwndListView, LVM_INSERTCOLUMN, 3, addr lvc
  ret
InitListView  endp
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
ShowCurrentFocus proc
  local lvi:LV_ITEM
  local buffer[256]:BYTE,@_hProcess,@buff[256]:DWORD,@buff1[256]:DWORD,v
  invoke SendMessage,hwndListView,LVM_GETNEXTITEM,-1, LVNI_FOCUSED
  mov lvi.iItem,eax
  mov lvi.iSubItem,0
  mov lvi.imask,LVIF_TEXT
  lea eax,buffer
  mov lvi.pszText,eax
  mov lvi.cchTextMax,256
  invoke RtlZeroMemory,addr buffer,sizeof buffer
  invoke RtlZeroMemory,addr szBuffer,sizeof szBuffer
  invoke SendMessage,hwndListView,LVM_GETITEM,0,addr lvi
  invoke wsprintf,addr @buff,addr szFmtStrProc,addr buffer
  invoke MessageBox,NULL, addr @buff,CTXT("提示!"),MB_OKCANCEL
  .if eax == IDOK
   invoke SendMessage,hwndListView,LVM_GETNEXTITEM,-1, LVNI_FOCUSED
   mov lvi.iItem,eax
   mov lvi.iSubItem,1
   mov lvi.imask,LVIF_TEXT
   lea eax,buffer
   mov lvi.pszText,eax
   mov lvi.cchTextMax,256
   invoke SendMessage,hwndListView,LVM_GETITEM,0,addr lvi
   invoke StrToIntEx,addr [buffer+4],0,addr v
   invoke OpenProcess,PROCESS_ALL_ACCESS, FALSE, v
   mov @_hProcess,eax
   .if @_hProcess
    invoke TerminateProcess,@_hProcess,0
    .if eax
     invoke MessageBox,NULL, CTXT("进程结束成功!"),CTXT("提示!"),MB_OK
    .else
     invoke MessageBox,NULL, CTXT("结束进程失败!"),CTXT("提示!"),MB_ICONERROR
    .endif
   .else
    invoke MessageBox,NULL, CTXT("打开进程失败!"),CTXT("提示!"),MB_ICONERROR
   .endif
  .endif
  invoke SendMessage,hwndListView,LVM_DELETEALLITEMS,0,0;清除所有列
  call   FillProcInfo
  ret
ShowCurrentFocus endp
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
_ProcDlgMain proc uses ebx edi esi hWnd,wMsg,wParam,lParam
  local tvinsert:TV_INSERTSTRUCT
  local tvhit:TV_HITTESTINFO
  local DlgHeight:DWORD
  local DlgWidth:DWORD
  local DlgRect:RECT
  local DesktopRect:RECT
  mov eax,wMsg
  .if eax == WM_CLOSE
   invoke EndDialog,hWnd,NULL
  .elseif eax == WM_INITDIALOG
   invoke LoadIcon,hInstance,ICO_MAIN
   invoke SendMessage,hWnd,WM_SETICON,ICON_BIG,eax
   invoke GetDlgItem,hWnd,IDB_List
   mov hwndListView,eax
   invoke GetDlgItem,hWnd,IDC_COUNT
   mov hCount,eax
   invoke GetDlgItem,hWnd,IDC_UPDATE
   mov hUpdate,eax
   invoke GetDlgItem,hWnd,IDOK
   mov hOK,eax
   invoke EnableWindow,hUpdate,0
   call InitListView
    ;以下是居中窗口
   invoke GetWindowRect,hWnd,addr DlgRect
   invoke GetDesktopWindow
   mov ecx,eax
   invoke GetWindowRect,ecx,addr DesktopRect
   push  0
   mov  eax,DlgRect.bottom
   sub  eax,DlgRect.top
   mov  DlgHeight,eax
   push eax
   mov  eax,DlgRect.right
   sub  eax,DlgRect.left
   mov  DlgWidth,eax
   push eax
   mov  eax,DesktopRect.bottom
   sub  eax,DlgHeight
   shr  eax,1
   push eax
   mov  eax,DesktopRect.right
   sub  eax,DlgWidth
   shr  eax,1
   push eax
   push hWnd
   call MoveWindow
   ;居中窗口结束
  .elseif eax == WM_COMMAND
   mov eax,wParam
   .if ax == IDOK
    invoke SendMessage,hwndListView,LVM_DELETEALLITEMS,0,0;清除所有列
    call   FillProcInfo
    invoke EnableWindow,hOK,0
    invoke EnableWindow,hUpdate,TRUE
   .else
    invoke SendMessage,hwndListView,LVM_DELETEALLITEMS,0,0;清除所有列
    call   FillProcInfo
   .endif
   invoke SetDlgItemText,hWnd,IDC_COUNT,addr szBuffer ;设置进程数
  .elseif eax == WM_NOTIFY
   push edi
   mov edi,lParam
   assume edi:ptr NMHDR
   mov eax,[edi].hwndFrom
   .if eax==hwndListView
    .if [edi].code==NM_DBLCLK
     invoke ShowCurrentFocus
    .endif
   .endif
  .else
   mov eax,FALSE
   ret
  .endif
  mov eax,TRUE
  ret
_ProcDlgMain endp
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
start:
  invoke GetModuleHandle,NULL
  mov hInstance,eax
  invoke DialogBoxParam,hInstance,DLG_MAIN,NULL,offset _ProcDlgMain,NULL
  invoke ExitProcess,NULL
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
  end start




下面是RC

//>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
#include  <resource.h>
//>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
#define ICO_MAIN 0x1000 //图标
#define DLG_MAIN 1
#define IDB_List 1001
#define IDC_COUNT 1002
#define IDC_UPDATE 1003
//>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
ICO_MAIN ICON  "Main.ico"
//>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
DLG_MAIN DIALOG DISCARDABLE  50, 50, 243, 221
STYLE DS_MODALFRAME | WS_POPUP | WS_VISIBLE | WS_CAPTION | WS_SYSMENU
CAPTION "listview进程枚举"
FONT 9, "宋体"
BEGIN
    PUSHBUTTON      "开始枚举(&F)",IDOK,186,201,53,15
    CONTROL         "List1",IDB_List,"SysListView32",LVS_REPORT |
                    LVS_SINGLESEL | WS_BORDER | WS_TABSTOP,5,5,232,191
    LTEXT           "进程数:",IDC_STATIC,11,205,32,9
    LTEXT           "----",IDC_COUNT,52,205,16,9
    PUSHBUTTON      "刷新(&U)",IDC_UPDATE,126,201,53,15
    LTEXT           "QQ:175943462",IDC_STATIC,73,205,48,7
END
//>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

mars1199 发表于 2009-10-22 18:14
看了。。。不错。。。
fulongzai 发表于 2010-8-2 23:32
wtuping 发表于 2010-8-4 01:54
qq20048888 发表于 2010-8-4 02:16
看不懂啊。.
qubick 发表于 2010-8-4 04:58
[s:46]看看 老东西咯貌似
hrbwz 发表于 2010-8-4 10:04
看看到底是什么东西
头像被屏蔽
coaco 发表于 2010-9-1 23:04
提示: 作者被禁止或删除 内容自动屏蔽
头像被屏蔽
languageme 发表于 2011-12-13 15:34
提示: 作者被禁止或删除 内容自动屏蔽
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-10 10:20

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表