Определение где находятся все установленные VisualStudio

W

Watchman

Original poster
Как-то утром на рассвете. Поезд рельсы потеряет.
Вспыхнет зарево в колодце. Хрустнет веточка в овраге.
Порвутся штаны от широкой походки...
Всем хай, не стану писать статью, как обычно. Просто скину сорцы с комментами.
Имелся у меня криптор. который я поддерживал аж с 2010 года, точнее криптокомбайн. В его комплект входил автобилдер, выдающий сразу несколько копий криптованного софта с уникальными сигнатурами при компиляции стаба. С недавнего времени я его забросил практически, но назрел вопрос "защитить" новый софт. Так как он перекомбайнивался при помощи спец утилиты, которую я писал для MS VisualStudio 2010 SP1. Обнаружил, что новые студии уже как раньше в реестре не прописываются, поэтому сочинил приблуду, которая ищет ВСЕ студии установленные в винде. Но так как мой криптор Xeon далеко ушёл , впрочем как и АВ - его необходимо пересобирать на разных компиляторах/линкерах с учетом, что это будет автоматически и без всяких костылей.
В общем сабж (там не обращайте внимание на замеры производительности - это для крипта и OpenMP в принципе тож не надо, если токо пригодится кому).
Компилять под 2019 студию, солюшен в комплекте.

C++:
#include <windows.h>
#include <stdio.h>
#include <conio.h>
#include <omp.h>



//Частота генератора
volatile LARGE_INTEGER li_freq;
//_______________________________________________________________________________________________________
//Есть ли файло?
bool __fastcall FileExists(char* szFullFileName)
{
    return (GetFileAttributesA(szFullFileName) != DWORD(-1));
}

//_______________________________________________________________________________________________________
//Функа для замера текущих тиков проца ;)
__forceinline double   PerfCounterX()
{
    LARGE_INTEGER li_pc;
    if (TRUE != QueryPerformanceCounter(&li_pc))
    {
        printf("Error in QueryPerformanceCounter() - Err=%d\n", GetLastError());
        return -1.;
    }
    return (double)li_pc.QuadPart / li_freq.QuadPart;
}

int main()
{
  
  
    if (TRUE != QueryPerformanceFrequency((LARGE_INTEGER*)&li_freq))
    {
        printf("Error in QueryPerformanceFrequency() - Err=%d\n", GetLastError());
        return -1;
    }
    double t1_0 = PerfCounterX();
    //распараллеливаем цикл на ядра через OpenMP для прикола ;)
    //не удивляемся, что вывод идёт не по порядку но нам пофиг, мы выигрываем микросекунды :)))
    //Включите в компиляторе /openmp - если делать нефиг
    #pragma omp parallel
    {
        #pragma omp for
        //Перебор всех студий начиная с 2010
        for (int i = 0; i <=9; i++)
        {
            char szPathVS[MAX_PATH * 2] = { 0 };
            char szCurPathVS[MAX_PATH * 2] = { 0 };
            char szCurEnv[MAX_PATH * 2] = { 0 };
            char szTemp[MAX_PATH * 2] = { 0 };

            sprintf_s(szTemp, "VS1%d", i); //здесь название студии
            sprintf_s(szCurEnv,"%s0COMNTOOLS", szTemp); //Формируем название системной переменной
            if (GetEnvironmentVariableA(szCurEnv, szCurPathVS, MAX_PATH * 2 - 1))
            {
                //Есть такая переменная - уходим в подкаталоги
               // printf("Path in Environment %s = %s\n", szTemp, szCurPathVS);
                char* szNtemp = strrchr(szCurPathVS, '\\');
                if (szNtemp)
                {
                   szNtemp[0] = 0;
                   szNtemp = strrchr(szCurPathVS, '\\');
                    if (szNtemp)
                    {
                        szNtemp[sizeof(char)] = 0;
                        sprintf_s(szPathVS, "%sIDE\\devenv.exe", szCurPathVS);
                        if (FileExists(szPathVS))
                        {
                            //О и файло студии есть!
                            printf("Path Devenv %s = %s\n", szTemp, szPathVS);
                        }
                    }
                }
            }
            else
            {
                //Если через COMMONTOOLS не нашли то более поздние версии через VS....INSTALLDIR
                sprintf_s(szTemp, "VS201%d", i); ////здесь название студии
                sprintf_s(szCurEnv, "%sINSTALLDIR", szTemp); //Формируем название системной переменной

                //printf("---%s\n", szCurEnv);

                if (GetEnvironmentVariableA(szCurEnv, szPathVS, MAX_PATH * 2 - 1))
                {
                    //Есть такая переменная
                    strcat_s(szPathVS, "\\Common7\\IDE\\devenv.exe");
                    if (FileExists(szPathVS))
                    {
                        //О и файло студии есть!
                        printf("Path Devenv %s = %s\n", szTemp, szPathVS);
                    }
                    
                }
            }
        }
    }
    double t1 = PerfCounterX();
    printf("Found in: %.8lf[sec]\n",t1 - t1_0);

    printf("Press any key to exit...\n");
    _getch();
}

//P.S.: для чего это нужно иногда.
//Недавно стала задача автоматически собирать солюшены из своего собственного приложения
//Так как после 2010 студии к сожалению уже не прокатывает как для 2010 студии - брать чисто в реестре
//вот так:
//***************
////Получение пути к devenv 10 -й студии
//BOOL GetStudioPath()
//{
//    LONG lResult;
//    LPCWSTR lpSubKey = L"SOFTWARE\\Microsoft\\VisualStudio\\10.0_Config";
//    HKEY hKey;
//    if (lResult = RegOpenKeyEx(HKEY_CURRENT_USER, lpSubKey, 0, KEY_READ, &hKey) != ERROR_SUCCESS)
//    {
//        printf("Error open key\n");
//    }
//    else
//    {
//        DWORD BuffLen = sizeof(wcDevenv);
//        if (RegQueryValueEx(hKey, L"InstallDir", NULL, NULL, (LPBYTE)&wcDevenv, &BuffLen) != ERROR_SUCCESS)
//        {
//            printf("Error RegQueryValue key\n");
//            RegCloseKey(hKey);
//            return FALSE;
//        }
//        else
//        {
//            wcscat(wcDevenv, L"devenv.exe");
//            wprintf(L"Path: %s Found \n________________________________________________________________________\n", wcDevenv);
//        }
//        RegCloseKey(hKey);
//        return TRUE;
//    }
//    return FALSE;
//}
//*************

//То путём небольших исследований пришлось сделать по другому, это с угетом что ни через SetipAPI ,
// ни через WMI мы не получим всех VisualStudio что установлены, и конкретно нас интересующего
//его шелла devenv.exe так необходимого для пересборки криптора и так удобного.

//P.P.S: за openMP и замеры производительности не обессудьте - это кусок проекта, так сказать "надо".
Сорцы (солюшен 2019 студии):

Авторизируйтесь или Зарегистрируйтесь что бы просматривать ссылки.

 
  • Like
Реакции: Admin
Название темы
Автор Заголовок Раздел Ответы Дата
Ёшкин_кот Интересно Определение объёма встроенной видео памяти на ноутбуке. Свободное общение и флейм 0
B ПРОБИВ МЕГАФОН МТС БИЛАЙН РОСТЕЛЕКОМ!! ДЕТАЛИЗАЦИИ С БС БИЛАЙН!! ОПРЕДЕЛЕНИЕ МЕСТОПОЛОЖЕНИЯ БИЛАЙН Ищу работу. Предлагаю свои услуги. 5
A Определение типа документа (DTD) Другие ЯП 0
Q Где можно купить стилер? Вопросы и интересы 1
G "Грязный" биткоин. Где купить? Свободное общение и флейм 3
Support81 Где и как вы знакомитесь с девушками? Свободное общение и флейм 0
M Приглашаю всех, кто знаком с MLM и сетевым маркетингом в тему, где вы максимально монетизируете свои навыки! Предоставляю работу. Ищу специалиста. 0
Support81 Просчитались, но где? Заказ на убийство в зашифрованном чате обернулся для бандитов тюрьмой Новости в сети 0
M Где взять немецкие базы для брута ? Вопросы и интересы 0
АнАлЬнАя ЧуПаКаБрА Zabugor 260K. где - то 95% вадида. USA, Германия, Франция Раздача email 0
АнАлЬнАя ЧуПаКаБрА Zabugor 531K. Валида где - то 60 - 70% Раздача email 0
Tania1212 Создал Discord сервер где будет моя музыка … Видео/Музыка 1
E Закрыто Chaturbate/stripchat - сайт где за токены девушки выполняют ваши грязные желания Корзина 1
K где взять базы для брута много гб Вопросы и интересы 3
M Интересно Где искать рефералов [для новичков] Способы заработка 1
X Закрыто где продать акк? Корзина 1
T Где купить ipv4 на 1 день? Вопросы и интересы 0
I Где разместить? Вопросы и интересы 1
АнАлЬнАя ЧуПаКаБрА INLINE Шоп где есть гифты на разные сервисы, также в сервисе есть токены и купоны Проекты Private Keeper 0
D Кто знает где можно найти недорогой VPS с поддержкой виртуализации на уровне процессора? Вопросы и интересы 2
АнАлЬнАя ЧуПаКаБрА INLINE Сайт где за баланс можно заказать E-mail рассылку Проекты Private Keeper 0
Ф Где купить приватные читы ? Вопросы и интересы 7
Ф Где скачивать читы ? Вопросы и интересы 6
S Вывожу с любых сервисов где нужен валид. Ищу работу. Предлагаю свои услуги. 0
С Где найти фотографии ? Вопросы и интересы 5
Т Банковские карты, где купить анонимную с пин кодом? Вопросы и интересы 4
G Где искать новую информацию кардеру Полезные статьи 3
K Seoxa - крупный портал где куча сладчин по заработку, сливы, софт и прочее со всеми темами и без хайдов Дамп форума Другое 6
АнАлЬнАя ЧуПаКаБрА [Private Keeper] Пак проектов где вывод без валида + Reg check Проекты Private Keeper 0
J Где сейчас можно купить скан доков Вопросы и интересы 13
U Простой способ накрутки чего угодно, где угодно. СИ/Фишинг/Мошенничество 10
N Где достать сим карты оптом по МСК ? Вопросы и интересы 0
U Хочу знаний! Где взять? Вопросы и интересы 10
O Где купить аккаунты VK? Вопросы и интересы 1
Т Где найти действующую программу для взлома электронной почты Вопросы и интересы 0
D Где спамить и получать профит Вопросы и интересы 6
K Где купить энкодер? Вопросы и интересы 0
P Где можно достать хороший брутфорсер вк с капчей? Вопросы и интересы 3
C Где взять базу аккаунтов вк? Полезные статьи 1
S Где взять живой файловый трафик? Вопросы и интересы 1
C Где можно покупать вк аккаунты? Вопросы и интересы 3
K Куплю Где купить скимер и сколько стоит? Куплю/Продам 1
T Где можно получить дедик на тестовый период Полезные статьи 2
D Помогите чайнику , где брать прокси и аккаунты для загрузки, заранее спасибо Вопросы и интересы 1
S Где достать сканы паспортов и другие доки Другое 3
Admin Список форумов где нам купить рекламу Информация по работе сайта и форума 6
Admin Нашелся где то в закромах харда мануал по хардкорной настройке тора. Взял в паблике. Анонимность и приватность 3

Название темы