SHA安全散列算法

package com.dream.util;

import java.security.MessageDigest;
import java.security.Security;

import junit.framework.TestCase;
import org.apache.commons.codec.digest.DigestUtils;
import org.bouncycastle.crypto.Digest;
import org.bouncycastle.crypto.digests.SHA1Digest;
import org.bouncycastle.crypto.digests.SHA224Digest;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.bouncycastle.util.encoders.Hex;

/**
 * @author zxg
 * @see SHA 安全散列算法 跟md5的区别主要是明文一样,对应加密后的值密文更加散列,更安全 SHA1,MD5已经被王小云教授破解
 */
public class SHATest extends TestCase {
	private final String str = "zxg is a boy";
	/**
	 * jdk SHA1
	 */
	public void testjdkSHA() throws Exception {
		MessageDigest md = MessageDigest.getInstance("SHA");
		md.update(str.getBytes());
		System.out.println(Hex.toHexString(md.digest()));

	}
	/**
	 * bc SHA1
	 */
	public void testbcSHA1() {
		Digest digest = new SHA1Digest();
		digest.update(str.getBytes(), 0, str.getBytes().length);
		byte[] sha1Bytes = new byte[digest.getDigestSize()];
		digest.doFinal(sha1Bytes, 0);
		System.out.println(org.bouncycastle.util.encoders.Hex
				.toHexString(sha1Bytes));
	}

	/**
	 * bc SHA224
	 */
	public void testbcSHA2() {
		Digest digest = new SHA224Digest();
		digest.update(str.getBytes(), 0, str.getBytes().length);
		byte[] sha224Bytes = new byte[digest.getDigestSize()];
		digest.doFinal(sha224Bytes, 0);
		System.out.println(org.bouncycastle.util.encoders.Hex
				.toHexString(sha224Bytes));
	}

	/**
	 * bc SHA224 第二种方式
	 */
	public void testbcSHA224_2() throws Exception {
		Security.addProvider(new BouncyCastleProvider());
		MessageDigest md = MessageDigest.getInstance("SHA224");
		md.update(str.getBytes());
		System.out.println(Hex.toHexString(md.digest()));

	}

	/**
	 * apache SHA1
	 */
	public void testccSHA() throws Exception {
		System.out.println(DigestUtils.sha1Hex(str.getBytes()));
	}
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值