С Новым годом! Форум программистов, компьютерный форум, киберфорум
Visual C++
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
 Аватар для _Lamer
9 / 9 / 1
Регистрация: 16.11.2010
Сообщений: 33

При установке ловушки на клавиатуру зависают приложения, запущенные от имени другого пользователя.

16.11.2010, 16:41. Показов 1986. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток. Пишу на С++ (MS Visual Studio 2008). Коротко о самой задаче, затем о проблеме.
Задача:
пишется EXE-ник, который запускает проги на новом рабочем столе, это не терминал, а просто новый рабочий стол на той же станции (HWINSTA). Так же нужно переключение между рабочими столами.
Реализация:
написан EXE-ник (RunApp.exe), который запускает проги на новом рабочем столе.
написана DLL (HOOK.DLL), в которой реализована процедура "LRESULT CALLBACK KeyboardProc(...".
запуск в следующем порядке:
Сначала RunApp.exe подгружает HOOK.DLL на основном Desktope,
Затем RunApp.exe запускает на новом DESKTOP-e процесс DesktopInit.exe, который подгружает HOOK.DLL на новом DESKTOPe.
Затем запускает на новом DESKTOPe любые приложения (согласно пареметрам коммандной строки RunApp.exe).
Подгружать HOKK.DLL на обоих DESKTOP-ах нужно потому что все процессы при запуске привязаны к одному рабочему столу параметром lpDesktop структуры STARTUPINFO и ловушки срабатывают так же с привязкой к DESKTOP-у.

***ПРОБЛЕМА***
на новом DESKTOPе можно запустить процесс (например notepad.exe) от имени другого пользователя, и при нажатии на клавиатуру все работатет. Нажмем условную комбинацию клавиш и переключемся на основной DESKTOP, А ТУТ ЗАСАДА, если запустить процес от имени другого юзера (на важно Admin или нет) то процес работает пока не нажмешь клавишу на кавиатуре. как тока нажал - ПРОЦЕСС ВИСНЕТ и все. А процессы запущенные от того же юзера - работают без нариканий, и по той -же комбинации можно опять переключится на новый DESKTOP.

ВОПРОС: пучему виснет и как избежать зависания !!!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.11.2010, 16:41
Ответы с готовыми решениями:

Запущенные приложения после закрытия скрытно зависают в памяти
Запущенные приложения после закрытия скрытно зависают в памяти. Батники и ранее запущенные приложения некоторое время не удаляются(в...

Запуск стороннего приложения от имени другого пользователя
Доброго времени суток. Пишу программу которая должна проверять установленость драйверов при помощи devcon-а и ещё некоторые программы на...

При установке Windows 7 не работают мышь и клавиатура на экране ввода имени пользователя
Устанавливаю значит windows 7 с загрузочной флешки, это не лицензия. Всё шло нормально до того как перестали работать мышь и клавитура (обе...

7
 Аватар для _Lamer
9 / 9 / 1
Регистрация: 16.11.2010
Сообщений: 33
17.11.2010, 20:44  [ТС]
Если RunApp.exe не запускает ни один процесс на новом Desktope, или запускает процессы на основном рабочем столе, и подгружает HOOK.DLL и устанавливает ловушку на клавиатуру, то на основном (единственном) рабочем столе ничего не виснет, под любым юзером, все красиво отрабатывается.
0
 Аватар для _Lamer
9 / 9 / 1
Регистрация: 16.11.2010
Сообщений: 33
19.11.2010, 15:21  [ТС]
Народ, если нужны исходники, то я выложу без проблем, тока скажите че конкретно надо,
три проекта - это не пять сторчек.
Или подскажите где или у кого спросить. Может я че непонятно рассказал? Или не так спросил?
Вы не молчите, а то я как то себя не уютно чувствую.
Проблему НАДО РЕШИТЬ, а из 39 просмотров ни одного совета,
ну хоть намекните .

Добавлено через 3 минуты
Запуск на новом раб. столе:
код RunApp.exe:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
hWinstaSave = GetProcessWindowStation();
if ( !hWinstaSave ) 
    return bResult;
 
hWinsta = OpenWindowStation(WinSta, false, READ_CONTROL | WRITE_DAC);
if ( !hWinsta ) 
    return bResult;
 
if (!SetProcessWindowStation(hWinsta))
    return bResult;
 
hDesk = OpenDesktop(Desktop, 0, false, dwAccessFlags);
if (hDesk == 0) {
    hDesk = CreateDesktop(Desktop, NULL, NULL, DF_ALLOWOTHERACCOUNTHOOK, dwAccessFlags, NULL);
    if (hDesk == 0) return bResult;
}
 
if (!SetProcessWindowStation(hWinstaSa ve))
    return bResult;
 
ZeroMemory(&si, sizeof(si));
si.cb = sizeof(si);
 
TCHAR m_strTmp[1024];
_sntprintf_s(m_strTmp, 1023, _tcslen(WinSta) + _tcslen(Desktop) + 1, _T("%s\\%s"), WinSta, Desktop);
si.lpDesktop = m_strTmp;
 
ZeroMemory(&pi, sizeof(pi));
pi.hThread = pi.hProcess = INVALID_HANDLE_VALUE;
 
bResult = CreateProcess(NULL, lpCommandLine, lpp, lpt, bi, NORMAL_PRIORITY_CLASS | CREATE_NEW_CONSOLE,
Env, CurDir, &si, &pi);
.....
в DLL:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
HINSTANCE gl_hInst;
BOOL APIENTRY DllMain( HANDLE hModule, DWORD ul_reason_for_call, LPVOID lpReserved) {
switch (ul_reason_for_call)
{
case DLL_THREAD_ATTACH:
    break;
case DLL_THREAD_DETACH:
    break;
case DLL_PROCESS_DETACH:
    break;
case DLL_PROCESS_ATTACH:
    gl_hInst=(HINSTANCE)hModule;
return TRUE;
}
Установка ловушки
C++
1
hKeyHook = SetWindowsHookEx(WH_KEYBOARD, &KeyboardProc, gl_hInst, 0);
Виснет даже при такой реализации
C++
1
2
3
LRESULT CALLBACK KeyboardProc (int code, WPARAM wParam, LPARAM lParam) {
    return CallNextHookEx(hKeyHook, code, wParam, lParam);
}
0
 Аватар для _Lamer
9 / 9 / 1
Регистрация: 16.11.2010
Сообщений: 33
21.11.2010, 12:05  [ТС]
Это третий форум, всего просмотров больше 250, и ни на одном ни одного ответа, ни совета, ни предложения.....
Ну че блин за фигня, проблему то надо как то решить, ну хоть че нить подскажите.
плиииз.
0
Почетный модератор
Эксперт .NET
 Аватар для NickoTin
8725 / 3677 / 404
Регистрация: 14.06.2010
Сообщений: 4,513
Записей в блоге: 9
21.11.2010, 15:16
Ну как бы проблема может быть в этом
Цитата Сообщение от _Lamer Посмотреть сообщение
C++
1
hKeyHook = SetWindowsHookEx(WH_KEYBOARD, &KeyboardProc, gl_hInst, 0);
т.к. WH_KEYBOARD это локальный хук. Если нужно на все окна, то тогда нужно WH_KEYBOARD_LL. Попробуй, если что почитай это, ну и сюда пиши, попробуем разобраться )

Добавлено через 57 секунд
з.ы. Странно что вообще хук ставится... Тебе надо было в раздел WinApi сразу писать... )
0
 Аватар для _Lamer
9 / 9 / 1
Регистрация: 16.11.2010
Сообщений: 33
22.11.2010, 18:21  [ТС]
Прочитал здесь что:
WH_KEYBOARD Thread or global
WH_KEYBOARD_LL Global only
т.е WH_KEYBOARD можно использовать и в ДЛЛ когда Id потока = 0,
вообще в своей DLL я использую

C++
1
2
3
4
5
6
7
8
//Проверяю сообщение
if ( code == HC_ACTION) {
    BYTE bKeyState[256]={0};
    if (GetKeyboardState(bKeyState)) {
        // проверяю комбинацию клавиш
        .....
    }
}
так вот с WH_KEYBOARD_LL у меня чето не работало, хук почемуто не срабатывал.

я создал еще один тестовый прект по умолчанию Win32 (создает окно, процедуру обраб. сообщ. окна ...)
запустил его из под VS под друзим юзером, нажал на клаву и процесс повис, я в отладчик жму на паузу
а мне сообщение:
"Процесс, по-видимому заблокирован (или не в состоянии выполнять код пользовательского режима). Все потоки остановлены."
остановился на строке
C++
1
while (GetMessage(&msg, NULL, 0, 0))
и в какойто системной DLL бесконечный цикл.

Добавлено через 2 часа 37 минут
Попробовал снова с WH_KEYBOARD_LL
установка ловушки
C++
1
hKeyHook = SetWindowsHookEx(WH_KEYBOARD_LL, &LowLevelKeyboardProc, gl_hInst, 0);
реализация LowLevelKeyboardProc
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
 LRESULT CALLBACK LowLevelKeyboardProc (int code, WPARAM wParam, LPARAM lParam)
{
    try
    {   
        //Проверяю сообщение
        if ( code == HC_ACTION ) {
 
            BYTE bKeyState[256]={0};
            if (GetKeyboardState(bKeyState)) {
            // так вот при любом нажатии здесь bKeyState не изменяется,
            // точнее не отражает состояние нажатых (переключеных) клавиш
            // что в принципе и нормально т.к. "перехват" выполнен с WH_KEYBOARD_LL,
            //  т.е. до того как GetMessage тек. процесса получит сообщение от клавы.
            }
        }
 
    }
    catch(...){}
 
    //Передать сообщение другим ловушкам в системе
    return CallNextHookEx(hKeyHook, code, wParam, lParam);
}
хук срабатывает, на ОСНОВНОМ DESKTOPe НИЧЕГО НЕ ВИСНЕТ ПОД ДРУГИМ ЮЗЕРОМ,но вызвав GetKeyboardState(bKeyState) не могу получить состояние клавиатуры, (а надо анализировать одноременное нажатие нескольких клавиш)
может подскажете как?

Добавлено через 4 часа 54 минуты
Избавился от зависания
Установка ловушки
C++
1
hKeyHook = SetWindowsHookEx(WH_KEYBOARD, &KeyboardProc, gl_hInst, 0);
Но загружать DLL и устанавливать ловушку на соновном раб. столе нужно не RunApp.exe, т.е.
RunApp.exe запускает процесс DesktopInit.exe на основном рабочем столе, который подгружает HOOK.DLL и устанавливает ловушку (раньше RunApp.exe сам подгружал HOOK.DLL и устанавливал ловушку).
Затем RunApp.exe запускает на новом DESKTOP-e процесс DesktopInit.exe, который подгружает HOOK.DLL на новом DESKTOPe.
Затем RunApp.exe запускает на новом DESKTOPe любые приложения (согласно пареметрам коммандной строки RunApp.exe).
Походу после запуска процессов на новом рабочем столе RunApp.exe "теряет привязку" к основному рабочему столу, тем более никаких окон RunApp не имеет, но это предположение.
Поскольку истина не доступна, тему можно оставить открытой.
0
Волшебник
 Аватар для Rapsod
65 / 64 / 7
Регистрация: 21.11.2009
Сообщений: 319
18.10.2012, 18:12
Цитата Сообщение от _Lamer Посмотреть сообщение
Избавился от зависания
Здравствуйте _Lamer!
А как Вы избавились от зависания?
И почему оно происходило?

А то у меня та же ситуация..(
0
 Аватар для _Lamer
9 / 9 / 1
Регистрация: 16.11.2010
Сообщений: 33
18.10.2012, 22:05  [ТС]
читай предыдущее моё сообщение, решил, написав приложение- прокладку между RunApp и Hook.dll, назвав его DesktopInit.exe.
Почему так я и не понял, сроки кончились и решил любым доступным способом, криво но работает.
Больше к проекту не возвращался хотя познать истинную причину не откажусь.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.10.2012, 22:05
Помогаю со студенческими работами здесь

Поток от имени другого пользователя
Доброго времени суток! Моя служба должна работать под аккаунтом SYSTEM для взаимодействия с рабочим столом, но проблема в том, что мне...

Запуск от имени другого пользователя
Меня задобала вечно вылезающая панель. "Запуск от имени другого пользователя". Почти при каждой попытке открыть любую программу. Ну...

Чтение файла от имени другого пользователя
Подскажите, есть ли возможность в VB.NET (2010) при чтении данных из файла указать имя пользователя и пароль с которыми следует...

Запуск программы от имени другого пользователя
Добрый день. Подскажите пожалуйста как запустить программу от имени администратора, указав в скрипте пароль, но не используя runas...

Запуск агента от имени другого пользователя.
Подскажите как реализовать? Проблема в следующем. Есть 2е базы: база1 и база2. Через базу1 агентом есть возможность генерить...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru