如何使用Java生成MD5代码

Python014

如何使用Java生成MD5代码,第1张

这是我以前做的一个小项目时用到md5写的

import java.security.MessageDigest

import java.security.NoSuchAlgorithmException

//将用户密码进行md5加密   并返回加密后的32位十六进制密码

public class MD5Util {

public static String md5(String password) {

try {

// 获取md5对象

MessageDigest md = MessageDigest.getInstance("md5")

// 获取加密后的密码并返回十进制字节数组

byte[] bytes = md.digest(password.getBytes())

// 遍历数组得到每个十进制数并转换成十六进制

StringBuffer sb = new StringBuffer()

for (byte b : bytes) {

// 把每个数转成十六进制 存进字符中

sb.append(toHex(b))

}

String finish = sb.toString()

return finish

} catch (NoSuchAlgorithmException e) {

e.printStackTrace()

throw new RuntimeException(e)

}

}

// 十进制转十六进制方法

private static String toHex(byte b) {

int target = 0

if (b <0) {

target = 255 + b

} else {

target = b

}

int first = target / 16

int second = target % 16

return Hex[first] + Hex[second]

}

static String[] Hex = { "0", "1", "2", "3", "4", "5", "6", "7", "8", "9",

"a", "b", "c", "d", "e", "f" }

/*public static void main(String[] args) {

String a = MD5Util.md5("1234")

System.out.println(a)

}*/

}

这里定义了一些基本的变量与静态对象,并指定采用的方式是“md5“,下张图为定义了一个方法,方法的参数是接收一个文件File对象,并且返回该文件生成的”md5“值。

这里定义了一个转化方法,把文件或文件流以字节的方式进行转换,使之生成唯一的md5,此方法间接的应用到了md5的生成中。

这里主要定义了一个根据提供的文件流输入流InputStream进行生成md5的值,如上几幅图中的代码加在一起就是完整的文件或文件流的md5值生成方法。

4

最后一张图片为最终生成后的效果,文件上传的时候可以先生成md5的值后到数据库中进行查找,如果找到了就说明相同的文件已经存在,那么就不应该再保存了,否则会出现相同的冗余文件。

考虑一下中文字符问题。两边使用的编码是不是一样的。保持一样就可以了。

建议使用UTF8编码

JAVA代码如下(在你给同的代码上只做了少量修改):

public class Security {

public static void main(String[] args) {

try {

System.out.println(MD5("中国"))

} catch(Exception ex) {}

}

public static String MD5(String txt) {

char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',

'a', 'b', 'c', 'd', 'e', 'f' }

try {

byte[] btInput = txt.getBytes("utf-8")

MessageDigest mdInst = MessageDigest.getInstance("MD5")

// 使用指定的字节更新摘要

mdInst.update(btInput)

// 获得密文

byte[] md = mdInst.digest()

// 把密文转换成十六进制的字符串形式

int j = md.length

char str[] = new char[j * 2]

int k = 0

for (int i = 0 i < j i++) {

byte byte0 = md[i]

str[k++] = hexDigits[byte0 >>> 4 & 0xf]

str[k++] = hexDigits[byte0 & 0xf]

}

return new String(str)

} catch (Exception e) {

e.printStackTrace()

return null

}

}

}

C#代码如下:

static void Main(string[] args)

        {

            Console.WriteLine(Md5("中国"))

            Console.ReadLine()

        }

        static string Md5(string txt) {

            byte[] result = Encoding.UTF8.GetBytes(txt)   

            MD5 md5 = new MD5CryptoServiceProvider()

            byte[] output = md5.ComputeHash(result)

            return BitConverter.ToString(output).Replace("-", "")  

        }