На главную Наши проекты:
Журнал   ·   Discuz!ML   ·   Wiki   ·   DRKB   ·   Помощь проекту
ПРАВИЛА FAQ Помощь Участники Календарь Избранное RSS
msm.ru
Обратите внимание:
1. Прежде чем начать новую тему или отправить сообщение, убедитесь, что вы не нарушаете правил форума!
2. Обязательно воспользуйтесь поиском. Возможно, Ваш вопрос уже обсуждали. Полезные ссылки приведены ниже.
3. Темы с просьбой выполнить какую-либо работу за автора в этом разделе не обсуждаются.
4. Используйте теги [ code=cpp ] ...текст программы... [ /code ] для выделения текста программы подсветкой.
5. Помните, здесь телепатов нет. Старайтесь формулировать свой вопрос максимально грамотно и чётко: Как правильно задавать вопросы
6. Запрещено отвечать в темы месячной и более давности без веских на то причин.

Полезные ссылки:
user posted image FAQ Сайта (C++) user posted image FAQ Форума user posted image Наши Исходники user posted image Поиск по Разделу user posted image MSDN Library Online (Windows Driver Kit) user posted image Google

Ваше мнение о модераторах: user posted image B.V.
Модераторы: B.V.
  
> SHGetFolderPath и Сервис ( NT AUTHORITY\SYSTEM ) , SHGetFolderPath получить путь к %USER%\AppData\Local
    Доброе время суток .
    Есть программа которая запускается от сервиса т.е от прав (NT AUTHORITY\SYSTEM)

    ExpandedWrap disabled
      WCHAR szPath[MAX_PATH] = {0};
       
          if (SHGetFolderPathW(NULL, CSIDL_LOCAL_APPDATA, 0, SHGFP_TYPE_CURRENT, szPath) == S_OK)
          {
              
              
              MessageBoxW(0, szPath, L"ok", 0);
          }



    получаю C:\windows\system32\config\systemprofile\AppData\Local

    так вот как сделать так чтобы программа получала путь к %USER%\AppData\Local текущий сессии юзера ?


    запуск в сервисе через CreateProcessAsUserW и программа работает от сессии "администратора"(юзера ) но получает данные от (NT AUTHORITY\SYSTEM)
    Сообщение отредактировано: docroot -
      Цитата docroot @
      так вот как сделать так чтобы программа получала путь к %USER%\AppData\Local текущий сессии юзера ?

      А там разве не может быть несколько открытых сессий? Тебе, наверное нужен путь к папке конкретного пользователя?
        Цитата docroot @
        так вот как сделать так чтобы программа получала путь к %USER%\AppData\Local текущий сессии юзера ?

        Насколько я знаю, для доступа к профилю юзера надо сделать
        ExpandedWrap disabled
          ::ExpandEnvironmentStrings(_T("%USERPROFILE%")....

        Для запускаемого процесса надо создать EnvironmentBlock, посредством
        "CreateEnvironmentBlock". Иначе все переменные будут унаследованы
        от родительского процесса, что у тебя и происходит.
        Если вдруг переменная "%USERPROFILE%" окажется не определена,
        тогда можно пытаться решить проблему используя переменные
        %HOMEDRIVE% и %HOMEPATH%.
        Т.е. %USERPROFILE% это %HOMEDRIVE% + %HOMEPATH%
        И, если всё в UNICODE, тогда при создании дочернего процесса нужен флаг "CREATE_UNICODE_ENVIRONMENT".
        Сообщение отредактировано: ЫукпШ -
          Цитата docroot @
          так вот как сделать так чтобы программа получала путь к %USER%\AppData\Local текущий сессии юзера ?
          А там разве не может быть несколько открытых сессий? Тебе, наверное нужен путь к папке конкретного пользователя?

          я уточнил что
          Цитата
          ...текущий сессии юзера ...программа работает от сессии "администратора"(юзера )



          спасибо за ответ поводу функции CreateEnvironmentBlock так и на писано ->

          Цитата
          Retrieves the environment variables for the specified user. This block can then be passed to the CreateProcessAsUser function.



          Решения нашел через GetUserProfileDirectory токен получаем от explorer,
          или запускать через CreateProcessAsUser с токеном explorer'А .
          Но как я понимаю через CreateEnvironmentBlock это будет более элегантный вариант.

          Спасибо за ответы .
          Сообщение отредактировано: docroot -
            Есть ещё "ExpandEnvironmentStringsForUser".
            0 пользователей читают эту тему (0 гостей и 0 скрытых пользователей)
            0 пользователей:


            Рейтинг@Mail.ru
            [ Script execution time: 0,0234 ]   [ 16 queries used ]   [ Generated: 26.04.24, 20:21 GMT ]