Вместо вывода результатов функции find_locs () на консоль вы должны записывать каждый строковый адрес в массив. Затем, после того, как это будет выполнено, прокрутите их и вызовите WriteProcessMemory , перезаписав их чем угодно, просто убедитесь, что у вас правильный размер / нулевое завершение.
Или вы можете отсканировать память дляодин шаблон, перезаписать результат, выполнить повторный поиск следующего, перезаписать, пока PatternScan () не вернет результат. Но это менее эффективно.
Для скорейшего разрешения вашего вопроса я отредактировал find_all (), добавив в него вызов WriteProcessMemory, который является самым быстрым способом выполнения того, что вы хотите. Я изменил несколько других вещей, поэтому обязательно скопируйте и вставьте весь этот исходный код, переписав ваш.
Я удалил материал повышения уровня токена SeDebug, в этом нет необходимости. Вам нужно только запустить вашу программу как администратор, чтобы использовать эти API.
Протестировано работает, просто убедитесь, что длина перезаписываемой строки по крайней мере равна длине someDataNew
#include <iostream>
#include <vector>
#include <string>
#include <windows.h>
#include <algorithm>
#include <iterator>
const char * someDatanew = "Foobar\0";
HANDLE process = 0;
template <class InIter1, class InIter2, class OutIter>
void find_all(unsigned char* base, InIter1 buf_start, InIter1 buf_end, InIter2 pat_start, InIter2 pat_end, OutIter res) {
for (InIter1 pos = buf_start;
buf_end != (pos = std::search(pos, buf_end, pat_start, pat_end));
++pos)
{
*res++ = base + (pos - buf_start);
if (WriteProcessMemory(process, (LPVOID)(base + (pos - buf_start)), (LPCVOID)someDatanew, strlen(someDatanew), 0))
std::cout << "done";
}
}
template <class outIter>
void find_locs(HANDLE process, std::string const &pattern, outIter output) {
unsigned char* p = NULL;
MEMORY_BASIC_INFORMATION info;
for (p = NULL;
VirtualQueryEx(process, p, &info, sizeof(info)) == sizeof(info);
p += info.RegionSize)
{
std::vector<char> buffer;
std::vector<char>::iterator pos;
if (info.State == MEM_COMMIT &&
(info.Type == MEM_MAPPED || info.Type == MEM_PRIVATE))
{
SIZE_T bytes_read;
buffer.resize(info.RegionSize);
ReadProcessMemory(process, p, &buffer[0], info.RegionSize, &bytes_read);
buffer.resize(bytes_read);
find_all(p, buffer.begin(), buffer.end(), pattern.begin(), pattern.end(), output);
}
}
}
int main()
{
DWORD pid;
std::cout << "Enter PID: ";
std::cin >> pid;
std::cin.get();
std::string pattern;
std::cout << "pattern to find: ";
std::getline(std::cin, pattern);
process = OpenProcess(
PROCESS_VM_READ | PROCESS_QUERY_INFORMATION | PROCESS_ALL_ACCESS | PROCESS_VM_OPERATION,
false,
pid);
find_locs(process, pattern,
std::ostream_iterator<void*>(std::cout, "\n")); //outputs addresses that contains the strings
system("pause");
return 0;
}