暴力破解Linux密碼程序

原文鏈接
這里介紹一下怎么用程序包里破解linux加密的 就寫一個程序來實現(xiàn)如何暴力破解它。當然,這個程序的前提是你能夠拿到對方的root權(quán)限并查看到/etc/shadow里面的內(nèi)容,linux當然不會讓你那么輕易地拿到的。所以這里只是出于興趣破解一下本機上的密碼而已。代碼如下:

#define _GNU_SOURCE  
#include <stdio.h>  
#include <stdlib.h>  
#include <unistd.h>  
#include <string.h>

char letter[37] = "abcdefghijklmnopqrstuvwxyz0123456789"; // 存放所有可能的字符峡眶,不包含特殊字符以及大小寫
char result[10];    // 存放最終結(jié)果,假設不超過十個字符  
int minlen = 1;     // 密碼的最小長度  
int maxlen = 10;    // 密碼的最大長度  

// 這是通過/etc/shadow所獲取的加密后的文本  
char *encrypted = "$6$jMzjGK/$0QVw8FM87jd3yF0wvzgXPPe1l3FOfrIA7LhGPIVCbum9es5 /tQsGMJqmaQ78IY.Hv4h6UWnvTs4cLntrPMSfM/";  
char *salt = "$6$jMzjGK//$";    // 由上面的文本所得到的值植锉,crypt函數(shù)的第二個參數(shù)

// 遞歸嘗試  
void try_next(int index, int length)  
{  
    int i;  
    if(index == length)  
        return ; // 遞歸結(jié)束條件  
    for(i = 0; i< 36; i++) // 把當前位置的所有情況試完  
    {  
        result[index] = letter[i]; // 給當前位置賦值  
        memset(result + index +1, letter[0], length – index -1); // index之后辫樱,length之前的字符都用character[0]即a來代替  
        if(i != 0) // i=0的情況已經(jīng)判斷過了  
        {  
            printf("嘗試:%s\n", result);  
            if(! strcmp(encrypted, crypt(result, salt)))  
            {  
                printf("發(fā)現(xiàn)密碼:%s\n", result);  
                exit (0);  
            }  
        }  
        try_next(index + 1, length); // 遞歸替換下一個位置的字符,直到找到密碼或者index==length為止  
    }  
}

void try(int length, int begin, int end)  
{  
    int i;  
    for(i = begin; i<= end; i++)  
    {  
        result[0] = letter[i]; // 這一步只確定第一個字符  
        memset(result + 1, letter[0], length-1); // 第一個字符后面length前面的字符就用character[0]即a來代替  
        printf("嘗試:%s\n", result);  
        if(!strcmp(encrypted, crypt(result, salt))) // 如果這時候就能夠匹配那么直接推出  
        {  
            printf("發(fā)現(xiàn)密碼:%s\n", result);  
            exit (0);  
        }  
        try_next(1, length); // 遞歸嘗試第一個字符之后的字符  
    }  
}

int main()  
{  
    int len;  
    for(len = minlen; len <= maxlen; len++){  
        printf("\n正在嘗試長度為%d的密碼\n", len);  
        memset(result, 0, 10); // 初始化result數(shù)組為全0,這里并不是指字符0  
        try(len, 0, 36);  
    }  
    return 0;  
}

這是我第一次嘗試暴力破解俊庇,雖然沒有用多線程狮暑,但還是能明顯感覺到其效率之低鸡挠,以后得學學其他的方法。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末搬男,一起剝皮案震驚了整個濱河市拣展,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌缔逛,老刑警劉巖备埃,帶你破解...
    沈念sama閱讀 221,406評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異褐奴,居然都是意外死亡按脚,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,395評論 3 398
  • 文/潘曉璐 我一進店門敦冬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來辅搬,“玉大人,你說我怎么就攤上這事脖旱】八欤” “怎么了?”我有些...
    開封第一講書人閱讀 167,815評論 0 360
  • 文/不壞的土叔 我叫張陵萌庆,是天一觀的道長溶褪。 經(jīng)常有香客問我,道長践险,這世上最難降的妖魔是什么竿滨? 我笑而不...
    開封第一講書人閱讀 59,537評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮捏境,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘毁葱。我一直安慰自己垫言,他們只是感情好,可當我...
    茶點故事閱讀 68,536評論 6 397
  • 文/花漫 我一把揭開白布倾剿。 她就那樣靜靜地躺著筷频,像睡著了一般。 火紅的嫁衣襯著肌膚如雪前痘。 梳的紋絲不亂的頭發(fā)上凛捏,一...
    開封第一講書人閱讀 52,184評論 1 308
  • 那天,我揣著相機與錄音芹缔,去河邊找鬼坯癣。 笑死,一個胖子當著我的面吹牛最欠,可吹牛的內(nèi)容都是我干的示罗。 我是一名探鬼主播惩猫,決...
    沈念sama閱讀 40,776評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼蚜点!你這毒婦竟也來了轧房?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,668評論 0 276
  • 序言:老撾萬榮一對情侶失蹤绍绘,失蹤者是張志新(化名)和其女友劉穎奶镶,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體陪拘,經(jīng)...
    沈念sama閱讀 46,212評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡厂镇,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,299評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了藻丢。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片剪撬。...
    茶點故事閱讀 40,438評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖悠反,靈堂內(nèi)的尸體忽然破棺而出残黑,到底是詐尸還是另有隱情,我是刑警寧澤斋否,帶...
    沈念sama閱讀 36,128評論 5 349
  • 正文 年R本政府宣布梨水,位于F島的核電站,受9級特大地震影響茵臭,放射性物質(zhì)發(fā)生泄漏疫诽。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,807評論 3 333
  • 文/蒙蒙 一旦委、第九天 我趴在偏房一處隱蔽的房頂上張望奇徒。 院中可真熱鬧,春花似錦缨硝、人聲如沸摩钙。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,279評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽胖笛。三九已至,卻和暖如春宜岛,著一層夾襖步出監(jiān)牢的瞬間长踊,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,395評論 1 272
  • 我被黑心中介騙來泰國打工萍倡, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留身弊,地道東北人。 一個月前我還...
    沈念sama閱讀 48,827評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像佑刷,于是被迫代替她去往敵國和親莉擒。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,446評論 2 359

推薦閱讀更多精彩內(nèi)容