Android:MD5 32位 16位小写加密

Message Digest Algorithm MD5(中文名为 消息摘要算法第五版)为计算机安全领域广泛使用的一种散列函数,用以提供消息的完整性保护。MD5用的是 哈希函数,在计算机网络中应用较多的 不可逆加密算法有RSA公司发明的MD5算法和由美国国家技术标准研究所建议的 安全散列算法 SHA
/**
* MD5 32位加密方法一 小写
* @param str
* @return
*/

public final static String get32MD5(String s) {
char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };
try {
byte[] strTemp = s.getBytes();
//使用MD5创建MessageDigest对象
MessageDigest mdTemp = MessageDigest.getInstance("MD5");
mdTemp.update(strTemp);
byte[] md = mdTemp.digest();
int j = md.length;
char str[] = new char[j * 2];
int k = 0;
for (int i = 0; i < j; i++) {
byte b = md[i];
//System.out.println((int)b);
//将没个数(int)b进行双字节加密
str[k++] = hexDigits[b >> 4 & 0xf];
str[k++] = hexDigits[b & 0xf];
}
return new String(str);
} catch (Exception e) {
return null;
}

 

/**
* MD5 32位加密方法二 小写
* @param str
* @return
*/

public final static String get32MD5Str(String str) { 
MessageDigest messageDigest = null; 
try { 
messageDigest = MessageDigest.getInstance("MD5"); 
messageDigest.reset(); 
messageDigest.update(str.getBytes("UTF-8")); 
} catch (NoSuchAlgorithmException e) { 
System.out.println("NoSuchAlgorithmException caught!"); 
System.exit(-1); 
} catch (UnsupportedEncodingException e) { 
e.printStackTrace(); 
} 
byte[] byteArray = messageDigest.digest(); 
StringBuffer md5StrBuff = new StringBuffer(); 
for (int i = 0; i < byteArray.length; i++) { 
if (Integer.toHexString(0xFF & byteArray[i]).length() == 1) 
md5StrBuff.append("0").append(Integer.toHexString(0xFF & byteArray[i])); 
else 
md5StrBuff.append(Integer.toHexString(0xFF & byteArray[i])); 
} 
return md5StrBuff.toString(); 
}


 

/**
* Md5 32位 or 16位 加密
* @param plainText 
* @return 32位加密
*/
public static String Md5(String plainText ) {
StringBuffer buf = null;
try {
MessageDigest md = MessageDigest.getInstance("MD5"); 
md.update(plainText.getBytes());
byte b[] = md.digest(); 
int i; 
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));
}
// Log.e("555","result: " + buf.toString());//32位的加密 
//Log.e("555","result: " + buf.toString().substring(8,24));//16位的加密

} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return buf.toString(); 
}


 

附:java String 转化成 MD5 byte[]
public static byte[] hexStringToByte(String hex) {
int len = (hex.length() / 2); 
byte[] result = new byte[len];
char[] achar = hex.toCharArray(); 
for (int i = 0; i < len; i++) {
int pos = i * 2; 
result[i] = (byte) (toByte(achar[pos]) << 4 | toByte(achar[pos + 1])); 
} 
return result; 
} 
private static byte toByte(char c) 
{ 
byte b = (byte) "0123456789abcdef".indexOf(c); 
return b; 
}



 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MD5是一种常用的加密算法,它可以将任意长度的数据转换为固定长度的32位十六进制数。ASP是一种服务器端脚本语言,可以用于开发动态网页。 要在ASP中使用MD5加密算法对字符串进行加密,可以通过调用相关的加密函数来实现。以下是一个简单实例: 首先,我们需要在ASP的代码中引入一个加密函数的库,如"cryptlib.dll"。然后,我们可以定义一个函数来实现对字符串进行MD5加密的功能。例如: ``` <%@ LANGUAGE="VBScript" %> <% Function MD5Encrypt(str) Set crypto = Server.CreateObject("cryptlib.MD5") crypto.GenerateHash crypto.SetString str encryptedStr = crypto.HashStringHex Set crypto = Nothing MD5Encrypt = encryptedStr End Function ' 调用函数进行加密 Dim originalStr originalStr = "Hello World" Dim encryptedStr encryptedStr = MD5Encrypt(originalStr) Response.Write ("原始字符串: " & originalStr & "<br>") Response.Write ("加密后的字符串: " & encryptedStr & "<br>") %> ``` 上述代码中的MD5Encrypt函数使用了cryptlib.dll库中的MD5对象来进行加密。它首先创建了一个MD5对象,然后使用GenerateHash方法生成一个初始哈希值。接着,使用SetString方法将要加密的字符串传递给MD5对象。最后,使用HashStringHex方法获取加密后的字符串,并返回给调用者。 通过上述代码,我们可以对任意字符串进行MD5加密,并将加密后的结果输出到网页上。 需要注意的是,MD5算法是一种单向不可逆的加密算法,即无法从加密后的结果中还原出原始字符串。因此,MD5加密通常用于存储用户密码等敏感信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值