md5是什么算法(MD5是什么算法)
md5是什么算法
MD5:嚴格來說不算加密算法,只能說是摘要算法;
MD5是什么算法
md5,sha1,sha256屬于密碼級散列函數,算法相對比較復雜,參與加密算法的過程中時也比較安全。crc只是專用的校驗散列函數,算法相對比較簡單。
安全級別不同也導致輸出長度
常用的CRC32 只輸出32bit
MD5輸出128bit
SHA1輸出160bit
SHA256輸出256bit
這也反映了復雜度和安全要求的遞增。
對安全要求的不同導致他們的“應用場景就不同”:
對密碼用CRC32就很不安全,普通密碼可以用MD5,但數字證書和數字簽名就法定必須用SHA256,
對普通數據效驗完整性也沒必要用SHA1,SHA256這樣計算相對復雜的算法,會慢很多。
描述MD5算法
對MD5逆向算法簡要的敘述可以為:MD5以512位分組來處理輸入的信息,且每一分組又被劃分為16個32位子分組,經過了一系列的處理后,算法的輸出由四個32位分組組成,將這四個32位分組級聯后將生成一個128位散列值。
第一步、填充:如果輸入信息的長度(bit)對512求余的結果不等于448,就需要填充使得對512求余的結果等于448。填充的方法是填充一個1和n個0。填充完后,信息的長度就為N*512+448(bit);
第二步、記錄信息長度:用64位來存儲填充前信息長度。這64位加在第一步結果的后面,這樣信息長度就變?yōu)镹*512+448+64=(N+1)*512位。
第三步、裝入標準的幻數(四個整數):標準的幻數(物理順序)是(A=(01234567)16,B=(89ABCDEF)16,C=(FEDCBA98)16,D=(76543210)16)。如果在程序中定義應該是(A=0X67452301L,B=0XEFCDAB89L,C=0X98BADCFEL,D=0X10325476L)。
MD5算法代碼
md5就是一種信息摘要加密算法。MD5英文名叫MD5 Message-Digest Algorithm,一種被廣泛使用的密碼散列函數,可以產生出一個128位(16字節(jié))的散列...
md5屬于什么算法
SHA-1與MD5的比較
因為二者均由MD4導出,SHA-1和MD5彼此很相似。相應的,他們的強度和其他特性也是相似,但還有以下幾點不同:
l 對強行攻擊的安全性:最顯著和最重要的區(qū)別是SHA-1摘要比MD5摘要長32 位。使用強行技術,產生任何一個報文使其摘要等于給定報摘要的難度對MD5是2^128數量級的操作,而對SHA-1則是2^160數量級的操作。這樣,SHA-1對強行攻擊有更大的強度。
l 對密碼分析的安全性:由于MD5的設計,易受密碼分析的攻擊,SHA-1顯得不易受這樣的攻擊。
l 速度:在相同的硬件上,SHA-1的運行速度比MD5慢。
md5算法作用
SHA-1算法的哈希值大小為160位,其計算輸出長度為40位。
MD5算法的哈希值大小為128位,其計算輸出長度為32位。
MD5 算法
MD5算法(英語:MD5 Message-Digest Algorithm),是一種被廣泛使用的密碼散列函數,可以產生出一個128位(16字節(jié))的散列值(hash value),用于確保信息傳輸完整一致。MD5由美國密碼學家羅納德·李維斯特(Ronald Linn Rivest)設計,于1992年公開,用以取代MD4算法。
這套算法的程序在 RFC 1321 標準中被加以規(guī)范。1996年后該算法被證實存在弱點,可以被加以破解,對于需要高度安全性的數據,專家一般建議改用其他算法,如SHA-2。2004年,證實MD5算法無法防止碰撞(collision),因此不適用于安全性認證,如SSL公開密鑰認證或是數字簽名等用途。
MD5算法的具體過程
MD5嚴格意義上來講,不是加密算法,而是摘要算法/散列算法,或者叫做哈希算法。
加密算法的目的,在于別人無法成功查看加密后的數據,并且在需要的時候還可以對數據進行解密來重新查看數據。而 MD5 算法是一種哈希算法,哈希算法的設計目標本身就決定了,它在大多數時候都是不可逆的,即你經過哈希算法得出的數據,無法再經過任何算法還原回去。所以,既然不能將數據還原,也就不能稱之為可以解密;既然不能解密,那么哈希的過程自然也就不能稱作是「加密」了。
MD5是( )算法
MD5算法不可逆的原因是其是一種散列函數,使用的是hash算法,在計算過程中原文的部分信息是丟失了的。
不過有個地方值得指出的是,一個MD5理論上的確是可能對應無數多個原文的,因為MD5是有限多個的而原文可以是無數多個。比如主流使用的MD5將任意長度的“字節(jié)串映射為一個128bit的大整數。也就是一共有2128種可能,大概是3.4*1038,這個數字是有限多個的,而但是世界上可以被用來加密的原文則會有無數的可能性。