linux下c語言的crypt函數怎麼用?

来源:https://www.cnblogs.com/ivanlee717/archive/2023/04/04/17288313.html
-Advertisement-
Play Games

linux的crypt 最近學校佈置了一個網安的小作業,要用到linux裡面的這個crypt函數,寫一篇總結一下。首先我們要瞭解這個函數是用來做什麼的。 密碼影子文件中存儲了每一個用戶的用戶明文和其單向哈希過的秘文 cipher = "$1$C68vnJ27$1ttFZ1/Rylq/xi350A0N ...


linux的crypt

最近學校佈置了一個網安的小作業,要用到linux裡面的這個crypt函數,寫一篇總結一下。首先我們要瞭解這個函數是用來做什麼的。

image-20230404230218492

密碼影子文件中存儲了每一個用戶的用戶明文和其單向哈希過的秘文

cipher = "$1$C68vnJ27$1ttFZ1/Rylq/xi350A0NI0";

密碼欄位用\(id\)salt$hashed的格式存儲,其中id欄位是1,salt是C68vnJ27,hash為1ttFZ1/Rylq/xi350A0NI0

其中$id表示計算密碼密文所用的哈希演算法,對應關係如下:

  • $1$ 表示 MD5
  • $5$ 表示 SHA-256
  • $6$ 表示 SHA-512
  • $2a$$2y$表示Blowfish演算法

那這個由明文加密的過就是由crypt()函數完成的,crypt()是一個密碼加密函數(將密碼加密,明文變成密文),該函數基於數據加密標準(DES,Data Encryption Standard )演算法以及基於DES的其他變種演算法,該函數不依賴於電腦硬體實現數據加密。DES演算法僅適合於加密字元串,也就是用於生成密碼。儘管密碼的生成有很多種方法。

salt的定義是在密碼學中,是指通過在密碼任意固定位置插入特定的字元串,讓散列後的結果和使用原始密碼的散列結果不相符,這種過程稱之為“加鹽”。Salt 可以是任意字母、數字、或是字母或數字的組合,但必須是隨機產生的,每個用戶的 Salt 都不一樣,用戶註冊的時候,資料庫中存入的不是明文密碼,也不是簡單的對明文密碼進行散列,而是 MD5( 明文密碼 + Salt)。salt是一種混淆key的一段範圍在abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789./中的“隨機”字元串,具體最小長度和最大長度根據加密方法的不同而不同。

image-20230404233332711

官方給出的crypt的用法是要傳入一個密鑰和一個salt,這個密鑰就是用戶密碼。在編譯c語言文件時,我們主要寫成"gcc -o crypt crypt.c -lcrypt"去調用crypt這個庫

現在題目給出了12位密鑰中的前五位和後兩位,中間5個都是數字,我們可以使用爆破的方式去實現一下crypt方法。

image-20230404234247466

直接給出代碼

```c
//
// Created by ivanlee on 2023/3/26.
//
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
#include <crypt.h>

const char* ans_cipher = "$1$XwynSv0a$qgSbP2GtPyeEyq6ZVWPUZ1";
const char* first5 = "*CMS";
const char* last2 = "c#";
const char* salt = "$1$XwynSv0a$";

int main(int argc, char* argv[]){
    for(int a=0; a<10;a++){
        char str[30];
        strcpy(str,first5);
        char tmpa;
        tmpa = '0' + a;
        str[5] = tmpa;
        for(int b=0; b<10;b++){
            char tmpb;
            tmpb = '0' + b;
            str[6] = tmpb;
            for(int c=0; c<10;c++){
                char tmpc;
                tmpc = '0' + c;
                str[7] = tmpc;
                for(int d=0; d<10;d++){
                    char tmpd;
                    tmpd = '0' + d;
                    str[8] = tmpd;
                    for(int e=0; e<10;e++){
                        char tmpe;
                        tmpe = '0'+e;
                        str[9]=tmpe;
                        str[10]='c';
                        str[11]='#';
                        char cipher[50];
                        char new[12];
                        strncpy(new,str,12);
                        strcpy(cipher,crypt(new,salt));
                        if(strcmp(cipher,ans_cipher)==0) {
                            printf("the ans is: %s\n", new);
                            return 0;
                        }

                    }
                }
            }
        }
    }
    return 0;

}

主要當我們瞭解了鹽是什麼,crypt是怎麼加密的,這個判斷爆破密碼的很簡單了,從00000開始到99999依次拼接進去進行加密,半分鐘左右就爆出密碼了

image-20230404234704340

本文來自博客園,作者:ivanlee717,轉載請註明原文鏈接:https://www.cnblogs.com/ivanlee717/p/17288313.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 什麼是SwaggerHub? Hub 謂之 中心, 所以 SwaggerHub即swagger中心. 什麼時候需要它? 通常, 公司都擁有多個服務, 例如商品服務, 訂單服務, 用戶服務, 等等, 每個服務都有自己的environment, endpoint, swagger schema. 然而這 ...
  • 首先,安裝AspNetCore.RateLimit NuGet 包。您可以通過NuGet包管理器控制台或Visual Studio的NuGet包管理器來執行此操作。安裝後,您將在項目中看到一個名為AspNetCoreRateLimit的文件夾,其中包含中間件的配置類。 接下來,您需要在 Startu ...
  • //裝箱拆箱 string name = "Zery"; int age = 22; Console.WriteLine(age.ToString() + name);//已ToString的操作 Console.WriteLine(age+name);//未ToString操作 老規矩,一段C#, ...
  • 閱讀IL主要是為了能夠更好的學會Emit 從控制台開始吧:事先準備工具ILSpy,和IL的命令指南(這個可以網上搜索或者去看OpCode枚舉),記住棧中的都是引用的地址 int i = 10; int j = 20; int k = 30; Console.WriteLine(i + j + k); ...
  • #1. 緩存 緩存指的是在軟體應用運行過程中,將一些數據生成副本直接進行存取,而不是從原始源(資料庫,業務邏輯計算等)讀取數據,減少生成內容所需的工作,從而顯著提高應用的性能和可伸縮性,使用好緩存技術,有利於提高我們提升用戶體驗性。 對於緩存的使用有以下一些註意點: 緩存最適用於不常更改且生成成本很 ...
  • 1.創建一個新的WinForms或WPF應用程式,具體取決於您的需要。 2.將Telerik Reporting組件添加到您的應用程式中。您可以通過NuGet包管理器來完成此操作。 3.在您的應用程式中添加多個報表文件。您可以使用Telerik Report Designer創建報表並將其添加到您的 ...
  • 【目錄】 1 委托 2 事件-概念的引出 3 事件-關於異常 4 事件-關於非同步 5 委托-Func與Action 1 委托 在.NET中定義“委托”需要用到delegate關鍵字,它是存有對某個方法的引用的一種引用類型變數,類似於 C 或 C++ 中函數的指針。“委托”主要有兩大作用: (1)將方 ...
  • 一:背景 1. 講故事 昨天有位朋友找到我,說他的程式記憶體存在泄露導致系統特別卡,大地址也開了,讓我幫忙看一下怎麼回事?今天上午看了下dump,感覺挺有意思,在我的分析之旅中此類問題也蠻少見,算是完善一下體系吧。 二:WinDbg 分析 1. 到底是哪裡的泄露 在.NET高級調試訓練營中,我多次告訴 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...