Компьютерный форум OSzone.net  

Компьютерный форум OSzone.net (http://forum.oszone.net/index.php)
-   Скриптовые языки администрирования Windows (http://forum.oszone.net/forumdisplay.php?f=102)
-   -   Переменные. Скрипт на разных языковых версиях ОС (en/ru w10pro). (http://forum.oszone.net/showthread.php?t=342729)

rango13 30-10-2019 09:54 2894010

Переменные. Скрипт на разных языковых версиях ОС (en/ru w10pro).
 
Всем привет!

Необходимо написать скрипт со следующим алгоритмом:

1. Ввести имя машины
2. Проверить, что машина доступна по сети(т.е. отвечает на эхо-запросы команды ping)
3. Если да - проверить, кто из пользователей на ней залогинен на текущий момент и активен. Вытащить номер сессии пользователя в переменную.
4. Присоединиться к его оболочке/экрану/теневому сеансу(не знаю, как тут правильно назвать) средствами удалённого рабочего стола Windows на основании переменной из п.3. Типа Radmin.

У меня пока только вопрос по п.3 - команду по вытаскиванию всех сессий я нашёл:

Код:

PS C:\Users\administrator> $rdpsession = qwinsta /server:ivanovis | ForEach-Object { $_.Trim() -replace "\s+", "," } | ConvertFrom-Csv
PS C:\Users\administrator> $rdpsession

Код:

Результат вывода на русскоязычной версии ОС:
СЕАНС        : services
ПОЛЬЗОВАТЕЛЬ : 0
ID          : Диск
СТАТУС      :
ТИП          :
УСТР-ВО      :

СЕАНС        : console
ПОЛЬЗОВАТЕЛЬ : ivanovis
ID          : 1
СТАТУС      : Активно
ТИП          :
УСТР-ВО      :

СЕАНС        : rdp-tcp
ПОЛЬЗОВАТЕЛЬ : 65536
ID          : Прием
СТАТУС      :
ТИП          :
УСТР-ВО      :

Код:

Результат вывода на англоязычной версии ОС:
SESSIONNAME : services
USERNAME    : 0
ID          : Disc
STATE      :
TYPE        :
DEVICE      :

SESSIONNAME : console
USERNAME    : ivanovis
ID          : 1
STATE      : Active
TYPE        :
DEVICE      :

SESSIONNAME : rdp-tcp
USERNAME    : 65536
ID          : Listen
STATE      :
TYPE        :
DEVICE      :

Если мне необходимо извлечь значения поля "Сеанс" при запуске команды в ru-версии ОС, то я ввожу команду:
$rdpsession.Сеанс

Если необходимо сделать тоже самое в en-версии, то я ввожу команду:
$rdpsession.SESSIONNAME


Вопросы:
1. Необходимо писать несколько проверок на язык ОС и затем запускать соответствующую часть скрипта под нужный язык?
2. Или у этих параметров есть какие-то универсальные обозначения?

DJ Mogarych 30-10-2019 10:41 2894017

Код:

if ($rdpsession.Сеанс) {$rdpsession.Сеанс}
else {$rdpsession.SESSIONNAME}


Ageron 30-10-2019 11:40 2894027

Цитата:

Цитата rango13
Если да - проверить, кто из пользователей на ней залогинен на текущий момент и активен. Вытащить номер сессии пользователя в переменную. »

сделайте проще, сразу доставайте id

(Get-WmiObject -computername $CompRemote -query "Select logonid from Win32_LogonSession where logontype = 2").LogonId

Charg 30-10-2019 13:33 2894036

Цитата:

Цитата rango13
Присоединиться к его оболочке/экрану/теневому сеансу(не знаю, как тут правильно назвать) средствами удалённого рабочего стола Windows »

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

rango13 30-10-2019 16:27 2894063

Цитата:

Цитата Charg
Не зная пароля пользователя - не получится. »

Сеть доменная, на ПК сотрудников в локальную группу удалённого рабочего стола(и локальных администраторов) добавлен определённый пользователь.
С другого ПК, где залогинен этот пользователь запускается консоль и в ней вводится команда:

PS> qwinsta /server:ivanovis
Получаю вывод сессий, среди которых вижу ID пользователя, который работает за этим ПК. Затем пишу команду:
PS> mstsc /shadow:3 /v:ivanovis /control /noConsentPrompt

Загружается удалённый сеанс, где я вижу, что делает пользователь+я могу управлять курсором и передавать нажатия клавиш.
Вот статья на эту тему.

Iska 30-10-2019 17:56 2894066

Цитата:

Цитата Charg
RDP работает с сеансами, вклиниться в сеанс пользователя не являясь этим пользователем невозможно (средствами RDP). »

В домене, администратору — можно было (удалённое управление). А вот если сессия заблокирована — тогда да, нужно было знать пароль пользователя для разблокировки.

Как нынче с этим делом под новыми ОС — не знаю.

Charg 31-10-2019 18:06 2894190

Хм, был неправ, действительно подключиться к десктопным ОС можно, хотя и статьи говорят об обратном и везде речь идёт именно о серверах.

Iska 31-10-2019 21:31 2894203

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

rango13 15-12-2019 06:16 2900464

DJ Mogarych, Ageron, Charg, Iska, наконец-то освободилось время и написал скрипт уровня начинающий. Может, вам или вашим коллегам пригодится вдруг.
Удалённое подключение средствами ОС к работающему сеансу пользователя для удалённого решения его проблем
Код:

Import-Module ActiveDirectory
$encoding = [System.Text.Encoding]::UTF8
$MSRA = 'C:\Windows\System32\msra.exe'
$MSTSC = 'C:\Windows\System32\mstsc.exe'
$ipRegEx="\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}"
$i=1


### Ввод части имени компьютера для поиска в AD и проверка, существует ли такой ПК в домене.
### Если не существует - сообщить об этом и снова предложить ввести корректное имя ПК в домене.
[console]::ForegroundColor = "Green"
clear-host
$List_of_computers = "1"
$i=1

do {
    switch ($List_of_computers.length)
        {
            {$List_of_computers -eq "1"}
                {
                    $ComputerName = Read-Host "Введите часть имени компьютера для удалённого подключения через Windows Remote Assistance"
                }
            {$List_of_computers.length -eq 0}
                {
                    clear-host
                    $ComputerName = Read-Host "Компьютера с таким именем($ComputerName) не существует.`nПожалуйста, введите другое имя"
                }
        }

### "[dc.vektor.local]" - имя вашего домен-контроллера, если нужно искать конкретно на нём имена рабочиз станций
### 'OU=Workstations,DC=vektor,DC=local' - путь к OU, где располагаются все рабочие станции, по которым будет происходить выборка
    $List_of_computers = (Get-ADComputer -Server "[dc.vektor.local]" -SearchBase 'OU=Workstations,DC=vektor,DC=local' -LDAPFilter "(name=*$ComputerName*)" | Select Name -ExpandProperty Name | Sort)
} while ($List_of_computers.length -eq 0)


[console]::ForegroundColor = "White"

### Проверка - если найден только один ПК из найденных компьютеров в домене - занести в переменную $Targeted_Computer только его.
### Иначе вывести список найденных ПК с предложением выбора нужного компьютера и присовением имени выбранного ПК в переменную $Targeted_Computer
if ($List_of_computers.gettype().isArray -eq $False)
    {
      Write-Output "`nПо поисковому запросу найден только один компьютер($List_of_computers)`n"
      "[$i] " + $List_of_computers
      $Targeted_Computer=$List_of_computers
    }
        else {
                for (;$List_of_computers[$i-1];$i++)
                    {
                        "[$i]  "+ $List_of_computers[$i-1]
                    }
            $i=[int](Read-Host "Введите номер компьютера из списка или нажмите Ctrl+C - для завершения работы скрипта")
            $Targeted_Computer=$List_of_computers[$i-1]
            }

### После выбора ПК производится проверка сетевой доступности этого компьютера.
### Если по DNS-имени недоступен - появляется предложение ввести его IP-адрес, чтобы подключиться через него.
### Но, если ПК доступен по DNS-имени, то произвести проверку на версию ОС.
### Если версия ОС уровня Windows 7 - подключиться старым способом с запросом у юзера разрешения на доступ к его ПК
### Иначе подключиться к юзеру без запроса логина/пароля.
if (-not (Test-Connection -ComputerName $Targeted_Computer -Quiet -Count 1 -EA Silent))
    {
        $ComputerIP = Read-Host "Компьютер недоступен(не пингуется DNS-имя), попробуйте ввести его ip-адрес"
        if ($ComputerIP -notmatch $ipRegEx)
            {
                Write-Host "ip-адрес введён неверно, запустите скрипт заново"
                exit
            }
        start-Process -FilePath $MSRA -Args "/offerra \\$ComputerIP"
    }   
    else
        {
            $OsVer = (Get-WmiObject Win32_OperatingSystem -ComputerName "$Targeted_Computer").version
            if ($OsVer -match ("6.1"))
                {
                    start-Process -FilePath $MSRA -Args "/offerra \\$Targeted_Computer"
                }
                else
                    { 
### Здесь производится поиск номера сессии на удалённом ПК и занесение номера в переменную, чтобы использовать её для удаленного подключения
                            $i=0
                            $User_Session = (quser /server:$Targeted_Computer | Select-Object -skip 1 | ForEach-Object{$_.Split(' ',[System.StringSplitOptions]::RemoveEmptyEntries)})
                            foreach ($Session_name in $User_Session)
                                {
                                    if ($Session_name -like "console")
                                        {
                                            $rid = $User_Session[$i+1]
                                        }
                                    $i++
                                } 
                           
                            write-host "Запускается удалённый помощник на компьютере $Targeted_Computer"
                            start-Process -FilePath $MSTSC -Args "/shadow:$rid /v:$Targeted_Computer /control /noConsentPrompt"   
                    }
        }



Время: 17:16.

Время: 17:16.
© OSzone.net 2001-