SHA 1摘要演算法原始碼

2021-08-29 19:07:37 字數 2625 閱讀 8367

public class sha1 ;

// 摘要資料儲存陣列

private int digestint = new int[5];

// 計算過程中的臨時資料儲存陣列

private int tmpdata = new int[80];

// 計算sha-1摘要

private int process_input_bytes(byte bytedata)

// 摘要計算函式

encrypt();

}return 20;

}// 格式化輸入位元組陣列格式

private byte bytearrayformatdata(byte bytedata) else if (m == 56) else

// 補位後生成的新陣列內容

byte newbyte = new byte[size];

// 複製陣列的前面部分

system.arraycopy(bytedata, 0, newbyte, 0, n);

int l = n;

// 補1操作

newbyte[l++] = (byte) 0x80;

// 補0操作

for (int i = 0; i < zeros; i++)

// 計算資料長度,補資料長度位共8位元組,長整型

long n = (long) n * 8;

byte h8 = (byte) (n & 0xff);

byte h7 = (byte) ((n >> 8) & 0xff);

byte h6 = (byte) ((n >> 16) & 0xff);

byte h5 = (byte) ((n >> 24) & 0xff);

byte h4 = (byte) ((n >> 32) & 0xff);

byte h3 = (byte) ((n >> 40) & 0xff);

byte h2 = (byte) ((n >> 48) & 0xff);

byte h1 = (byte) (n >> 56);

newbyte[l++] = h1;

newbyte[l++] = h2;

newbyte[l++] = h3;

newbyte[l++] = h4;

newbyte[l++] = h5;

newbyte[l++] = h6;

newbyte[l++] = h7;

newbyte[l++] = h8;

return newbyte;

}private int f1(int x, int y, int z)

private int f2(int x, int y, int z)

private int f3(int x, int y, int z)

private int f4(int x, int y)

// 單元摘要計算函式

private void encrypt()

int tmpabcde = new int[5];

for (int i1 = 0; i1 < tmpabcde.length; i1++)

for (int j = 0; j <= 19; j++)

for (int k = 20; k <= 39; k++)

for (int l = 40; l <= 59; l++)

for (int m = 60; m <= 79; m++)

for (int i2 = 0; i2 < tmpabcde.length; i2++)

for (int n = 0; n < tmpdata.length; n++)

}// 4位元組陣列轉換為整數

private int bytearraytoint(byte bytedata, int i)

// 整數轉換為4位元組陣列

private void inttobytearray(int intvalue, byte bytedata, int i)

// 將位元組轉換為十六進製制字串

private static string bytetohexstring(byte ib) ;

char ob = new char[2];

ob[0] = digit[(ib >>> 4) & 0x0f];

ob[1] = digit[ib & 0x0f];

string s = new string(ob);

return s;

}// 將位元組陣列轉換為十六進製制字串

private static string bytearraytohexstring(byte bytearray)

return strdigest;

}// 計算sha-1摘要,返回相應的位元組陣列

public byte getdigestofbytes(byte bytedata)

return digest;

}// 計算sha-1摘要,返回相應的十六進製制字串

public string getdigestofstring(byte bytedata)

public static void main(string args)

}

SHA1 摘要演算法

sha1 演算法 訊息摘要演算法,把訊息按照512 bits進行分組,不斷的對5個int型變數進行計算,直到所有訊息都運算完畢。最終得到 160 bit 即 20 位元組的雜湊值。流程圖 c語言實現 用到的資料結構 sha1演算法的上下文,儲存一些狀態,中間資料,結果 typedef struct ...

SHA1演算法原理

1 sha1演算法簡介 安全雜湊演算法 secure hash algorithm 主要適用於數字簽名標準 digital signature standard dss 裡面定義的數字簽名演算法 digital signature algorithm dsa 對於長度小於2 64位的訊息,sha1會...

Sha 1演算法詳解

一 hash函式和訊息完整性 二 常見的hash函式 三 sha 1演算法實現的基本步驟 1 將訊息摘要轉換成位字串 01100001 01100010 01100011 2 對轉換後的位字串進行補位操作 初始的資訊摘要 01100001 01100010 01100011 第一步補位 011000...