Page 1 of 1

Get Wifi Passwords

Posted: 2021-Jul-25, 7:57 am
by MigrationUser
26 Jan 2015 02:06
Seinu


Hello All,
This script runs several commands that eventually spits out a log file at C:\wifipass.log containing all saved wifi profiles with clear text passwords. It automatically requests admin access which is required to get the clear text passwords. I'm hoping some more experienced coders can help make this script better.

Code: Select all

'Creates new instance of script as Administrator
Set WshShell = WScript.CreateObject("WScript.Shell")
If WScript.Arguments.length = 0 Then
Set ObjShell = CreateObject("Shell.Application")
ObjShell.ShellExecute "wscript.exe", """" & _
WScript.ScriptFullName & """" &_
 " RunAsAdministrator", , "runas", 1
End If

'create file system object as objFSO
'create string as strLine
Dim objFSO, strLine
Set objFSO = CreateObject("Scripting.FileSystemObject")

'Create Shell object to run a command
'start log hotspot profiles to C:\profiles.log
'sleep for 5 seconds
Set objShell = WScript.CreateObject("WScript.Shell")
objShell.Run ("cmd /k netsh wlan show profiles > C:\profiles.log"), 0 
WScript.Sleep(5000)

'get cleaned profiles from profiles.log
'open text file C:\profiles.log for reading
'create C:\profiles.dat for writing cleaned hotspot names
Set Rprofileslog = objFSO.OpenTextFile("C:\profiles.log")
Set Wprofilesdat = objFSO.CreateTextFile("C:\profiles.dat")

'loop reading lines until end of file is reached
'read each line as strLine
'if text ": " is found in the line then
'cut the line from beginning of hotspot name to end of line
'write each saved hotspot name to C:\profiles.dat in a newline
Do Until Rprofileslog.AtEndOfStream
	strLine = Rprofileslog.Readline
	if instr(strLine, ": ") Then
		strLine = Mid(strLine, 28)
		Wprofilesdat.WriteLine(strLine)
	End If
Loop

'closes both opened files profiles.log and profiles.dat
Rprofileslog.Close
Wprofilesdat.close

 'open profiles.dat for reading
 'loop through hotspot names
 'get full information with clear text password for each profile
 'sleep for 2.5 seconds
Set Rprofilesdat = objFSO.OpenTextFile("C:\profiles.dat")
Do Until Rprofilesdat.AtEndOfStream 
	strLine = Rprofilesdat.Readline 
	objShell.Run ("cmd /k netsh wlan show profile name=""" & strLine & """ key=clear >> C:\Wifi.log"), 0
	WScript.Sleep(2500)
Loop

 'closes previously opened file profiles.dat
Rprofilesdat.Close

'open wifi.log for reading
'create C:\wifipass.log to hold hotspots and their passwords
Set RWifilog = objFSO.OpenTextFile("C:\Wifi.log") 'open profiles.log for reading
Set Wwifipasslog = objFSO.CreateTextFile("C:\wifipass.log") 'create wifipass.log for writing cleaned wifi profiles

'loop through each line of wifi.log
'search for "SSID name" to find the line with hotspot name
'copy hotspot name and write to wifipass.log
'search for "Key Content" to find the line with hotspot password
'copy hotspot password and write to wifipass.log prefixed with "Password = "
Do Until RWifilog.AtEndOfStream
	strLine = RWifilog.Readline
	if instr(strLine, "SSID name") Then
		strLine = Mid(strLine, 30)
		Wwifipasslog.WriteLine(strLine)
	End If
	if instr(strLine, "Key Content") Then
		strLine = Mid(strLine, 30)
		Wwifipasslog.WriteLine("Password = " & strLine)
	End If
Loop

'closes previously opened files Wifi.log and wifipass.log
RWifilog.Close
Wwifipasslog.close
'sleep for 5 seconds
WScript.Sleep(5000)


'clean tracks by deleting unused files
objFSO.DeleteFile("C:\profiles.log")
objFSO.DeleteFile("C:\profiles.dat")
objFSO.DeleteFile("C:\Wifi.log")

' **START** work in progress **START**
'------------------------------------------------
'If (fso.FileExists("C:\profiles.log")) Then
'	objFSO.DeleteFile("C:\profiles.log")
'Else
'	WScript.Echo("File does not exist!")
'End If
'
'If (fso.FileExists("C:\profiles.log")) Then
'	objFSO.DeleteFile("C:\profiles.dat")
'Else
'	WScript.Echo("File does not exist!")
'End If
'
'If (fso.FileExists("C:\profiles.log")) Then
'	objFSO.DeleteFile("C:\Wifi.log")
'Else
'	WScript.Echo("File does not exist!")
'End If
'------------------------------------------------
' **STOP** work in progress **STOP**


'**Start** kill all used processes so no tracks are left **Start**

'cmd.exe
strComputer = "."
Set objWMIService = GetObject("winmgmts:" _
& "{impersonationLevel=impersonate}!\\" & strComputer & "\root\cimv2")
Set colProcessList = objWMIService.ExecQuery _
("SELECT * FROM Win32_Process WHERE Name = 'cmd.exe'")
For Each objProcess in colProcessList
	objProcess.Terminate()
Next

'conhost.exe
strComputer = "."
Set objWMIService = GetObject("winmgmts:" _
& "{impersonationLevel=impersonate}!\\" & strComputer & "\root\cimv2")
Set colProcessList = objWMIService.ExecQuery _
("SELECT * FROM Win32_Process WHERE Name = 'conhost.exe'")
For Each objProcess in colProcessList
	objProcess.Terminate()
Next

'kill random access denied popup
strComputer = "."
Set objWMIService = GetObject("winmgmts:" _
& "{impersonationLevel=impersonate}!\\" & strComputer & "\root\cimv2")
Set colProcessList = objWMIService.ExecQuery _
("SELECT * FROM Win32_Process WHERE Name = 'wscript.exe'")
For Each objProcess in colProcessList 'loop for all processes
	objProcess.Terminate()
Next
'**Stop** kill all used processes so no tracks are left **Stop**

Set objFSO = nothing


----------------------------

#2 05 Feb 2015 05:01
Hackoo


Re: Get Wifi Passwords

Hi ;)
This vbscript is tested on french machines and on windows 7 32 bits and it works 5/5 ! wink
Hope it works for you smile just give a try and let me know

Code: Select all

'Show_Wifi_Keys by Hackoo 2014
Option Explicit
Dim MyCmd,Temp,Titre,MsgTitre,MsgAttente,Copyright,oExec,ws,WshNetwork,NomMachine
Copyright = "Exportation du résumé des informations du système sans fil avec les clés de sécurité © Hackoo 2014"
Set ws = CreateObject("WScript.Shell")
Set WshNetwork = CreateObject("WScript.Network")
NomMachine = WshNetwork.ComputerName
Temp = ws.ExpandEnvironmentStrings("%Temp%")
Titre = Copyright
MsgAttente = "Veuillez patienter. Exportation du résumé des informations du système sans fil avec les clés de sécurité . . . . "
Call CreateProgressBar(Titre,MsgAttente)
Call LancerProgressBar()
Call Pause(1)
Call Show_Wifi_Keys()
Call FermerProgressBar()
'**************************************************************************************
Function Executer(StrCmd,Console)
	Dim ws,MyCmd,Resultat
	Set ws = CreateObject("wscript.Shell")
'La valeur 0 pour cacher la console MS-DOS
	If Console = 0 Then
		MyCmd = "CMD /C " & StrCmd & ""
		Resultat = ws.run(MyCmd,Console,True)
		If Resultat = 0 Then
'MsgBox "Success"
		Else
			MsgBox "Une erreur inconnue est survenue !",16,"Une erreur inconnue est survenue !"
		End If
	End If
'La valeur 1 pour montrer la console MS-DOS
	If Console = 1 Then
		MyCmd = "CMD /K " & StrCmd & ""
		Resultat = ws.run(MyCmd,Console,True)
		If Resultat = 0 Then
'MsgBox "Success"
		Else
			MsgBox "Une erreur inconnue est survenue !",16,"Une erreur inconnue est survenue !"
		End If
	End If
	Executer = Resultat
End Function
'**************************************************************************************
Sub Show_Wifi_Keys()
	Dim objShell,fso,File,strContents,objRegEx,objMatch,colMatches
	Dim UnicodeFile,AsciiFile
	UnicodeFile = "Unicode_Cles_Wifi.txt"
	AsciiFile = "Cles_Wifi_"& NomMachine & ".txt"
	set objShell = CreateObject("WScript.Shell")
	Set fso = CreateObject("Scripting.FileSystemObject") 
	Call Executer("netsh wlan show all > Cles_WifiTmp.txt",0)
	Set File = fso.OpenTextFile("Cles_WifiTmp.txt",1)
	strContents = File.ReadAll
	File.Close
	Set objRegEx = New RegExp
	objRegEx.IgnoreCase = True
	objRegEx.Global = True
	objRegEx.Multiline = True
	objRegEx.Pattern = """([^""]+)"""
	set colMatches = objRegEx.Execute(strContents)
	Call Executer("Echo ****************************************************************** >> Cles_WifiTmp.txt"_
	& "& echo Clés Wifi de sécurité avec les SSID enregistrés sur %ComputerName% >> Cles_WifiTmp.txt"_
	& "& echo. & echo ****************************************************************** >> Cles_WifiTmp.txt",0)
	For each objMatch in colMatches
		Call Executer("echo "& objMatch.Value &" >> Cles_WifiTmp.txt & echo. >> Cles_WifiTmp.txt & Netsh wlan show profiles name="& objMatch.Value &" key=clear | Findstr /i ""Conten"" >> Cles_WifiTmp.txt"_
		& "& echo. & echo ******************************************************************>> Cles_WifiTmp.txt & cmd /U /C Type Cles_WifiTmp.txt > "& UnicodeFile & "",0)
	Next
	Call Convert(UnicodeFile,AsciiFile)
	Call Executer("Start "& AsciiFile & "& Del Cles_WifiTmp.txt & Del "& UnicodeFile & "",0)
End sub
'***************************************************************************************
Sub WLAN_Networks()
	If Executer("netsh wlan show profiles > Wlan_tmp.txt & netsh wlan show networks >> Wlan_tmp.txt & netsh wlan show interfaces >> Wlan_tmp.txt & cmd /U /C Type Wlan_tmp.txt > Wlan_Networks.txt",0) = 0 Then
		Call Executer("Start Wlan_Networks.txt & Del Wlan_tmp.txt",0)
	End If
End Sub
'***************************************************************************************
Function DblQuote(Str)
	DblQuote = Chr(34) & Str & Chr(34)
End Function
'***************************************************************************************
'Pour Convertir le LogFile de Unicode en Ascii
Sub Convert(UnicodeFile,AsciiFile)
	Const ForReading = 1, ForWriting = 2, ForAppending = 8
	Const ModeAscii = 0, ModeUnicode = -1
	Dim fso, f_in, f_out
	Set fso = CreateObject("Scripting.FileSystemObject" )
	Set f_in = fso.OpenTextFile(UnicodeFile, ForReading,, ModeUnicode)
	Set f_out = fso.OpenTextFile(AsciiFile, ForWriting, true, ModeAscii)
	Do Until f_in.AtEndOfStream
		f_out.Write f_in.Read(1)
	Loop
	f_in.Close
	f_out.Close
End Sub
'****************************************************************************************
Sub CreateProgressBar(Titre,MsgAttente)
	Dim ws,fso,f,f2,ts,ts2,Ligne,i,fread,LireTout,NbLigneTotal,Temp,PathOutPutHTML,fhta,oExec
	Set ws = CreateObject("wscript.Shell")
	Set fso = CreateObject("Scripting.FileSystemObject")
	Temp = WS.ExpandEnvironmentStrings("%Temp%")
	PathOutPutHTML = Temp & "\Barre.hta"
	Set fhta = fso.OpenTextFile(PathOutPutHTML,2,True)
	fhta.WriteLine "<HTML>"
	fhta.WriteLine "<HEAD>"
	fhta.WriteLine "<Title>  " & Titre & "</Title>"
	fhta.WriteLine "<HTA:APPLICATION"
	fhta.WriteLine "ICON = ""magnify.exe"" "
	fhta.WriteLine "BORDER=""THIN"" "
	fhta.WriteLine "INNERBORDER=""NO"" "
	fhta.WriteLine "MAXIMIZEBUTTON=""NO"" "
	fhta.WriteLine "MINIMIZEBUTTON=""NO"" "
	fhta.WriteLine "SCROLL=""NO"" "
	fhta.WriteLine "SYSMENU=""NO"" "
	fhta.WriteLine "SELECTION=""NO"" "
	fhta.WriteLine "SINGLEINSTANCE=""YES"">"
	fhta.WriteLine "</HEAD>"
	fhta.WriteLine "<BODY text=""white""><CENTER>"
	fhta.WriteLine "<marquee DIRECTION=""LEFT"" SCROLLAMOUNT=""3"" BEHAVIOR=ALTERNATE><font face=""Comic sans MS"">" & MsgAttente &"</font></marquee>"
	fhta.WriteLine "<br><img src="""" />"
	fhta.WriteLine "</CENTER></BODY></HTML>"
	fhta.WriteLine "<SCRIPT LANGUAGE=""VBScript""> "
	fhta.WriteLine "Set ws = CreateObject(""wscript.Shell"")"
	fhta.WriteLine "Temp = WS.ExpandEnvironmentStrings(""%Temp%"")"
	fhta.WriteLine "Sub window_onload()"
	fhta.WriteLine "    CenterWindow 600,100"
	fhta.WriteLine "    Self.document.bgColor = ""DarkOrange"" "
	fhta.WriteLine " End Sub"
	fhta.WriteLine " Sub CenterWindow(x,y)"
	fhta.WriteLine "    Dim iLeft,itop"
	fhta.WriteLine "    window.resizeTo x,y"
	fhta.WriteLine "    iLeft = window.screen.availWidth/2 - x/2"
	fhta.WriteLine "    itop = window.screen.availHeight/2 - y/2"
	fhta.WriteLine "    window.moveTo ileft,itop"
	fhta.WriteLine "End Sub"
	fhta.WriteLine "</script>"
	fhta.close
End Sub
'**********************************************************************************************
Sub LancerProgressBar()
	Set oExec = Ws.Exec("mshta.exe " & Temp & "\Barre.hta")
End Sub
'**********************************************************************************************
Sub FermerProgressBar()
	oExec.Terminate
End Sub
'**********************************************************************************************
Sub Pause(NSeconds)
	Wscript.Sleep(NSeconds*1000)
End Sub  
'**********************************************************************************************
----------------------------

#3 06 Feb 2015 17:21
Seinu


That script is simply beautiful that should prove to be excellent reference to learn how to code better vbscript

original thread: https://ss64.org/oldforum/viewtopic.php?id=1965