涛之雨 发表于 2021-1-24 10:53

【bat脚本】读取当前设备wifi密码(仅win10测试)

本帖最后由 涛之雨 于 2021-1-24 13:56 编辑

Win10查看WiFi密码小技巧
https://www.52pojie.cn/thread-1357342-1-1.html
(出处: 吾爱破解论坛)

根据这个帖子的代码,似乎很有意思,但是使用比较麻烦。
需要手动复制wifi名称
因此写了这个脚本。
仅供参考。

第二版:

[*]新增了输出文件到文本(其实bat输出后鼠标拖拽选择然后点击右键就可以复制了。。。)
[*]修改了去除空白的模式,代码更简洁

@echo off
color 2f
mode con: cols=40 lines=15
title WiFi密码查询
echo 正在查询结果
setlocal enabledelayedexpansion
for /f "tokens=2* delims=:" %%i in ('netsh wlan show profiles') do (
    set str=%%i
    for /f "tokens=3* delims= " %%d in ('netsh wlan show profiles key^=clear name^="!str:~1!"^| findstr "关键内容"') do (
      echo "!str:~1!"密码为:【%%d】
      echo "!str:~1!"密码为:【%%d】>>WiFi.txt
    )
)
echo 保存在脚本所在目录的WiFi.txt文件中
echo 任意键退出查询
pause>nul


第一版:
@echo off
color 2f
mode con: cols=40 lines=15
title WiFi密码查询
echo 正在查询结果
for /f "tokens=2* delims=:" %%i in ('netsh wlan show profiles') do (
    for /f "tokens=* delims= " %%a in ("%%i") do (
      for /f "tokens=3* delims= " %%d in ('netsh wlan show profiles key^=clear name^="%%a"^| findstr "关键内容" ') do (
      echo "%%a"密码为:【%%d】
      )
    )
)
echo 任意键退出查询
pause>nul


原理:
大概是第一次for循环去读取wifi名称
第二次循环的目的是去除第一次循环获取的多余的一个空格(感觉写的不好。。。又不知道咋截取,干脆用循环去分割吧,如果有更好的写法欢迎在回复里提出。)
第三次是获取对应wifi名字的信息,然后用findstr去找关键内容那一行,如果找到了就分割一下(老分割了。。。)写出密码
没有密码就拉倒。。。
绿色无残留,安全无捆绑
无须管理员权限运行(似乎是的)
无须额外配置,一键获取全部以保存的wifi名及其密码

演示:


食用方法:
复制代码,粘贴到记事本里,按照下图保存
注!最好不要用第三方编辑器。。。。
win10默认的保存语言是utf-8,bat只支持ANSI,中文编码错误保存会乱码


成品:
如果出现问题的朋友可以试试我打包好的bat,是不是还有这些问题。

knian 发表于 2021-3-5 09:26

上个版本不生成excel文件,这个会自动保存到excel# -*- coding: UTF-8 -*-
import os
import sys
import xlwt
import time
from datetime import datetime


# 定义一个函数checkWIFI,获取电脑连接过的所有wifi名称和密码,结果以列表形式返回
def checkWIFI():
        # 定义一个空列表,用来存放查询结果
        list = []
        # 查询所有的wifi名称
        message = os.popen('netsh wlan show profiles').readlines()
        # print(message)
        # 不是笔记本,或者wifi模块未启动
        if(message.find(u"没有运行")) != -1:
                return message
        # 获取的结果是一个列表list,需要进行遍历
        for i in message:
                # 遍历结果含有中文会乱码,需要进行编码
                result = i.strip().encode('gb2312').decode('gb2312','strict')
                # print(result)
                # print(result+"的长度为"+str(len(result))+",数据类型为"+str(type(result)))

                # 检查每一个结果中是否含有指定关键字
                if result.find(u"所有用户配置文件 : ") != -1:
                        # print("位置:"+str(result.find(u": ")))
                        # 从位置11开始截取
                        # print("wifi名称:"+result)

                        # netsh wlan show profiles name="Xiaomi_216E" key=clear
                        # 如果找到关键字,就截取指定位置的字符串,即wifi名称,再拼接成cmd命令
                        command = 'netsh wlan show profiles name="' + result + '" key=clear'
                        # print(command)
                        # 执行拼接好的命令,获取含有密码的结果
                        per_wifi = os.popen(command.encode('gb2312').decode('gb2312')).readlines()
                        # print(per_wifi)
                        # 获取的结果是一个列表list,需要进行遍历
                        for j in per_wifi:
                                # 遍历结果含有中文会乱码,需要进行编码
                                passwd = j.strip().encode('gb2312').decode('gb2312','strict')
                                # print(passwd)

                                # 检查每一个结果中是否含有指定关键字
                                if passwd.find(u"关键内容            :") != -1:
                                        # 获取字符串指定位置的内容并判断是否为空
                                        if passwd != '':
                                                # 定义一个临时列表list_temp存放每一个wifi信息,即wifi名称和密码
                                                list_temp = []
                                                # 将wifi名称追加到列表list_temp
                                                list_temp.append(result)
                                                # 将密码追加到列表list_temp
                                                list_temp.append(passwd)
                                                # 将每个wifi信息作为一个整体追加到列表list
                                                list.append(list_temp)
        return list

# 生成excel文件 (数据,名称)
def write_data_to_excel(result,name):
        # 将sql作为参数传递调用get_data并将结果赋值给result,(result为一个嵌套元组)
        #[["wifi","password"],["jz@cfhec","jzusers88"]]
        # 实例化一个Workbook()对象(即excel文件) 设置编码
        wbk = xlwt.Workbook(encoding = 'utf-8')
        # 创建一个worksheet
        sheet = wbk.add_sheet('Sheet1',cell_overwrite_ok=True)
        # 获取当前日期,得到一个datetime对象如:(2016, 8, 9, 23, 12, 23, 424000)
        today = datetime.today()
        # 将获取到的datetime对象仅取日期如:2016-8-9
        today_date = datetime.date(today)
        # 遍历result中的没个元素。
        for i in range(len(result)):
                #对result的每个子元素作遍历,
                for j in range(len(result)):
                        #将每一行的每个元素按行号i,列号j,写入到excel中。
                        # 参数对应 行, 列, 值
                        sheet.write(i,j,result)
        # 要保存的excel名称
        excel_name = name+"_"+str(today_date)+'.xls'
        # 保存
        wbk.save(excel_name)

# 如果该文件不是被import,则执行下面代码。
if __name__ == '__main__':
        print("正在查询......")
        # 定义一个变量,存放调用checkWIFI的执行结果
        password_list = checkWIFI()
        print("\n返回结果如下:\n")
        # 判断返回值是否是list
        if isinstance(password_list,list):
                # 将查询结果遍历输出
                for n in password_list:
                        print("[+]" + "\t    Wifi:\t" + n + "\n\tPassword:\t" + n+"\n")
                # 执行写入文件
                write_data_to_excel(password_list,"WifiPassword")
        elif isinstance(password_list,str):
                print ("[-]\t"+password_list)

        print("10秒后退出")
        time.sleep(10)

超正义的小煌 发表于 2021-1-24 11:19

我运行bat后
只有
正在查询结果
任意键退出查询
。。。。请问是为什么呀?

fanvalen 发表于 2021-1-24 13:17

fanvalen 发表于 2021-1-24 13:08
来来来我给你加了一句解决过多不好看不能复制问题
保存在d盘下名字叫wifi.txt的
@ ...

我搞错了,你这循环怎么嵌套的,怎么只存了一个下来,你再改改

正己 发表于 2021-1-24 11:01

学废了,这就去偷邻居家的密码{:17_1054:}

lm877966 发表于 2021-1-24 11:13

好评,很好用!

IWayne 发表于 2021-1-24 11:18

可以,可以。我也没想到WIN10的bat可以这么玩。

huer 发表于 2021-1-24 11:21

没大鸟用,既然登陆了当前wifi,为啥要读密码?

hhx 发表于 2021-1-24 11:24

WiFi多了,小窗口显示不全,后面的会把前面的覆盖,需要手动放大窗口

沉心云 发表于 2021-1-24 11:27

牛逼,能查到邻居的密码

Azad 发表于 2021-1-24 11:28

感谢大佬。能查到之前连过的所有WiFi{:301_993:}

Dumeng 发表于 2021-1-24 11:29

CHCP 65001
页: [1] 2 3 4 5 6 7 8
查看完整版本: 【bat脚本】读取当前设备wifi密码(仅win10测试)