【shell】压缩包密码暴破脚本
作者:小编日期:2023-04-20浏览:2516分类:娱乐休闲
本来一开始是打算用python的,但一想python写保存路径,到最后还是放弃了,因为python的目录写法,终究逃不掉 Windows c:/xxx/、Mac ~/xxxx/ ,这就造成了平台上的不适配,那我还不如索性写两份体验体验。
谈谈这次遇到的小问题,主要问题其实在注释上已经说明了,不过还是单拿出了,方便观看与讨论:
发现
brew install p7zip > /dev/null 2>&1运行效率较低,也算是个无心之举。跑代码测试的时候,我发现这种写法,明显感觉比if慢好多,所以就pass掉了。在Mac上,7z并不支持验证rar压缩包密码;Mac下面的rar,也不支持zip的密码验证。这个是p7zip与rar(两者都是 brew 安装)的实验结论。
密码暴破没成功,没有输出echo,主要是自己逻辑上出现了问题:break之后又执行了常规的输出,定位代码处
# echo "$?",需要外部使用变量来固化状态值,再做判断(类似批处理的延迟变量)。
细节方面就是:dos2unix,关于LF格式和CRLF格式的TXT文件了,统一处理,问题不大。
代码本地测试效果
在线测试效果图,顺带还发现了个有趣的现象:特权提升的$username,由自己的本地用户名,变成了“root”
与Windows版本的效果
整体来说,由于系统的差异明显,以及batch、shell的实现各有差异,殊途同归了,算是。可以粗糙理解为类似《富士山下》、《爱情转移》粤语歌与普通话的两种唱法。
附源码:https://github.com/hoochanlon/ihs-simple/blob/main/d-shell/7z_rar_sensei.sh
# 实验
## brew install p7zip > /dev/null 2>&1 运行效率较低,大概有2~3秒不等,if算了
## 在Mac上,7z并不支持验证rar压缩包密码;Mac下面的rar,也不支持zip的密码验证。
## 网上txt为CRLF的问题,dos2unix搞定。
## 密码没找到,没输出,排查问题如下:
### $0 用于存储上一个命令的退出状态。当一个命令成功执行时,它的退出状态为 0,否则为非零值。
### 直接不在外层初始化flag,容易算数异常,推测是作用域问题。
# 缺什么就安装什么
[ ! -e $(which rar) ] && brew install rar
[ ! -e $(which 7z) ] && brew install p7zip
[ ! -e $(which dos2unix) ] && brew install dos2unix
# 不存在就下载密码本
if [ ! -f ~/Downloads/rarpasswd.txt ]; then
curl -o ~/Downloads/rarpasswd.txt https://ghproxy.com/https://raw.githubusercontent.com/hoochanlon/ihs-simple/main/d-txt/rarpasswd.txt
fi
# 保存密码本为基本路径格式
# 无法输出用户名 // ,储存变量结果后,再输出 /Users/<用户名> 正常。
username=$USER
passwd_txt="/Users/$username/Downloads/rarpasswd.txt"
# CRLF文本换成LF文本
dos2unix $passwd_txt >/dev/null 2>&1
# has_passwd_rar="/Users/chanlonhoo/Desktop/BlackFell.zip"
echo -e "\n"
read -p "将压缩包文件拖入到终端: " has_passwd_rar
# 打上flag,保存break状态码,固化存储。
found_passwd_tag_num=0
unrar_passwd_find() {
# 遍历密码文件中的每一行密码
while read password; do
# 尝试使用当前密码解压缩压缩包
unrar t -p$password "$has_passwd_rar" >/dev/null 2>&1
# 检查解压缩命令的退出码
if [ $? -eq 0 ]; then
# 如果退出码为 0,说明密码正确,输出提示信息并退出循环
echo -e "\n密码是: $password \n"
# flag
found_passwd_tag_num=1
break
fi
done <$passwd_txt
# echo "$?"
if [ $found_passwd_tag_num -ne 1 ]; then
echo -e "\n没找到正确的密码。\n"
fi
}
7z_passwd_find() {
# 遍历密码文件中的每一行密码
while read password; do
# 尝试使用当前密码解压缩压缩包
7z t -p$password "$has_passwd_rar" >/dev/null 2>&1
# 检查解压缩命令的退出码
if [ $? -eq 0 ]; then
# 如果退出码为 0,说明密码正确,输出提示信息并退出循环
echo -e "\n密码是: $password \n"
# flag
found_passwd_tag_num=1
break
fi
done <"$passwd_txt"
if [ $found_passwd_tag_num -ne 1 ]; then
echo -e "\n没找到正确的密码。\n"
fi
}
# 判断文件名后缀是否包含rar
if [[ ${has_passwd_rar##*.} == "rar" ]]; then
unrar_passwd_find
else
7z_passwd_find
fi相关文章
- 11-18 隐蔽摄像机 Alibi 0.5.3
- 11-07 战斗吧精灵大世界九世代《宝可梦》手游,自由捕捉探索
- 11-04 小红书获客软件:这款小红书综合工具如何让精准流量主动找你?
- 10-12 多平台直播聚合平台 simple_live 1.9.4
- 10-04 安卓WiFi万能钥匙v5.1.56高级版
- 09-30 寂静岭f/SILENT HILL f 绿色版 免安装
- 09-17 三角洲改枪方案集助手
- 09-04 抖音福袋扭蛋机最新版
- 08-15 剪映手机版+PC版v6.1.0和v6.0.1永久激活版
- 08-13 游戏修改器专业的游戏解锁器
- 08-13 安卓Ai象棋终极版v8.5.0永久授权
- 08-11 【旺仔小乔同款变声器】1:1音色复刻!超仿真人声【安卓+PC】免费使用
取消回复欢迎你发表评论:
- 协助本站优化一下
- 最近发表
- 1最新优茗导航系统源码/全开源版本/精美UI/带后台/附教程
- 2最新付费进群系统源码 V4.1全开源版本源码 附教程
- 3源支付v7开源版1.8.9源码附带云端源码+挂机软件
- 4信息数据恢复V1.0.3 挽救数据恢复成功率高
- 5【小梨听书】1.0.4 各类小说资源应有尽有 无广告
- 6橘子影视V3.0.1.7 宝藏追剧App
- 7【好看头像】1.064 精选优质素材 已除广告
- 8呱呱视频V1.1.0 海量资源免费看
- 9【奇酷阅读】1.0.0 小说漫画全都有 解锁VIP
- 10专业级AI智能文章生成工具支持ai检测,ai改写等功能
- 11新北京烤鸭配方 / 材料简单易上手学得快!鸭饼制作 / 鸭酱制作
- 12素颜个人主页网址永久发布页
- 13【五香卤肉教程】2025视频教程新手自学零基础精通教学课程
- 1470套时尚中式剪映婚礼婚庆快剪模板花絮视频草稿文件
- 15计算器 HiPER Calc Pro_v11.2.8
Copyright© XGW9.COM版权所有〖小庚资源网〗
〖恒创科技〗为本站提供专业云计算服务
本站发布的内容来源于互联网,如果有侵权内容,请联系我们删除!E-mail:xgzyw6@outlook.com
关于我们|我要投稿|免责声明|XML地图














暂无评论,来添加一个吧。