Java加密解密算法-SHA加密

package algo;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

/**
 * SHA(Secure Hash Algorithm,安全散列算法),
 * 数字签名等密码学应用中重要的工具,被广泛地应用于电子商务等信息安全领域。
 * 虽然,SHA与MD5通过碰撞法都被破解了, 但是SHA仍然是公认的安全加密算法,较之MD5更为安全。
 * @author Administrator
 *
 */
public class SHA {

    public static void main(String[] args) {
        String str = "南海是中国的";
        System.out.println("---原始---:"+str);
        String encryptShaRes1 = encryptSHA1(str);
        System.out.println("SHA-1加密后:"+encryptShaRes1);
    }

    private static String SHA = "SHA-1";
    //private static String SHA2 = "SHA";

    /**
     * SHA摘要加密,一般用于数字签名
     * @param decript
     * @return
     */
    public static String encryptSHA1(String decript) {
        try {

            // 获得SHA-1摘要算法的 MessageDigest 对象
            MessageDigest digest = MessageDigest.getInstance(SHA);
            //MessageDigest digest = java.security.MessageDigest.getInstance(SHA2);

            // 使用指定的字节更新摘要
            digest.update(decript.getBytes());

            // 获得密文
            byte[] messageDigest = digest.digest();

            // 把密文转换成十六进制的字符串形式
            StringBuffer hexString = new StringBuffer();

            // 字节数组转换为 十六进制 数
            for (int i = 0; i < messageDigest.length; i++) {
                String shaHex = Integer.toHexString(messageDigest[i] & 0xFF);
                if (shaHex.length() < 2) {
                    hexString.append(0);
                }
                hexString.append(shaHex);
            }
            return hexString.toString();

        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
        return null;
    }
}

你可能感兴趣的:(Java基础知识)