| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1717 人关注过本帖
标题:C++指针问题求助,求帮助
取消只看楼主 加入收藏
q272236218
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2017-5-5
结帖率:100%
收藏
 问题点数:0 回复次数:0 
C++指针问题求助,求帮助
#pragma once
#define  _CRT_SECURE_NO_WARNINGS
#include<Windows.h>
#include<iostream>
#define FILE_ADDRESS "F:/ipmsg_new.exe"
#define MessageBox1 0x76F0FDE6
#define SHELL_CODESIZE 0x12
PIMAGE_DOS_HEADER PDOS_header = NULL;
PIMAGE_NT_HEADERS NT_header = NULL;
PIMAGE_FILE_HEADER PE_HEADER = NULL;
PIMAGE_OPTIONAL_HEADER32 P_OPTIONAL_HEADER = NULL;
PIMAGE_SECTION_HEADER PSECTION_HEADER = NULL;
BYTE SHELL_CODE[] = {
    0x6A,0x00,0x6A,0x00,0x6A,0x00,0x6A,0x00,
    0xE8,0x00,0x00,0x00,0x00,
    0xE9,0x00,0x00,0x00,0x00

};
using namespace std;
int FILE_SIZE=0;
static DWORD FILE_open(LPSTR FILE_lujing, LPVOID *FILE_BUFFER)
{
   
   
    FILE *NAME = NULL;
    LPVOID TEP_FILEBUFFER = NULL;
    NAME=fopen(FILE_lujing, "rb");
    if (!NAME)
    {
        cout << "打开文件失败" << endl;
        return 0;
    }
    fseek(NAME, 0, SEEK_END);//设置指针
    FILE_SIZE = ftell(NAME);
    fseek(NAME, 0, SEEK_SET);//设置指针
    TEP_FILEBUFFER = malloc(FILE_SIZE);
   
    if (!TEP_FILEBUFFER)
    {
        cout << "分配内存空间失败" << endl;
        fclose(NAME);
        return 0;
        
    }
   
    size_t n=fread(TEP_FILEBUFFER, 1, FILE_SIZE, NAME);


    if (!n)
    {
        cout << "文件读入失败" << endl;
        free(TEP_FILEBUFFER);
        fclose(NAME);
        return 0;
    }
    *FILE_BUFFER = TEP_FILEBUFFER;
    TEP_FILEBUFFER = NULL;
    fclose(NAME);
    return FILE_SIZE;
}

static DWORD FILE_IMAGE_BUFFER(LPVOID FILE_BUFFER, LPVOID *IMAGE_BUFFER)
{

    LPVOID TEPIMAGEBUFFER = NULL;
    if (FILE_BUFFER == NULL)
    {
        cout << "文件指针无效" << endl;
        return 0;
    }
    if (*((PWORD)FILE_BUFFER) != IMAGE_DOS_SIGNATURE)
    {
        cout << "这个文件不是有效的MZ标志" << endl;
        return 0;
    }
    PDOS_header = (PIMAGE_DOS_HEADER)FILE_BUFFER;
    if (*((PDWORD)((DWORD)FILE_BUFFER +PDOS_header->e_lfanew)) != IMAGE_NT_SIGNATURE)
    {
        cout << "不是有效的PE标志" << endl;
        return 0;
    }
    NT_header = (PIMAGE_NT_HEADERS)(PDWORD)((DWORD)FILE_BUFFER + PDOS_header->e_lfanew);
    PE_HEADER = (PIMAGE_FILE_HEADER)(((DWORD)NT_header) + 4);
    P_OPTIONAL_HEADER = (PIMAGE_OPTIONAL_HEADER32)((DWORD)PE_HEADER + IMAGE_SIZEOF_FILE_HEADER);
    PSECTION_HEADER = (PIMAGE_SECTION_HEADER)((DWORD)P_OPTIONAL_HEADER + PE_HEADER->SizeOfOptionalHeader);
    TEPIMAGEBUFFER = malloc(P_OPTIONAL_HEADER->SizeOfImage);
    if (!TEPIMAGEBUFFER)
    {
        cout << "分配空间失败" << endl;
        return 0;
    }
    memset(TEPIMAGEBUFFER, 0, P_OPTIONAL_HEADER->SizeOfImage);
    memcpy(TEPIMAGEBUFFER, PDOS_header, P_OPTIONAL_HEADER->SizeOfHeaders);
    PIMAGE_SECTION_HEADER TempPSECTION_HEADER = PSECTION_HEADER;
    for (int i = 0; i < PE_HEADER->NumberOfSections; i++, TempPSECTION_HEADER++)
    {
        memcpy((void*)((DWORD)TEPIMAGEBUFFER + TempPSECTION_HEADER->VirtualAddress), (void*)((DWORD)PDOS_header + TempPSECTION_HEADER->PointerToRawData), TempPSECTION_HEADER->SizeOfRawData);

    }
   
    *IMAGE_BUFFER = TEPIMAGEBUFFER;
    TEPIMAGEBUFFER = NULL;
    return P_OPTIONAL_HEADER->SizeOfImage;
}
static DWORD CopyIMAGEtoNEWBUFFER(LPVOID INMAGEBUFFER, LPVOID* NEWBUFFER)
{
   

    LPVOID TEMPNEWBUFFER = NULL;
    DWORD NUMBEROFSECTION = 0;
    if (!INMAGEBUFFER)
    {
        cout << "缓冲区指针无效" << endl;
        return 0;

    }
    if (*((PWORD)INMAGEBUFFER) != IMAGE_DOS_SIGNATURE)
    {
        cout << "这个文件不是有效的MZ标志" << endl;
        return 0;
    }
    PDOS_header = (PIMAGE_DOS_HEADER)INMAGEBUFFER;
    if (*((PDWORD)((DWORD)INMAGEBUFFER + PDOS_header->e_lfanew)) != IMAGE_NT_SIGNATURE)
    {
        cout << "不是有效的PE标志" << endl;
        return 0;
    }


    TEMPNEWBUFFER = malloc(FILE_SIZE);
    memset(TEMPNEWBUFFER, 0, FILE_SIZE);
    memcpy(TEMPNEWBUFFER, PDOS_header, P_OPTIONAL_HEADER->SizeOfHeaders);
    PIMAGE_SECTION_HEADER TEPPSECTION_HEADER = PSECTION_HEADER;
    for (int i = 0; i < PE_HEADER->NumberOfSections; i++, TEPPSECTION_HEADER++)
    {
        memcpy((void*)((DWORD)TEMPNEWBUFFER + TEPPSECTION_HEADER->PointerToRawData), (void*)((DWORD)PDOS_header + TEPPSECTION_HEADER->VirtualAddress), TEPPSECTION_HEADER->SizeOfRawData);

    }
    *NEWBUFFER = TEMPNEWBUFFER;
    TEMPNEWBUFFER = NULL;
    TEPPSECTION_HEADER = NULL;
    return 1;

}
static DWORD WRITEFILETOPATCH(LPSTR ADDRESS, LPVOID NEWBUFFER)
{
   
    if (!NEWBUFFER)
    {
        cout << "内存地址无效" << endl;
        return 0;
    }
    FILE* FILE_NEW = fopen(ADDRESS, "wb");
    fwrite(NEWBUFFER, 1, FILE_SIZE, FILE_NEW);
    fclose(FILE_NEW);
    return 1;
}
static DWORD AddMessageBoxA(LPVOID *IMAGE_BUFFER)
{
    PBYTE CODEBEGIN=NULL;
    CODEBEGIN = (PBYTE)(*(PDWORD)IMAGE_BUFFER + (PSECTION_HEADER->VirtualAddress + PSECTION_HEADER->Misc.VirtualSize));
    memcpy(CODEBEGIN, SHELL_CODE, SHELL_CODESIZE);
    DWORD CALLADD = MessageBox1 - ((DWORD)P_OPTIONAL_HEADER->ImageBase + ((DWORD)(CODEBEGIN + 0xD)- *(PDWORD)IMAGE_BUFFER));
    *(PDWORD)(CODEBEGIN + 9) = CALLADD;
    DWORD JMPADD = (((DWORD)P_OPTIONAL_HEADER->ImageBase + P_OPTIONAL_HEADER->AddressOfEntryPoint)- (P_OPTIONAL_HEADER->ImageBase+((DWORD)(CODEBEGIN + 0x12) - *(PDWORD)IMAGE_BUFFER)));
    *(PDWORD)(CODEBEGIN + 0xE) = JMPADD;
    P_OPTIONAL_HEADER->AddressOfEntryPoint = (DWORD)CODEBEGIN - *(PDWORD)IMAGE_BUFFER;
    return 1;
}为什么P_OPTIONAL_HEADER->AddressOfEntryPoint没有被改变值
搜索更多相关主题的帖子: include 
2017-05-06 11:52
快速回复:C++指针问题求助,求帮助
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.023765 second(s), 9 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved