У меня есть сценарий PowerShell, который регистрирует пользователей со временем IDLE, превышающим 1 час:
#Force script to run.
Set-ExecutionPolicy Unrestricted -force
#Check connected users and save output.
quser|out-file C:\Users\Administrator\Documents\disconectAgora\quser.txt
#Read output with logged in users.
$file = Get-Content C:\Users\Administrator\Documents\disconectAgora\quser.txt
#Obtain IDLE time by using patters.
$pattern = "Disc(.*?)11"
#Obtaons session ID by using patther.
$pattern2 = "adminagora(.*?)Disc"
#Execute query using above patterns.
$result = [regex]::Match($file,$pattern).Groups[1].Value
$result2 = [regex]::Match($file,$pattern2).Groups[1].Value
#Trim file and save both session id and username.
$result = $result -replace(' ','')
$result |out-file C:\Users\Administrator\Documents\disconectAgora\getDCUser.txt
$result2 = $result2 -replace(' ','')
$result2 |out-file C:\Users\Administrator\Documents\disconectAgora\getDCUserID.txt
#If IDLE time is greater than 1 hour user is disconnected.
if ($result -gt '1:00'){
logoff $result2
}
else{
write-host "No users with IDLE time greater than 1 hour found.No users to be logged off."
}
Что я хочу сделать, это проверить, запущен процесс cmd или нет, поэтому пользователь может остатьсявошел в систему, пока этот процесс не завершился.
Я подумал, что, возможно, запустив эту команду get-process | where-object {$_.mainwindowhandle -ne 0} | select-object name, mainwindowtitle
и используя регулярное выражение для получения только процессов cmd, он может добиться цели, но это очень примитивный подход.
Если вы, ребята, имеете какое-либо представление о том, как это сделать, пожалуйста, дайте мне знать.
По запросу, вот вывод команды quser:
Короче говоря
Мне нужен способ узнать, выполняется ли что-то с помощью CMD , кроме проверки использования ЦП: