Форум АНТИЧАТ

Форум АНТИЧАТ (https://forum.antichat.xyz/index.php)
-   С/С++, C#, Delphi, .NET, Asm (https://forum.antichat.xyz/forumdisplay.php?f=24)
-   -   Свой системный загрузчик с блекджеком и шлюхами (https://forum.antichat.xyz/showthread.php?t=187643)

Gar|k 17.03.2010 02:19

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

Проверка пароля учетной записи в windows меня никогда не радовала да и в unix тоже. А что до загрузки систмы? системный загрузчик так почему бы нам его не модифицировать?

Опираясь на статью Криса Касперски MBR своими руками я немного модифицировал загрузчик windows XP добавив туда проверку пароля (проверяется каждый символ - нужно ввести все сразу правильно, а если ошибся начинай заново) и написал установщик.

http://zona-chat.narod.ru/src/disk_write.jpg

СКАЧАТЬ
Программа установки загрузчика
изначально предлагает создать аварийную загрузочную флешку (которая запускает систему в обход mbr на жестком диске), а затем выбрать номер физического диска куда следует установить загрузчик.

Часть кода программы, функция записи в первый сектор физического диска
Код:

#define sPD "\\\\.\\PhysicalDrive%d"

int wr_disk(BYTE disks,unsigned char *data,size_t szdata) {
        unsigned char buf[1024],name[100],ndump[30];
        HANDLE hFile;
        HFILE f;
        //------
        DISK_GEOMETRY_EX dg; // структура геометрии диска
        DWORD junk;
        //------

        sprintf((LPSTR)name,sPD,disks);

        hFile=CreateFile((LPCSTR)name,GENERIC_READ, FILE_SHARE_READ,NULL,OPEN_EXISTING,0,0);
        if(hFile!=INVALID_HANDLE_VALUE)
        {
                if(DeviceIoControl(hFile,IOCTL_DISK_GET_DRIVE_GEOMETRY_EX,NULL,0,&dg,sizeof(DISK_GEOMETRY_EX),&junk,NULL))
                {
                        if(szdata>dg.Geometry.BytesPerSector){CloseHandle(hFile); return -1;}

                        SetFilePointer(hFile,0,0,FILE_BEGIN);
                        ReadFile(hFile,&buf[0],dg.Geometry.BytesPerSector,&junk,NULL);
                        CloseHandle(hFile);


                        sprintf((LPSTR)ndump,"dump_mbr.%6d",rand());
                        f=_lcreat((LPCSTR)ndump, 0);
                        _lwrite(f,(LPCCH)&buf[0],dg.Geometry.BytesPerSector);
                        _lclose(f);

                        memcpy(&buf[0],&data[0],szdata);

                        hFile=CreateFile((LPCSTR)name,GENERIC_WRITE, FILE_SHARE_WRITE,NULL,OPEN_EXISTING,0,0);
                        SetFilePointer(hFile,0,0,FILE_BEGIN);
                        WriteFile(hFile,&buf[0],dg.Geometry.BytesPerSector,&junk,NULL);
                        if(junk!=dg.Geometry.BytesPerSector){printf("Error write\n");}else{printf("%s write\tOK\n",name);}
                        CloseHandle(hFile);

                }
        }
}

Ради теста загрузчик можно записать на флешку и поставить в BIOS загрузку с USB (если ваша материнка это поддерживет). В принципе так можно и оставить. Я уверен ваши близкие будут в шоке и больше не подойдут к компьютеру пока вас нет дома :D

З.Ы: я не рекомендую ставить свой загрузчик как основной. Работает он и тестировал я его только под winXP (под win7 пишет boot error т.к там совершенно другая система загрузки)
В общем на свой страх и риск! После записи загрузчика оригинальный сохраняется в папке с программой как dump_mbr.*


Время: 17:12