Модераторы: Snowy, bartram, MetalFan, bems, Poseidon, Riply

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Закрыть чужой Mutex 
:(
    Опции темы
Romы4
Дата 4.7.2009, 12:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Проблема заключается в том чтобы убить мьютекс чужой программы, зная его имя....как создать и закрыть мьютекс я знаю, но с чужим проблема-я не знаю его хэндл
PM MAIL   Вверх
Romikgy
Дата 4.7.2009, 13:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Любитель-программер
****


Профиль
Группа: Участник Клуба
Сообщений: 7326
Регистрация: 11.5.2005
Где: Porto Franco Odes sa

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



Код

HANDLE OpenMutex(

    DWORD dwDesiredAccess,    // access flag 
    BOOL bInheritHandle,    // inherit flag 
    LPCTSTR lpName    // pointer to mutex-object name 
   );

+
Код

BOOL ReleaseMutex(

    HANDLE hMutex    // handle of mutex object  
   );


PS имхо читай мсдн


--------------------
Владение русской орфографией это как владение кунг-фу — истинные мастера не применяют его без надобности. 
smile

PM   Вверх
Romы4
Дата 4.7.2009, 13:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



release вроде не может закрыть мьютикс, только через closehandle, а вот какой хэндл у созданого мьютикса я хз как определить

Добавлено через 4 минуты и 39 секунд
если не сложно, напишите пример
PM MAIL   Вверх
Romы4
Дата 4.7.2009, 16:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



пробывал так:


Код

procedure TForm1.Button1Click(Sender: TObject);
begin
mutex1:=OpenMutex(MUTEX_ALL_ACCESS, false, '_R_F_is_execute_');
if mutex1 <> 0 then CloseHandle (mutex); ;
end;


procedure TForm1.Button2Click(Sender: TObject);
begin
mutex:=CreateMutex(nil, false, '_R_F_is_execute_');
ReleaseMutex(mutex);
end;



но реакции никакой, мутекс при нажатии кнопки 2 создается, но при нажатии кнопки 1 должен по идее вернуть хандл в mutex1 и закрыть mutex, но не закрывает

Это сообщение отредактировал(а) Rrader - 4.7.2009, 17:43
PM MAIL   Вверх
MetalFan
Дата 4.7.2009, 19:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Аццкий Сотона
****


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

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



такими методами никак ты этот мютекс не прибьешь.
тут я вижу два варианта:
1. "высокоуровневый" - внедряться во все процессы, где это мютекс открыт... нет, наверное это фантастика
2. "низкоуровневый" - писать драйвер, который будет грохать нужный мютекс на уровне ядра...



--------------------
There are always someone smarter than you...
PM MAIL   Вверх
Riply
Дата 4.7.2009, 22:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Комодератор
Сообщений: 572
Регистрация: 27.3.2007
Где: St. Petersburg

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



MetalFan,  вроде, можно и не внедряясь, но все равно остается фантастикой
учитывая проблемы, которые возникали у автора.


PM MAIL   Вверх
CodeMonkey
Дата 4.7.2009, 22:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


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

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



Нафига такое надо? 
Если не-программно - можно через Process Explorer. Он для работы использует свой драйвер.

Цитата(Romы4 @  4.7.2009,  16:02 Найти цитируемый пост)
но реакции никакой, мутекс при нажатии кнопки 2 создается, но при нажатии кнопки 1 должен по идее вернуть хандл в mutex1 и закрыть mutex, но не закрывает

Двойку вам за понимание работы системы. Срочно читать Рихтера.
Бросайте вы это дело, не для вашего уровня оно пока. Вернётесь к нему через годик-другой.

P.S. 2MetalFan: а способ №2 не фантастика, что-ли? smile На самом деле, вопрос стоял в закрытии мьютекса в конкретном процессе, поэтому достаточно при запуске этого процесса внедрить в него DLL, поставить хук на CreateMutex - и мы будем знать хэндл.


--------------------
Опытный программист на C++ легко решает любые не существующие в Паскале проблемы.
PM MAIL WWW ICQ Skype GTalk Jabber   Вверх
MetalFan
Дата 6.7.2009, 22:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Аццкий Сотона
****


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

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



Цитата(CodeMonkey @  4.7.2009,  22:21 Найти цитируемый пост)
поэтому достаточно при запуске этого процесса внедрить в него DLL, поставить хук на CreateMutex - и мы будем знать хэндл.

а ежели приложение наше запускается после искомого. а если неизвестно, какое приложение создает мютекс?)


--------------------
There are always someone smarter than you...
PM MAIL   Вверх
Romы4
Дата 7.7.2009, 11:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



известно приложение, точное имя процесса, точное имя мьютекса......расковырял идой приложение в 32-битном формате, нашел где вызывается создание мьютекса....собрать обратно правда не смог(((
PM MAIL   Вверх
Romikgy
Дата 7.7.2009, 20:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Любитель-программер
****


Профиль
Группа: Участник Клуба
Сообщений: 7326
Регистрация: 11.5.2005
Где: Porto Franco Odes sa

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



забей нопами вызов CreateMutex ))


--------------------
Владение русской орфографией это как владение кунг-фу — истинные мастера не применяют его без надобности. 
smile

PM   Вверх
dumb
Дата 7.7.2009, 22:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


sceloglauxalbifacies
****


Профиль
Группа: Экс. модератор
Сообщений: 2929
Регистрация: 16.6.2006

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



Romы4, просто выложи куда-нибудь .exe'шник, а мы посмотрим. smile
PM MAIL   Вверх
Romы4
Дата 8.7.2009, 10:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



лан ребят, забете, придется все выкладывать (5 гигов))))....загасил имя мьютекса через winhex-сделал его пустым....эта сволочь все-равно не позволяет вторую копию запустить
PM MAIL   Вверх
dumb
Дата 8.7.2009, 17:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


sceloglauxalbifacies
****


Профиль
Группа: Экс. модератор
Сообщений: 2929
Регистрация: 16.6.2006

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



.exe'шник 5-гиговый?! не нужно все, нужен только .exe
PM MAIL   Вверх
Romikgy
Дата 8.7.2009, 17:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Любитель-программер
****


Профиль
Группа: Участник Клуба
Сообщений: 7326
Регистрация: 11.5.2005
Где: Porto Franco Odes sa

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



надо забить само создание мутекса , а так он создает с именем все пробелы!


--------------------
Владение русской орфографией это как владение кунг-фу — истинные мастера не применяют его без надобности. 
smile

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


Новичок



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

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



Romikgy а как вычислить создание мьютекса подскажите плз! Как должен выглядеть хук? я так понимаю что нужно вызывать хук вот так:
Код

H:= SetWindowsHookEx(WH_CALLWNDPROC, @hook2, hInstance, 0);


где:
Код

function hook2(c0de, wParam, lParam : integer): Lresult; stdcall;


но как внутри функции hook2 отловить именно функцию CreateMutex??
Какой должен быть wParam здесь, чтобы отловить ее?
PM MAIL   Вверх
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: WinAPI и системное программирование"
Snowybartram
MetalFanbems
PoseidonRrader
Riply

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Литературу по Delphi обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • 99% ответов по WinAPI можно найти в MSDN Library, оставшиеся 1% здесь

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Snowy, bartram, MetalFan, bems, Poseidon, Rrader, Riply.

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


 




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


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

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