java加密——摘要算法

原创
2015/08/11 16:57
阅读数 198

MD5

  • 概述

MD5即Message Digest Algorithm 5(信息摘要算法5),用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一(又称摘要算法、哈希算法),主流编程语言普遍已有MD5实现。

  • MD5算法具有以下特点

     1、压缩性:任意长度的数据,算出的MD5值长度都是固定的。

     2、容易计算:从原数据计算出MD5值很容易。

     3、抗修改性:对原数据进行任何改动,哪怕只修改1个字节,所得到的MD5值都有很大区别。

     4、弱抗碰撞:已知原数据和其MD5值,想找到一个具有相同MD5值的数据(即伪造数据)是非常困难的。

      5、强抗碰撞:想找到两个不同的数据,使它们具有相同的MD5值,是非常困难的

  • 原理

        对MD5算法简要的叙述可以为:MD5以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值。 

  • 实例代码

public static byte[] encrypt(String str) throws NoSuchAlgorithmException {
  //根据MD5算法生成MessageDigest对象 
  MessageDigest md5 = MessageDigest.getInstance("MD5");
  byte[] srcData = str.getBytes();
  // 使用srcBytes更新摘要
  md5.update(srcData);
  // 完成哈希计算,得到result
  return md5.digest();
 }

SHA

  • 概述

    安全哈希算法(Secure Hash Algorithm)主要适用于数字签名标准(Digital Signature Standard DSS)里面定义的数字签名算法(Digital Signature Algorithm DSA)。对于长度小于2^64位的消息,SHA1会产生一个160位的消息摘要。

  • 原理

    SHA-1是一种数据加密算法,该算法的思想是接收一段明文,然后以一种不可逆的方式将它转换成一段(通常更小)密文,也可以简单的理解为取一串输入码(称为预映射或信息),并把它们转化为长度较短、位数固定的输出序列即散列值(也称为信息摘要或信息认证代码)的过程。

  • 实例代码

public static byte[] encrypt(String str) throws NoSuchAlgorithmException {
  //根据SHA算法生成MessageDigest对象 
  MessageDigest sha = MessageDigest.getInstance("SHA");
  
  byte[] srcData = str.getBytes();
  // 使用srcBytes更新摘要
  sha.update(srcData);
  // 完成哈希计算,得到result
  return sha.digest();
 }

 

展开阅读全文
加载中

作者的其它热门文章

打赏
0
4 收藏
分享
打赏
0 评论
4 收藏
0
分享
返回顶部
顶部