Команда MSG существовала еще в Windows 2000/XP и предназначалась для обмена сообщениями между пользователями вошедшими в систему локально и пользователями терминальных сессий ( подключившихся к удаленному рабочему столу ) . В Windows Vista и более поздних операционных системах семейства Windows команда MSG стала основным стандартным средством обмена сообщениями, поскольку команда net send в данных ОС больше не поддерживается.
1. Описание команды MSG.
1.1. Формат командной строки:
C:\ MSG {пользователь | имя сеанса | ID сеанса | @имя файла | *} [/SERVER:сервер] [/TIME:секунд] [/V] [/W] [сообщение]
1.2. Описание параметров командной строки :
- пользователь — Имя пользователя.
- имя сеанса — Имя сеанса.
- ID сеанса — Идентификатор сеанса.
- @имя файла — Файл, содержащий список имен пользователей, сеансов или идентификаторов сеансов, которым отправляется сообщение.
- * — Отправить сообщение всем сеансам на указанном сервере.
- /SERVER:сервер — Сервер (по умолчанию — текущий).
- /TIME:секунд — Интервал ожидания подтверждения от получателя.
- /V — Отображение информации о выполненных действиях.
- /W — Ожидание ответа от пользователя, полезно вместе с /V.
- сообщение — Отправляемое сообщение. Если не указано, выдается запрос или принимается ввод из STDIN.
Важно!
Нынешняя реализация msg.exe прекрасно подходит для обмена сообщениями между сеансами локальных и терминальных пользователей в пределах одной системы, однако, в случаях обмена между разными компьютерами локальной сети, потребуется изменить некоторые настройки безопасности, принятые по умолчанию в операционных системах Windows Vista, 7 и более поздних.
1.3. При стандартных настройках, отправка сообщения пользователям удаленных компьютеров не выполняется и сопровождается сообщением:
Ошибка 1722 при получении имен сеанса
Это означает, что на компьютере, где должно приниматься посылаемое сообщение, невозможно получить информацию о вошедших в систему пользователях. Причиной может быть то, что брандмауэр блокирует входящие соединения, недостаточны права пользователя по отношению к удаленной системе, запрет удаленного вызова процедур в параметрах службы сервера терминалов. Как минимум, для обмена сообщениями с использованием команды msg между компьютерами, необходимо иметь учетную запись пользователя, действительную по отношению к удаленной системе и на каждом компьютере, которому будут отправляться сообщения, добавить в раздел реестра HKLM\SYSTEM\CurrentControlSet\Control\Terminal Server параметр AllowRemoteRPC типа REG_DWORD и равный 1.
Для изменения настроек можно использовать .reg-файл следующего содержания:
Windows Registry Editor Version 5.00 [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Terminal Server] "AllowRemoteRPC"=dword:00000001
В ОС Windows Vista, Windows 7, 8, 10 ключ реестра AllowRemoteRPC существует, но имеет значение равное 0 , что необходимо исправить. Для применения изменений требуется перезагрузка.
1.4. Поскольку для обмена сообщениями утилита msg.exe использует протокол SMB (Server Message Block), на каждом компьютере, которому будут отправляться сообщения, должен быть открыт TCP порт 445.
2. Примеры использования MSG.
2.1. Отправить тестовое сообщение всем пользователям компьютера Server:
C:\ msg * /server:Server "Тестовое сообщение "
2.2. Отправить тестовое сообщение всем пользователям компьютера с IP-адресом 192.168.0.1:
msg * /server:192.168.0.1 "Тестовое сообщение "
2.3. Отправить тестовое сообщение пользователю терминальной сессии с именем RDP-Tcp#0 на компьютере TSServer:
msg RDP-Tcp#0 /server:TSServer "Тестовое сообщение"
2.4. Отправить тестовое сообщение текущему локальному пользователю компьютера Windows7:
msg console /server:Windows7 "Тестовое сообщение"
2.5. Отправка тестового сообщения от пользователя сеанса RDP локальному пользователю:
msg console "Тестовое сообщение"
Если эта команда выполняется не пользователем терминальной сессии, то сообщение будет отправлено локальным пользователем самому себе.
Для выполнения команды msg от имени другого пользователя можно воспользоваться утилитой PSExec из пакета PSTools или штатным средством runas.exe:
psexec -u otheruser -p otherpass msg * /server:win10 TEST message runas /user:otheruser "msg * /server:win10 Test message"
Сообщения, отправляемые командой msg локальному пользователю компьютера с операционной системой Windows XP, который отсутствует ( еще не вошел в Windows ) отображаются в окне с приглашением к регистрации в системе и могут быть доступны посторонним.