Rambler's Top100
"Knowledge itself is power"
F.Bacon
Поиск | Карта сайта | Помощь | О проекте | ТТХ  
 Круглый стол
  
Правила КС
>> Настройки

Фильтр вопросов
>> Новые вопросы
отслеживать по
>> Новые ответы

Избранное

Страница вопросов
Поиск по КС


Специальные проекты:
>> К л ю к в а
>> Г о л о в о л о м к и

Вопрос №

Задать вопрос
Off-topic вопросы

Помощь

 
 К н и г и
 
Книжная полка
 
 
Библиотека
 
  
  
 


Поиск
 
Поиск по КС
Поиск в статьях
Яndex© + Google©
Поиск книг

 
  
Тематический каталог
Все манускрипты

 
  
Карта VCL
ОШИБКИ
Сообщения системы

 
Форумы
 
Круглый стол
Новые вопросы

 
  
Базарная площадь
Городская площадь

 
   
С Л С

 
Летопись
 
Королевские Хроники
Рыцарский Зал
Глас народа!

 
  
ТТХ
Конкурсы
Королевская клюква

 
Разделы
 
Hello, World!
Лицей

Квинтана

 
  
Сокровищница
Подземелье Магов
Подводные камни
Свитки

 
  
Школа ОБЕРОНА

 
  
Арсенальная башня
Фолианты
Полигон

 
  
Книга Песка
Дальние земли

 
  
АРХИВЫ

 
 

Сейчас на сайте присутствуют:
 
  
 
Во Флориде и в Королевстве сейчас  21:22[Войти] | [Зарегистрироваться]
Ответ на вопрос № 83606

19-11-2018 00:49
Всем привет.

Снова запуск приложения из сервиса. Нашел несколько вариантов, все варианты проблемные. Нормального описания того, что тут происходит я тоже найти не могу, поэтому ваще не врубаюсь что тут делается... какие-то жетоны... :)

Короче, под 32-х разрядными windows xp и сервером 2003 все нормально работает. Сервер 2012 64бит вываливается на WTSQueryUserToken : 1008 An attempt was made to reference a token that does not exist

Других операционок проверить у меня нет. Дайте списать рабочий код, плиз. :)





function LaunchApplication(FileName: string): Boolean;
var pi: PROCESS_INFORMATION;
    si: STARTUPINFO;
    dwSessionId, winlogonPid, DesiredAccess,erno: DWORD;
    hUserToken, hUserTokenDup, hPToken, hProcess, hsnap: THandle;
    dwCreationFlags: DWORD;
    procEntry: TProcessEntry32;
    winlogonSessId: DWORD;
    tp, tpko: Windows.TTokenPrivileges;
    Buffer: DWORD;
    lpenv: pointer;
    ok: boolean; text: string;

label ex;

begin

Result := False;

hUserToken := 0;
hUserTokenDup := 0;
hPToken := 0;
hProcess := 0;


dwSessionId := WTSGetActiveConsoleSessionId;
hSnap := CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);

if (hSnap = INVALID_HANDLE_VALUE) then exit;

procEntry.dwSize := sizeof(TPROCESSENTRY32);

ok := Process32First(hSnap, procEntry);
if not ok then exit;

winlogonPid := 0;

repeat

winlogonSessId := 0;

ok := ProcessIdToSessionId(procEntry.th32ProcessID, @winlogonSessId);
if (ok and (winlogonSessId = dwSessionId))
then begin
    winlogonPid := procEntry.th32ProcessID;
    break;
    end;

until (not Process32Next(hSnap, procEntry));

ok := WTSQueryUserToken(dwSessionId, @hUserToken);
if not ok
then begin

    // тут ломается


    erno := GetLastError;
    text := 'WTSQueryUserToken : ' + inttostr(erno) + ' ' + SysErrorMessage(erno);
    AddStr2File(text,'test.txt');
    goto ex;
    end;

dwCreationFlags := NORMAL_PRIORITY_CLASS or CREATE_NEW_CONSOLE;
ZeroMemory(@si, sizeof(STARTUPINFO));
si.cb := sizeof(STARTUPINFO);
si.lpDesktop := PChar('Winsta0\Default');
ZeroMemory(@pi, sizeof(pi));

hProcess := OpenProcess(MAXIMUM_ALLOWED, FALSE, winlogonPid);

DesiredAccess := TOKEN_ALL_ACCESS or TOKEN_ADJUST_SESSIONID or TOKEN_READ or TOKEN_WRITE;


ok := OpenProcessToken(GetCurrentProcess, DesiredAccess, hPToken);
if not ok
then begin
    erno := GetLastError;
    text := 'OpenProcessToken : ' + inttostr(erno) + ' ' + SysErrorMessage(erno);
    AddStr2File(text,'test.txt');
    goto ex;
    end;

ok := LookupPrivilegeValue(nil, SE_DEBUG_NAME, tp.Privileges[0].Luid);
if not ok
then begin
    erno := GetLastError;
    text := 'LookupPrivilegeValue : ' + inttostr(erno) + ' ' + SysErrorMessage(erno);
    AddStr2File(text,'test.txt');
    goto ex;
    end;

tp.PrivilegeCount := 1;
tp.Privileges[0].Attributes := SE_PRIVILEGE_ENABLED;
ok := DuplicateTokenEx(hPToken, MAXIMUM_ALLOWED {DesiredAccess}, nil, SecurityIdentification, TokenPrimary, hUserTokenDup);
if not ok
then begin
    erno := GetLastError;
    text := 'DuplicateTokenEx : ' + inttostr(erno) + ' ' + SysErrorMessage(erno);
    AddStr2File(text,'test.txt');
    goto ex;
    end;

ok := SetTokenInformation(hUserTokenDup, TTokenInformationClass(ord(TokenSessionId)),
                          @dwSessionId, sizeof(dwSessionId));
if not ok
then begin
    erno := GetLastError;
    text := 'SetTokenInformation : ' + inttostr(erno) + ' ' + SysErrorMessage(erno);
    AddStr2File(text,'test.txt');
    goto ex;
    end;

ok := AdjustTokenPrivileges(hUserTokenDup, FALSE, tp, sizeof(tp), tpko, Buffer);
if not ok
then begin
    erno := GetLastError;
    text := 'AdjustTokenPrivileges : ' + inttostr(erno) + ' ' + SysErrorMessage(erno);
    AddStr2File(text,'test.txt');
    goto ex;
    end;

lpEnv := nil;
ok := CreateEnvironmentBlock(lpEnv, hUserTokenDup, TRUE);
if ok
then dwCreationFlags := dwCreationFlags or CREATE_UNICODE_ENVIRONMENT or PROFILE_USER
else lpEnv := nil;

CreateProcessAsUser(hUserTokenDup, PChar(FileName), nil, nil, nil, FALSE, dwCreationFlags,lpEnv, nil, si, pi);

ex:

CloseHandle(hUserToken);
CloseHandle(hPToken);
CloseHandle(hProcess);
CloseHandle(hUserTokenDup);

end;


[+] Добавить в избранные вопросы

Отслеживать ответы на этот вопрос по RSS

Ответы:


Уважаемые авторы вопросов! Большая просьба сообщить о результатах решения проблемы на этой странице.
Иначе, следящие за обсуждением, возможно имеющие аналогичные проблемы, не получают ясного представления об их решении. А авторы ответов не получают обратной связи. Что можно расценивать, как проявление неуважения к отвечающим от автора вопроса.

22-11-2018 09:53
А мой сервис этому приложению из другой сессии сможет PostMessage посылать?
Не сможет

21-11-2018 15:53 | Сообщение от автора вопроса
Спасибо. С этим, вроде, понятно.

А мой сервис этому приложению из другой сессии сможет PostMessage посылать?

20-11-2018 20:16
WTSQuerySessionInformation

20-11-2018 18:46 | Комментарий к предыдущим ответам
ок, список в виде SessionId,WinStationName,State я получил с помощью WTSEnumerateSessions. а юзернейм чем прочитать?

20-11-2018 17:37 | Комментарий к предыдущим ответам
запустил. не в этой. :)

а qwinsta как этот список делает? там как раз все параметры есть, что мне надо. я бы по STATE=Active и не пустому USERNAME взял бы свой номер...

20-11-2018 11:06
Не знаю "в этой ли я консольной сессии"? Как узнать?
Команду qwinsta на сервере запустите

19-11-2018 14:15 | Комментарий к предыдущим ответам
dwSessionId: 1

да, я к нему залогинен, правда через RDS. Это виртуальный сервер. Не знаю "в этой ли я консольной сессии"? Как узнать?


19-11-2018 10:07
Что возвращает WTSGetActiveConsoleSessionId? И залогинен ли пользователь в этой консольной сессии?

Добавьте свое cообщение

Вашe имя:  [Войти]
Ваш адрес (e-mail):На Королевстве все адреса защищаются от спам-роботов
контрольный вопрос:
Однажды, в студеную зимнюю пору я из лесу вышел, был сильный ЧТО?
в качестве ответа на вопрос или загадку следует давать только одно слово в именительном падеже и именно в такой форме, как оно используется в оригинале.
Надоело отвечать на странные вопросы? Зарегистрируйтесь на сайте.
Тип сообщения:
Текст:
Жирный шрифт  Наклонный шрифт  Подчеркнутый шрифт  Выравнивание по центру  Список  Заголовок  Разделительная линия  Код  Маленький шрифт  Крупный шрифт  Цитирование блока текста  Строчное цитирование
  • вопрос Круглого стола № XXX

  • вопрос № YYY в тесте № XXX Рыцарской Квинтаны

  • сообщение № YYY в теме № XXX Базарной площади
  • обсуждение темы № YYY Базарной площади
  •  
     Правила оформления сообщений на Королевстве

    Страница избранных вопросов Круглого стола.
      
    Время на сайте: GMT минус 5 часов

    Если вы заметили орфографическую ошибку на этой странице, просто выделите ошибку мышью и нажмите Ctrl+Enter.
    Функция может не работать в некоторых версиях броузеров.

    Web hosting for this web site provided by DotNetPark (ASP.NET, SharePoint, MS SQL hosting)  
    Software for IIS, Hyper-V, MS SQL. Tools for Windows server administrators. Server migration utilities  

     
    © При использовании любых материалов «Королевства Delphi» необходимо указывать источник информации. Перепечатка авторских статей возможна только при согласии всех авторов и администрации сайта.
    Все используемые на сайте торговые марки являются собственностью их производителей.

    Яндекс цитирования