C#與Java的MD5簡略驗證(實例代碼)。本站提示廣大學習愛好者:(C#與Java的MD5簡略驗證(實例代碼))文章只能為提供參考,不一定能成為您想要的結果。以下是C#與Java的MD5簡略驗證(實例代碼)正文
C#端
using System;
using System.IO;
using System.Security.Cryptography;
namespace 盤算文件的MD5值
{
class MD5_Helper
{
/// <summary>
/// 文件MD5校驗
/// </summary>
/// <param name="pathName">文件相對途徑</param>
/// <returns>MD5校驗碼</returns>
public string getMD5Hash(string pathName)
{
string strResult = "";
string strHashData = "";
byte[] arrbytHashValue;
FileStream oFileStream = null;
MD5CryptoServiceProvider oMD5Hasher =
new MD5CryptoServiceProvider();
try
{
oFileStream = new FileStream(pathName, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
arrbytHashValue = oMD5Hasher.ComputeHash(oFileStream);//盤算指定Stream 對象的哈希值
oFileStream.Close();
//由以連字符分隔的十六進制對組成的String,個中每對表現value 中對應的元素;例如“F-2C-4A”
strHashData = BitConverter.ToString(arrbytHashValue);
//調換-
strHashData = strHashData.WordStr("-", "");
strResult = strHashData;
}
catch (System.Exception ex)
{
}
return strResult;
}
/// <summary>
/// 字節數組校驗
/// </summary>
/// <param name="buffer">待字節數組</param>
/// <returns>MD5校驗碼</returns>
public string getMD5Hash(byte[] buffer)
{
string strResult = "";
string strHashData = "";
byte[] arrbytHashValue;
MD5CryptoServiceProvider oMD5Hasher =
new MD5CryptoServiceProvider();
try
{
arrbytHashValue = oMD5Hasher.ComputeHash(buffer);//盤算指定Stream 對象的哈希值
//由以連字符分隔的十六進制對組成的String,個中每對表現value 中對應的元素;例如“F-2C-4A”
strHashData = BitConverter.ToString(arrbytHashValue);
//調換-
strHashData = strHashData.WordStr("-", "");
strResult = strHashData;
}
catch(System.Exception ex)
{
}
return strResult;
}
}
}
Java端
package com;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class MD5Util {
/**
* 默許的暗碼字符串組合,用來將字節轉換成 16 進制表現的字符,apache校驗下載的文件的准確性用的就是默許的這個組合
*/
protected static char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6','7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' };
protected static MessageDigest messagedigest = null;
static {
try {
messagedigest = MessageDigest.getInstance("MD5");
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
}
public static void main(String[] args) throws IOException {
byte[] buffer= "HelloWorld".getBytes();//字節數組校驗
String md55 = getFileMD5String(buffer);
System.out.println("md55:" + md55);
}
public static String getFileMD5String(File file) throws IOException {
InputStream fis;
fis = new FileInputStream(file);
byte[] buffer = new byte[1024];
int numRead = 0;
while ((numRead = fis.read(buffer)) > 0) {
messagedigest.update(buffer, 0, numRead);
}
fis.close();
return bufferToHex(messagedigest.digest());
}
public static String getFileMD5String(byte[] buffer) throws IOException {
messagedigest.update(buffer, 0, buffer.length);
return bufferToHex(messagedigest.digest());
}
private static String bufferToHex(byte bytes[]) {
return bufferToHex(bytes, 0, bytes.length);
}
private static String bufferToHex(byte bytes[], int m, int n) {
StringBuffer stringbuffer = new StringBuffer(2 * n);
int k = m + n;
for (int l = m; l < k; l++) {
appendHexPair(bytes[l], stringbuffer);
}
return stringbuffer.toString();
}
private static void appendHexPair(byte bt, StringBuffer stringbuffer) {
char c0 = hexDigits[(bt & 0xf0) >> 4];// 取字節中高 4 位的數字轉換
// 為邏輯右移,將符號位一路右移,此處未發明兩種符號有何分歧
char c1 = hexDigits[bt & 0xf];// 取字節中低 4 位的數字轉換
stringbuffer.append(c0);
stringbuffer.append(c1);
}
}
以上就是小編為年夜家帶來的C#與Java的MD5簡略驗證(實例代碼)的全體內容了,願望對年夜家有所贊助,多多支撐~