Удаленное выполнение команд в системе Windows из консоли Linux. Установка из исходников Winexe 1.1 + Samba 4.5 на Debian 9 Stretch.

Содержание статьи:

Задался недавно вопросом, как можно из консоли Linux, подключится к удаленной машине с ОС Windows на борту и выполнить на ней какую либо команду (прим. «ipconfig») или запустить за ранее написанный скрипт (*.bat, *.ps1).

 

В ходе поиска решения данного вопроса, был найден инструмент Winexe, который по сути является аналогом psexec под Windows. Winexe работает в связке с Samba, поэтому последняя должна присутствовать в системе.

 

Из замеченных неудобств работы с Winexe, хочу отметить что для корректного отображения «кириллицы», необходимо конвертировать вывод в UTF-8 из cp866/cp1251. Так же в случае запуска на удаленной машине «cmd», «powershell» не работают клавиши курсора, «backspace» и возможен задвоенный ввод символов.

 

Установка будет производится на Debian 9 Stretch. В ходе установки будет использоваться Fork пакета Winexe 1.1 (https://sourceforge.net/u/mstowe/winexe/ci/v0.2/tree/), а так же версия Samba 4.5.16 из стандартные репозиториев Debian.

 

Подготовка системы

Обновляем систему до актуального состояния:

apt-get update && apt-get upgrade

Устанавливаем необходимые пакеты для сборки и работы «winexe»:

apt-get install gcc gcc-mingw-w64 make git python-dev pkg-config libgnutls28-dev libacl1-dev libldap2-dev samba-dev libsmbclient-dev

Для корректной сборки «winexe» делаем необходимые симлинки:

ln -s /usr/lib/x86_64-linux-gnu/samba/libcli-ldap.so.0 /usr/lib/x86_64-linux-gnu/samba/libcli-ldap-samba4.so.0 
ln -s /usr/lib/x86_64-linux-gnu/samba/libdcerpc-samba.so.0 /usr/lib/x86_64-linux-gnu/samba/libdcerpc-samba-samba4.so.0 
ln -s /usr/lib/x86_64-linux-gnu/samba/libsmbclient-raw.so.0 /usr/lib/x86_64-linux-gnu/samba/libsmbclient-raw-samba4.so.0
ln -s /usr/lib/x86_64-linux-gnu/samba/libsamba-debug.so.0 /usr/lib/x86_64-linux-gnu/samba/libsamba-debug-samba4.so.0

 

Установка Winexe

Скачиваем исходники «winexe», выполняем компиляцию и установку:

cd /opt
git clone git://git.code.sf.net/u/mstowe/winexe u-mstowe-winexe
cd u-mstowe-winexe/source
./waf configure build

Копируем скомпилированный «winexe» в (/usr/bin):

cp build/winexe /usr/bin/

 

Синтаксис использования «winexe»:

winexe -U [Domain/]User%Password //host command

 

Для примера выполним на удаленной машине команду «ipconfig»:

winexe -U Администратор%Aa1234567 //192.168.1.2 'ipconfig'

 ⣠®©ª  ¯௢®ª®«  IP ¤«ퟗindows


¤ ¯⦠ Ethernet Ethernet:

DNS-⤤䨪®¤ª«痢­¨힮 . . . . : 
®ª «쮫© IPv6- ¤ড ª ­ «  . . . : fe80::de2:f63f:7ae5:518d%6
IPv4- ¤ড. . . . . . . . . . . . : 192.168.1.2
 ᪠ ¯®¤ᦢ¨ . . . . . . . . . . : 255.255.255.0
᭮¢­®© 謮§. . . . . . . . . : 192.168.1.1

 

Как я и писал в начале, что в случае вывода с локалью отличной от вашей, мы получим не читаемые каракули. В примере выше, вывод был получен в кодировке «cp866», а текущая локаль моей системы «UTF-8».

 

Исправить это поможет пакет «luit», рассмотрим его установку и применение ниже.

 

Установка luit

Скачиваем исходники «luit», распаковываем архив:

wget https://invisible-island.net/datafiles/release/luit.tar.gz
tar -zxvf luit.tar.gz 
cd luit-20190106/

Выполняем сборку и установку пакета «luit»:

./configure --prefix= --datadir=/usr/share/luid
make
make install

 

Теперь перед запуском «winexe», указываем перекодировку из «cp866» в текущую:

luit -encoding cp866 winexe -U Администратор //192.168.1.2 'ipconfig'

Настройка протокола IP для Windows


Адаптер Ethernet Ethernet:

DNS-суффикс подключения . . . . . : 
Локальный IPv6-адрес канала . . . : fe80::de2:f63f:7ae5:518d%6
IPv4-адрес. . . . . . . . . . . . : 192.168.1.2
Маска подсети . . . . . . . . . . : 255.255.255.0
Основной шлюз. . . . . . . . . : 192.168.1.1

 

Дополнительно

Работоспособность пакета «winexe» проверил на системах Windows 7, 10, 2012R2, 2019. В случае с Windows 2012R2, 2019 пришлось на них установить компонент SMB 1.0/CIFS File Sharing Support

 

Понравилась или оказалась полезной статья, поблагодари автора

 

 

ПОНРАВИЛАСЬ ИЛИ ОКАЗАЛАСЬ ПОЛЕЗНОЙ СТАТЬЯ, ПОБЛАГОДАРИ АВТОРА

БесполезноСлабоватоПриемлемоОтличноПревосходно (1 голос(ов), в среднем: 5,00 из 5)
Загрузка...

Всего комментариев: 2 Комментировать

  1. Realmagnum /

    в тексте pspexec — должно быть psexec.

    1. Жаконда / Автор записи

      Спасибо, поправил!

Оставить ответ Жаконда Отменить ответ

1 × 3 =

© IT-блог Жаконды All Rights Reserved.
Яндекс.Метрика