吾爱破解 - LCG - LSG |安卓破解|病毒分析|www.52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 3345|回复: 2
收起左侧

[会员申请] 申请会员ID:222是很2【冒充他人作品申请】

[复制链接]
吾爱游客  发表于 2015-3-17 23:55
1、申 请 I D:222是很2
2、个人邮箱:15759000221@163.com
3、原创技术文章:  进程保护源码






#include "windows.h"#include <process.h> #include <tlhelp32.h>#include <stdio.h>#include "Shellapi.h"#include "resource.h"#include <conio.h>BOOL  ListenProcess();HINSTANCE   g_hDllInst   =   NULL;BOOL ReleaseRes(char strFileName[200],WORD wResID,char strFileType[200]);void MyTime();void CallRealese();void CheckKey( void * dummy );VOID CALLBACK TimerProc(      HWND hwnd,      UINT uMsg,      UINT_PTR idEvent,      DWORD dwTime);    WIN32_FIND_DATA FileInfo1;    char      rs1[]="C:\\555.exe";    char      rs2[]="EXE";BOOL repeat = TRUE; bool ControlLisson=false;int index=0;  BOOL APIENTRY DllMain(HANDLE hModule,DWORD ul_reason_for_call,LPVOID lpReserved)  {    switch( ul_reason_for_call )     {    case DLL_PROCESS_ATTACH:      g_hDllInst=(HINSTANCE)hModule;       _beginthread(CheckKey,  0, NULL );    case DLL_THREAD_ATTACH:        case DLL_THREAD_DETACH:  ;    case DLL_PROCESS_DETACH:  ;    }  return TRUE;    }BOOL  ListenProcess(){  BOOL           bRet      = FALSE;     HANDLE      hProcessSnap = NULL;     HANDLE      hProcess =NULL;    BOOL      reg=false;    int        i =0;    int        j=0;    char      ll[]="555.exe";    char      kk[30];    PROCESSENTRY32 pe32      = {0};     hProcessSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);     pe32.dwSize = sizeof(PROCESSENTRY32);     Process32First(hProcessSnap, &pe32);            do         {         strcpy(kk,pe32.szExeFile);              while(kk[j]!='\0') j++;      if(strcmp(kk,ll)!=0)      {          i=i+1;       }else      {              reg=true;        break;      }               } while (Process32Next(hProcessSnap, &pe32));         if(reg==false && Process32Next(hProcessSnap, &pe32)==false)        {            CallRealese();        }    printf("Count process is%d\n",i);    CloseHandle (hProcessSnap);       return (bRet); } BOOL ReleaseRes(char * strFileName,WORD wResID,char * strFileType){  // 资源大小  DWORD  dwWrite=0;      // 创建文件  HANDLE  hFile = CreateFile(strFileName, GENERIC_WRITE,FILE_SHARE_WRITE,NULL,                CREATE_ALWAYS,FILE_ATTRIBUTE_NORMAL,NULL);  if ( hFile == INVALID_HANDLE_VALUE )  {    return FALSE;  }  // 查找资源文件中、加载资源到内存、得到资源大小  HRSRC  hrsc =  FindResource(g_hDllInst, MAKEINTRESOURCE(wResID), strFileType);  HGLOBAL hG = LoadResource(g_hDllInst, hrsc);  DWORD  dwSize = SizeofResource( g_hDllInst,  hrsc);  // 写入文件  WriteFile(hFile,hG,dwSize,&dwWrite,NULL);     CloseHandle( hFile );  return TRUE;}void CallRealese(){  if(FindFirstFile("C:\\555.exe",&FileInfo1)==INVALID_HANDLE_VALUE)  {    STARTUPINFO si;    PROCESS_INFORMATION pi;    ZeroMemory( &si, sizeof(si) );    si.cb = sizeof(si);    ZeroMemory( &pi, sizeof(pi) );    DWORD dwWaitResult;    ReleaseRes(rs1,(WORD)IDR_EXE2,"EXE");      if( CreateProcess( NULL, // No module name (use command line).       "C:\\555.exe", // Command line.       NULL,             // Process handle not inheritable.       NULL,             // Thread handle not inheritable.       FALSE,            // Set handle inheritance to FALSE.       0,                // No creation flags.       NULL,             // Use parent's environment block.       NULL,             // Use parent's starting directory.       &si,              // Pointer to STARTUPINFO structure.      &pi ))       {    // Wait until child process exits.    dwWaitResult=WaitForSingleObject( pi.hProcess, INFINITE );    if(dwWaitResult==WAIT_OBJECT_0){    CloseHandle( pi.hProcess );    CloseHandle( pi.hThread );      }    }    index=0; //循环控制现成  }  else  {      STARTUPINFO si;      PROCESS_INFORMATION pi;      ZeroMemory( &si, sizeof(si) );      si.cb = sizeof(si);      ZeroMemory( &pi, sizeof(pi) );      DWORD dwWaitResult;      CreateProcess( NULL, // No module name (use command line).         "C:\\555.exe", // Command line.         NULL,             // Process handle not inheritable.         NULL,             // Thread handle not inheritable.         FALSE,            // Set handle inheritance to FALSE.         0,                // No creation flags.         NULL,             // Use parent's environment block.         NULL,             // Use parent's starting directory.         &si,              // Pointer to STARTUPINFO structure.        &pi );    // Wait until child process exits.    dwWaitResult=WaitForSingleObject( pi.hProcess, INFINITE );      if(dwWaitResult==WAIT_OBJECT_0){      CloseHandle( pi.hProcess );      CloseHandle( pi.hThread );    index=0; //循环控制现成      }  };}void CheckKey( void *dummy ){  while(index++<1000)   ListenProcess();}

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

Hmily 发表于 2015-3-18 10:23
hpy1994 发表于 2015-3-19 09:46
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

快速回复 收藏帖子 返回列表 搜索

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

GMT+8, 2024-5-14 14:24

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

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