SHA与MD5简单介绍
SHA介绍
SHA名为安全散列算法,是一种不可逆的数据加密算法,已经成为公认的最安全散列算法之一。
散列算法,是一种从任何一种数据中创建小的数字“指纹”的方法。散列函数把消息或数据压缩成摘要,使得数据量变小,将数据的格式固定下来。该函数将数据打乱混合,重新创建一个叫做散列值(或哈希值)的指纹。散列值通常用一个短的随机字母和数字组成的字符串来代表。
对于任意长度的消息,SHA都会产生一个256bit长的哈希值,称作消息摘要。
MD5介绍
MD5讯息摘要演算法(英语:MD5 Message-Digest Algorithm),一种被广泛使用的密码杂凑函数,可以产生出一个128位元(16位元组)的散列值(hash value),用于确保信息传输完整一致。
输入任意长度的信息,经过处理,输出为128位的信息(数字指纹),
不同的输入得到的不同的结果(唯一性)。
SHA实现
java编码SHA功能
package com.jwy.tools;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class MySHA {
public static String getMD5(String str) {
String reStr = null;
try {
MessageDigest sha = MessageDigest.getInstance("SHA");//创建具有指定算法名称的信息摘要
sha.update(str.getBytes());//使用指定的字节更新摘要。
byte ss[] = sha.digest();//通过执行诸如填充之类的最终操作完成哈希计算
reStr = bytes2String(ss);
} catch (NoSuchAlgorithmException e) {
}
return reStr;
}
private static String bytes2String(byte[] aa) {
//将字节数组转换为字符串
String hash = "";
for (int i = 0; i < aa.length; i++) {
//循环数组
int temp;
if (aa[i] < 0) //判断是否是负数
temp = 256 + aa[i];
else
temp = aa[i];
if (temp < 16)
hash += "0";
hash += Integer.toString(temp, 16);//转换为16进
}
hash = hash.toUpperCase(); //转换为大写
return hash;
}
}
页面实现
<%@page contentType="text/html" pageEncoding="GBK"%>
<html>
<head>
<title>SHA加密</title>
<meta http-equiv="Content-Type" content="text/html; charset=GBK">
<style type="text/css">
<!--
body {
margin-left: 0px;
margin-top: 0px;
margin-right: 0px;
margin-bottom: 0px;
}
-->
</style>
</head>
<body>
<table align="center" width="688" height="625">
<tr>
<td><form name="f1" method="post" action="showInfo.jsp">
<table style="position:relative;top:30;left:210">
<tr>
<td height="23">用户名:</td>
<td height="23"><input name="name"></td>
<