Хитрости bat-файлов.

Описание и фишки batch файлов.

Для начала давай разбёремся в том, что же такое batch'и. Прежде всего - это пакетные дос файлы, которые содержат в себе в ascii виде набор досовских команд. По-русски говоря, bat файл содержит в себе скрипт, интерпритатором служит command.com.

Поясняю: после прочтения этой статьи, ты сможешь писать проги, которые удаляют сис-темные файлы, форматируют диски и тд. Главное, тебе для этого понадобится только блокнот и прямые руки, никаких компиляторов и дебагеров не требуется (бачи не такие примитивные, как тебе кажется - есть вирусы\генераторы, на них написанные).

И ещё. Я не буду описывать все возможные флаги(параметры) каждой команды, только наиболее полезные.

Ну чё, готов? Поехали!

Простые команды:

Фишки, хитрости:

  1. choice /N /T:y,%сек% > nul - типа таймера (на n секунд задерживает выполнение после-дующих команд).

  2. %команда% > nul - запрещение вывода на экран самой команды и результата её дейст-вия (полезно при команде "copy"). Пример: copy c:\some.exe %windir%\some.exe > nul

  3. regedit /s %путь\файл.reg% - добавить ключи в реестр из файла, без вопросов

  4. start /m /w %путь\файл% - запустить файл в свёрнутом окне.

  5. слышал про файл Autoexec.bat? Знаешь, что он грузится вместе с компом? Наверное, да. Так вот, он имеет расширение BAT. На что я намекаю? На то, что ты можешь в него про-писать строчку, к примеру, "format C: /q" (прописывается она вот так: echo format C: /q >> c:\Autoexec.bat) и во время перезагрузки у жертвы отформатируется диск С.
    Это я к тому, что любой скрипт, вставленный в этот файл, будет выполнен при загрузке компа. Также можешь создать в каталоге с виндой файл winstart.bat. Он также запустится виндоусом.

  6. это относиться как раз к фишке с Autoexec'ом. К примеру, если ты положишь в каталог windows\command файл к примеру "load.bat" (наверное с плохим содержанием), это файлу из autoexec'a с вероятностью в 90% можно будет запустить строчкой "load". И это ещё от-стой… Ты сможешь загружать этот файл такой строчкой: "load keybrd32.sys,,cyr\lat" или такой: "load VideoAdapter32.drv -- By windows setup --". Вряд ли такие строчки рискнёт кто-нибудь удалять и твой файл без трабл загрузится.

  7. if exist c:\Progra~1 set drv=c:
    if exist d:\Progra~1 set drv=d:
    if exist d:\Progra~1 set drv=e:
    После выполнения этого скрипта в переменной %drv% будет прописан диск с Виндой, с Program Files'ами.

  8. в переменной %windir% хранится каталог с виндоусом в таком виде:
    диск:\название_каталога. Пример: copy c:\some.exe %windir%\some.exe

  9. batch скрипты не любят длинные, либо состоящие из двух слов, названия. Длинные уре-заются до 6-ти букв (после них должно стоять "~1", к примеру "Program Files -> Progra~1"). Пробелы он просто убирает (The Bat -> TheBat~1).
    Это я к тому, что в бачах обращайся к файлам по их досовским названиям. Пример: copy c:\some.exe c:\Progra~1\some.exe (копируется файл в папку Program Files).

  10. echo var WSHShell = WScript.CreateObject("WScript.Shell"); > %temp%\mes.js echo WSHShell.Popup("твой_текст"); >> %temp%\mes.js
    start %temp%\mes.js
    deltree /y %temp%\mes.js

Этот скрипт выводит на экран _Виндовое_ окошко (посредством Java Script) с твоим со-общением и кнопкой ОК.

Ну вот наверно и всё! Здесь я умолчал о переменных, циклах и создании меню в batch'ах, так как это довольно объёмные темы. Следующая статья будет как раз посвещена им.

Автор: D4rkGr3y