Модераторы: feodorv, GremlinProg, xvr, Fixin

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Разблокировать exe файл 
V
    Опции темы
bass
Дата 25.8.2015, 11:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 315
Регистрация: 5.8.2007

Репутация: 2
Всего: 2



Доброго дня.
Не когда не стояло такой задачи, но тут она встала. Нужно модифицировать свой EXE.
На ХР как то писал самоудаление помогала функция 
UnmapViewOfFile(0х400000); //при штатном распределении памяти
CloseHandle(4);
Но в семерке встала проблема с данными действиями.
Уже в место 
UnmapViewOfFile пробовал FreeLibrary возвращает 1.
Взял программу HANDLE не одного открытого дескриптора с данным файлом не нашел да и с другими приложениями тоже.

Кто по глубже знает систему.
Ведь при старте процесса он открывается с помощью CreateFile, потом отображается в память.

Должны быть дескрипторы.

За ранее спасибо.
PM MAIL   Вверх
_zorn_
Дата 25.8.2015, 20:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1077
Регистрация: 21.8.2007

Репутация: нет
Всего: 12



Что это за набор мыслей ? Я где то когдато что делал ?
Озвучь проблему. Что хочешь сделать и что не получается.
PM MAIL   Вверх
bass
Дата 25.8.2015, 23:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 315
Регистрация: 5.8.2007

Репутация: 2
Всего: 2



Цитата(_zorn_ @ 25.8.2015,  20:14)
Что это за набор мыслей ? Я где то когдато что делал ?
Озвучь проблему. Что хочешь сделать и что не получается.

Прошу прощения за столь сумбурно заданный вопрос. 
Хочу написать счетчик запуска программы и счетчик времени работы. Не чего не пришло в голову как перезапись самого ехе файла.
В системе ХР я бы воспользовался функцией:
UnmapViewOfFile
CloseHandle(4);

Все бы сработало.

Пробую данную манипуляцию на 7-ке - выходит болт. 

Пытаюсь найти кто  держит файл в заблокированном состояние.
Для данных манипуляций воспользовался утилитой HANDLE не каких десткрипторов удерживающих файл она мне не показала.
Кто на момент работы приложения все таки удерживает файл приложения в заблокированном состоянии.

 
PM MAIL   Вверх
feodorv
Дата 26.8.2015, 06:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2214
Регистрация: 30.7.2011

Репутация: 9
Всего: 45



А почему обязательно экзешник? Вариант с переменной в реестре (отдельном файле и т.д.) не подходит?

Цитата(bass @  25.8.2015,  23:32 Найти цитируемый пост)
Пытаюсь найти кто  держит файл в заблокированном состояние.

Сама система и держит (делает ему memory map на чтение). Если EXE запущен, то модификация его запрещена. 


--------------------
Напильник, велосипед, грабли и костыли - основные инструменты программиста...
PM MAIL   Вверх
bass
Дата 26.8.2015, 10:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 315
Регистрация: 5.8.2007

Репутация: 2
Всего: 2



Цитата(feodorv @ 26.8.2015,  06:50)

Сама система и держит (делает ему memory map на чтение). Если EXE запущен, то модификация его запрещена.


Сейчас и остановился на реестре.

Система звучит как то размыто. Координаты по точнее требуются. 
Вот в ХР сам процесс и держал данный файл.
При такой манипуляции:
Код

UnmapViewOfFile(0х400000); //при штатном распределении памяти
CloseHandle(4);

Система отпускала файл, есть нюансы что при этом выгрузиться имидж самого отгружаемого модуля. Но вопрос с отгруженным куском исполняемой памяти решается. И делай все что угодно со своим файлом.
Что в семерке изменилось??? 
PM MAIL   Вверх
feodorv
Дата 26.8.2015, 19:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2214
Регистрация: 30.7.2011

Репутация: 9
Всего: 45



Цитата(bass @  26.8.2015,  10:06 Найти цитируемый пост)
Что в семерке изменилось??? 

Скорее всего, закрыли это недоразумение. Это какой-то хакерский приём с непонятными последствиями (судя по всему, плохими). Правильно сделали, что прикрыли)))


--------------------
Напильник, велосипед, грабли и костыли - основные инструменты программиста...
PM MAIL   Вверх
disputant
Дата 26.8.2015, 22:03 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 210
Регистрация: 28.11.2011

Репутация: 1
Всего: 3



А ведь в добрые старые времена вирусы именно так и работали... smile

PM MAIL   Вверх
bass
Дата 27.8.2015, 00:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 315
Регистрация: 5.8.2007

Репутация: 2
Всего: 2



Короче поиски меня не к чему не привели, судя по ответам не кто мне не подскажет суть этого явления.. )))) 
Будем придумывать что то... 
PM MAIL   Вверх
GremlinProg
Дата 27.8.2015, 10:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2706
Регистрация: 9.8.2005
Где: Тюмень

Репутация: 99
Всего: 106



Process Explorer покажет, кто держит открытым дескриптор


--------------------
"Гений всегда разумнее, чем умнее. Ум — это машина, разум — водитель этой машины."
PM WWW ICQ   Вверх
bass
Дата 27.8.2015, 11:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 315
Регистрация: 5.8.2007

Репутация: 2
Всего: 2



Цитата(GremlinProg @ 27.8.2015,  10:35)
Process Explorer покажет, кто держит открытым дескриптор

Не показал, все дескрипторы связанные с данным процессом закрывал и файлом.
Дискрипторы открытого процесса были даже в системных процессах (Именно процесса а не файла). Закрывал все!!!!!!
Выход из своей ситуации я то нашел, прикрепил ключи гуардант а здесь уже интерес разобрал.
Хотел маленькую защитку от копирования сделать, файл сверяет свои временные метки перезаписывает свой модуль, одновременно уменьшает счетчик запуска. Конечно это все мертвому припарки но в библиотечке хотелось бы иметь защитку от дурака. 
PM MAIL   Вверх
GremlinProg
Дата 27.8.2015, 16:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2706
Регистрация: 9.8.2005
Где: Тюмень

Репутация: 99
Всего: 106



...защиту от дурака?
а чем не устраивают классические методы: http://forum.vingrad.ru/forum/topic-289403/view-all.html ?

Guardant - круто, правильно!


--------------------
"Гений всегда разумнее, чем умнее. Ум — это машина, разум — водитель этой машины."
PM WWW ICQ   Вверх
bass
Дата 27.8.2015, 17:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 315
Регистрация: 5.8.2007

Репутация: 2
Всего: 2



Цитата(GremlinProg @ 27.8.2015,  16:11)
...защиту от дурака?
а чем не устраивают классические методы: http://forum.vingrad.ru/forum/topic-289403/view-all.html ?

Guardant - круто, правильно!

Да просто со старой работы завалялись ключики...)))) Парочку оприходывал.))))Щ

Стандартные методы ??????

По сути в той ветке процесс удаления файлов. А  мне нужен процесс перезаписи.
Через бат файл как-то данное дияние неохото совершать.
Инжект встанут проблемы с АВП, длл рядом с ЕХЕ модулем.
Запуск дочернего процесса не должно спровоцировать АВП. Создать виртуальный диск запихнуть из ресурсов патчЕХЕ.
Запустить сторонний процесс из памяти.  
Есть еще вариант хукнуть стороннее приложение и далее с помощью релоков распеделить код в стороннем процессе., длл должна рядом с EXE модулем лежать. 
На какой метод будут срабатывать АВП пока мне не ясно.

Хотел малой кровью отделаться - Ключи на  разумнешее решение..))))
Только вот с флешкой еще и ключик придется вставлять, устанавливать драйвера хотя можно в HID режиме ключики запустить..

Да даже знаменитая программа UNlocker не справилась с данным заданием, уж так интересно стало чего накалякали специалисты Microsoft для совершения данной подлянки... ))))) 


Это сообщение отредактировал(а) bass - 27.8.2015, 17:25
PM MAIL   Вверх
volatile
Дата 27.8.2015, 18:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2107
Регистрация: 7.1.2011

Репутация: 13
Всего: 85



Цитата(bass @  26.8.2015,  10:06 Найти цитируемый пост)
Что в семерке изменилось???  

появился ACL  smile 
Может банально нет прав?

PM MAIL   Вверх
bass
Дата 27.8.2015, 18:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 315
Регистрация: 5.8.2007

Репутация: 2
Всего: 2



Цитата(volatile @ 27.8.2015,  18:12)
Цитата(bass @  26.8.2015,  10:06 Найти цитируемый пост)
Что в семерке изменилось???  

появился ACL  smile 
Может банально нет прав?

ProcessExplorer правда не нашел данного дескриптора.
Но можно и под учетной записью системы запуститься.....
Боюсь не исправит данное действие картину....
Мне кажется дело где-то глубже зарыто например в драйвере файловой системы.

Это сообщение отредактировал(а) bass - 27.8.2015, 18:31
PM MAIL   Вверх
feodorv
Дата 28.8.2015, 02:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2214
Регистрация: 30.7.2011

Репутация: 9
Всего: 45



Цитата(bass @  27.8.2015,  17:21 Найти цитируемый пост)
уж так интересно стало чего накалякали специалисты Microsoft для совершения данной подлянки... ))))) 

Боже мой, да простой if в коде unmap уровня ядра:
Код
  if( unmapAddr == base_map_addr_of_exe_file ) 
  {
    SetLastError(...);
    return FALSE;
  }



--------------------
Напильник, велосипед, грабли и костыли - основные инструменты программиста...
PM MAIL   Вверх
Ответ в темуСоздание новой темы Создание опроса
Правила форума "C/C++: Системное программирование и WinAPI"
Fixin
GremlinProg
xvr
feodorv
  • Большое количество информации и примеров с использованием функций WinAPI можно найти в MSDN
  • Описание сообщений, уведомлений и примеров с использованием компонент WinAPI (BUTTON, EDIT, STATIC, и т.п.), можно найти в MSDN Control Library
  • Непосредственно, перед созданием новой темы, проверьте заголовок и удостоверьтесь, что он отражает суть обсуждения.
  • После заполнения поля "Название темы", обратите внимание на наличие и содержание панели "А здесь смотрели?", возможно Ваш вопрос уже был решен.
  • Приводите часть кода, в которой предположительно находится проблема или ошибка.
  • Если указываете код, пользуйтесь тегами [code][/code], или их кнопочными аналогами.
  • Если вопрос решен, воспользуйтесь соответствующей ссылкой, расположенной напротив названия темы.
  • Один топик - один вопрос!
  • Перед тем как создать тему - прочтите это .

На данный раздел распространяются Правила форума и Правила раздела С++:Общие вопросы .


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Chipset, Step, Fixin, GremlinProg, xvr. feodorv.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Системное программирование и WinAPI | Следующая тема »


 




[ Время генерации скрипта: 0.0838 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.