暴力破解带有密码的压缩文件

暴力破解带有密码的压缩文件一暴力破解,就是不断生成新的密码去尝试能否破解成功。假如我们的密码位数为3位,其里面的值有可能是0或者1,其产生的密码集的数量为2的3次幂,也就是八个,然后一个一个去破解。而这生成这8个密码的过程就有一个递归规则存在。我们传入深度deep和对应字符串passwd两个参数,如果深度为1,直接输出字符串passwd,如果深度不为1,把深度deep减一,并把可能存在的字符串集合[0,1]遍历,添加…

大家好,又见面了,我是你们的朋友全栈君。

暴力破解,就是不断生成新的密码去尝试能否破解成功。假如我们的密码位数为3位,其里面的值有可能是0或者1,其产生的密码集的数量为2的3次幂,也就是八个,然后一个一个去破解。而这生成这8个密码的过程就有一个递归规则存在。
暴力破解带有密码的压缩文件
我们传入深度deep和对应字符串passwd两个参数,如果深度为1,直接输出字符串passwd,如果深度不为1,把深度deep减一,并把可能存在的字符串集合[0,1]遍历,添加到passwd的后面,重新回到这个递归函数,直到深度deep为1输出。

二 解压压缩文件
网上有对应的jar包去解压压缩文件,但是我这里使用一种比较简单的方法去实现,本地电脑window上装有winrar,java调用本地winrar.exe去解压压缩文件。
其核心代码为:

C:\Program Files\WinRAR\WinRAR.exe  x -ibck -hp123 -y F:\\BaiduNetdiskDownload\\yewen4\\a.rar D:\\test\\unrar\\

第一个路径是winrar.exe的路径,第二个路劲是需要解压缩文件的路径地址,第三个是存放的路径。-hp后面的123表示密码。

下面是代码的实现

 /**
     * 
     * @param filePath 解压文件路径
     * @param targetPath 解压之后存放的路径
     * @param passwd 密码
     * @return
     * @throws Exception
     */
public static int unrar(String filePath,String targetPath,String passwd) throws Exception {
		//winrar的执行路径
        String rarPath="C:\\Program Files\\WinRAR\\WinRAR.exe";
        StringBuilder sb = new StringBuilder();
        sb.append(rarPath);
        sb.append(" x -ibck -hp");
        sb.append(passwd).append(" -y ").append(filePath+" "+targetPath);
        Process process;

        process = Runtime.getRuntime().exec(sb.toString());
        if(process.waitFor() ==0 ){
            FileOutputStream fileOutputStream = new FileOutputStream(new File("D:\\test\\unrar\\getPassyewen4.txt"));
            String s = "解压后的密码:"+passwd;
            fileOutputStream.write(s.getBytes());
            fileOutputStream.flush();
            fileOutputStream.close();
            return 1;
        }else{
            System.out.println(new Date()+"--失败:"+passwd);
            return 0 ;
        }
    }

	 /**
     * 递归获取密码过程
     * @param deep 深度
     * @param parent 密码
     * @return
     * @throws Exception
     */
    public static int findpwd(int deep,String parent) throws Exception {
        String[] dir ={"q","w","e","r","t","y","u","i","o","p","a","s","d","f","g","h","j","k","l",
                "z","x","c","v","b","n","m","Q","W","E","R","T","Y","U","I","O","P","A","S","D","F","G","H","J","K","L","Z","X",
                "C","V","B","N","M","1","2","3","4","5","6","7","8","9","0","`","!","@","#","$","%","&","*","(",")","-","_","+","=","[",
                "]","{","}","|","\\","\"",":",";","\'","<",">",",",".","?","/"};
        if(deep == 1){
            if(unrar("","",parent) == 1){
                return 1;
            }else{
                return 0;
            }
        }else{
            for(int j =0;j<dir.length;j++){
                if(findpwd(deep-1,parent+dir[j]) ==1 ){
                    return 1;
                }
            }
        }
        return 0;
    }

文章最后的总结:
破解的难度跟设置密码的长度有关,破解一位的密码只需要92的1次幂个密码,而破解六位的密码需要92的6次幂个密码,其难度可想而知。所以这里写的内容只供学习参考。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/139685.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 20那天android得知

    20那天android得知

  • Java语言实现hello world代码[通俗易懂]

    Java语言实现hello world代码[通俗易懂]参考https://blog.csdn.net/yilovexing/article/details/53256713 24种编程语言的HelloWorld程序  Java文档注释Java支持三种注释方式。前两种分别是 // 和 /**/,第三种被称作说明注释,它以 /** 开始,以 */结束。说明注释允许你在程序中嵌入关于程序的信息。你可以使用javadoc工…

  • pycharm激活码注册码密钥2021破解方法

    pycharm激活码注册码密钥2021破解方法,https://javaforall.cn/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

  • js弹出框、对话框、提示框、弹窗总结[通俗易懂]

    js弹出框、对话框、提示框、弹窗总结[通俗易懂]js弹出框、对话框、提示框、弹窗总结一、JS的三种最常见的对话框[javascript] viewplaincopy//====================== JS最常用三种弹出对话框 ========================        //弹出对话框并输出一段提示信息      funct

    2022年10月29日
  • Diablo II中的各种hacks

    Diablo II中的各种hacksGamehacks,也就是通常所说的游戏软件。在网络游戏时代,也许是因为针对传奇这类游戏的软件大都利用WPE之类的抓包工具来制作,因此hacks又叫外挂。不过Diablo的hacks绝大多数是和游戏代码紧密结合在一起的,也许应该叫内挂才对。DiabloIILOD(以下简称D2X)中的hacks大概可分为exploit、bot和mod三大类。exploit即漏洞,就是利用游戏设计上的缺陷或者B…

  • 互斥量Mutex的简单应用

    互斥量Mutex的简单应用一、互斥量的简单介绍互斥量是一个内核对象,它用来确保一个线程独占一个资源的访问。互斥量与关键段的行为非常相似,并且互斥量可以用于不同进程中的线程互斥访问资源。使用互斥量Mutex主要将用到四个函数。下面是这些函数的原型和使用说明。1) CreateMutex函数功能:创建互斥量函数原型:HANDLECreateMutex(LPSECURITY_ATTRIBUTES…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号