欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關于SHA算法原理與常用實現方式

 更新時間:2022年08月18日 11:35:42   作者:zhangSir134  
這篇文章主要介紹了關于SHA算法原理與常用實現方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

看本文前,最好先看看之前的這一篇關于MD5算法的介紹。

MD5算法原理與常用實現

定義

SHA算法(Secure Hash Algorithm),又叫安全散列算法。

SHA算法是基于MD4算法的基礎上,演變而來。

但SHA算法出生好,是美國國家安全局設計的。

SHA算法,是一個系列家族,包括SHA-1,SHA-2(SHA-224、SHA-256、SHA-384、SHA-512),括號中的四個通常被統(tǒng)稱為SHA-2。

JDK中對SHA-1、SHA-256、SHA-384、SHA-512都有實現。

  • SHA-1的最終密碼長度是160位。
  • SHA-256的最終密碼長度是256位。
  • SHA-384的最終密碼長度是384位。
  • SHA-512的最終密碼長度是512位。

SHA算法,實際上也是一種消息摘要算法,這個和MD算法是類似的。

本文主要介紹SHA-256算法。

任意長度的消息文件,通過SHA-256算法加密,最終得到的密文都是256位(32字節(jié)),通常用一個長度為64的十六進制字符串來表示。

效果上,SHA算法,與MD5算法都差不多,主要特點都是不可逆。

MD5和SHA-1的碰撞問題

碰撞問題,就是指對于一個算法,由明文生成的密文,并不是唯一的,甚至可以人為的通過構造新的明文去得到指定的密文。

對于能出現這種情況的算法,我們就說這個算法是有碰撞問題的,簡單理解就是兩個不同的明文,通過算法加密,卻得到了同樣的密文。

目前為止,MD5算法和SHA-1算法,都被證實了存在碰撞問題。

所以在安全性特別高的場景下,都不會用MD5算法和SHA-1算法,至少都用SHA-256算法了。

常見應用場景

1、類似MD5的應用場景

MD5的應用場景,SHA算法基本也都可以使用。

2、比特幣

比特幣中,挖礦算法其實就是SHA-256算法,礦工們根據不斷修改隨機數,不斷的進行SHA-256運算,最終算的快的挖到礦。

3、https簽名算法會用到

打開瀏覽器,以谷歌為例,查看任意一個整數的詳情:

簽名算法就是:帶 RSA 加密的 SHA-256,如下圖:

SHA-256算法原理

SHA家族的基本算法思想,都和MD5一樣,先定義常量,然后循環(huán)計算,最后組裝,不同的就是循環(huán)里面的計算方式。

1、填補信息

類似MD5

2、拿到初始值

MD5中有4個初始值,而SHA-256中,有8個。

h0 := 0x6a09e667
h1 := 0xbb67ae85
h2 := 0x3c6ef372
h3 := 0xa54ff53a
h4 := 0x510e527f
h5 := 0x9b05688c
h6 := 0x1f83d9ab
h7 := 0x5be0cd19

3、真正的計算

計算分為多次循環(huán),每次循環(huán),都是用ABCD和原文在第一步填補完的信息,進行計算,最終得到新的ABCD。最后將最后一次ABCD拼成字符串,就是最終的密文。

  • 循環(huán)先分為主循環(huán),每個主循環(huán)中又套有子循環(huán)。
  • 主循環(huán)次數 = 原文長度/512。
  • 子循環(huán)次數 = 64次。

我們看看單次子循環(huán)都做了什么:

下面是單次子循環(huán)真正的計算邏輯(這段實現摘自網友):

java實現和使用

其實看過上一篇MD5介紹的,就會發(fā)現,其實SHA的java實現,和MD5的java實現,幾乎一模一樣。

唯一的不同,就是MessageDigest.getInstance(“SHA”);這個方法中:

  • SHA-1算法的入參是SHA
  • SHA-256算法的入參是SHA-256
  • SHA-384算法的入參是SHA-384
  • SHA-512算法的入參是SHA-512

MD5的入參是MD5

public class SHA1Util {
    public static void main(String[] args) throws IOException {
        System.out.println(encodeString("123"));
    }
    public static String encodeString(String plainText) throws UnsupportedEncodingException {
        return encodeBytes(plainText.getBytes("UTF-8"));
    }
    public static String encodeBytes(byte[] bytes) {
        try {
            MessageDigest md = MessageDigest.getInstance("SHA");
            md.update(bytes);
            byte b[] = md.digest();
            int i;
            StringBuffer buf = new StringBuffer("");
            for (int offset = 0; offset < b.length; offset++) {
                i = b[offset];
                if (i < 0) {
                    i += 256;
                }
                if (i < 16) {
                    buf.append("0");
                }
                buf.append(Integer.toHexString(i));
            }
            return buf.toString();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return "";
    }
}

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。 

相關文章

  • RocketMQ事務消息原理與使用詳解

    RocketMQ事務消息原理與使用詳解

    RocketMQ事務消息(Transactional Message)是指應用本地事務和發(fā)送消息操作可以被定義到全局事務中,要么同時成功,要么同時失敗。RocketMQ的事務消息提供類似 X/Open XA 的分布式事務功能,通過事務消息能達到分布式事務的最終一致
    2023-02-02
  • Java排序實現的心得分享

    Java排序實現的心得分享

    這篇文章主要介紹了Java排序實現的心得,有需要的朋友可以參考一下
    2014-01-01
  • java數據結構之實現雙向鏈表的示例

    java數據結構之實現雙向鏈表的示例

    這篇文章主要介紹了java數據結構實現雙向鏈表的示例,需要的朋友可以參考下
    2014-03-03
  • springboot配置多數據源(靜態(tài)和動態(tài)數據源)

    springboot配置多數據源(靜態(tài)和動態(tài)數據源)

    在開發(fā)過程中,很多時候都會有垮數據庫操作數據的情況,需要同時配置多套數據源,本文主要介紹了springboot配置多數據源(靜態(tài)和動態(tài)數據源),感興趣的可以了解一下
    2023-09-09
  • Android 資源 id詳解及的動態(tài)獲取

    Android 資源 id詳解及的動態(tài)獲取

    這篇文章主要介紹了Android 資源 id詳解及的動態(tài)獲取的相關資料,需要的朋友可以參考下
    2016-12-12
  • java如何使用Lombok更優(yōu)雅地編碼

    java如何使用Lombok更優(yōu)雅地編碼

    Lombok能通過注解的方式,在編譯時自動為屬性生成構造器、getter/setter、equals、hashcode、toString方法。這樣就省去了手動重建這些代碼的麻煩,使代碼看起來更簡潔些。下面我們來詳細學習下吧
    2019-06-06
  • 一篇文章教你如何用多種迭代寫法實現二叉樹遍歷

    一篇文章教你如何用多種迭代寫法實現二叉樹遍歷

    這篇文章主要介紹了C語言實現二叉樹遍歷的迭代算法,包括二叉樹的中序遍歷、先序遍歷及后序遍歷等,是非常經典的算法,需要的朋友可以參考下
    2021-08-08
  • 解決ObjectMapper.convertValue() 遇到的一些問題

    解決ObjectMapper.convertValue() 遇到的一些問題

    這篇文章主要介紹了解決ObjectMapper.convertValue() 遇到的一些問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • SpringBoot全局異常與數據校驗的方法

    SpringBoot全局異常與數據校驗的方法

    這篇文章主要介紹了SpringBoot全局異常與數據校驗的方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • 關于SpringMVC請求域對象的數據共享問題

    關于SpringMVC請求域對象的數據共享問題

    這篇文章主要介紹了SpringMVC請求域對象的數據共享問題,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-02-02

最新評論