JAVA每日一题10

本文通过一个具体的Java程序示例,介绍了如何使用MD5生成消息摘要,并利用RSA算法完成数字签名的过程。示例中详细展示了从密钥生成、数据加密到签名验证的整个流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

   题目:用JAVA做一个数字签名的例子。

  

package test;
import java.security.*;
import javax.crypto.*;
public class DigitalSignatureExample
{
	public static void main(String[] args) throws Exception
	{
		// 检查输入参数,得到明文
		if (args.length != 1)
		{
			System.err.println
				("Usage: java DigitalSignature1Example text");
			System.exit(1);
		}
		byte[] plainText = args[0].getBytes("UTF8");
		// 得到MD5消息摘要对象并且计算明文摘要
		MessageDigest messageDigest = 
			MessageDigest.getInstance("MD5");
		System.out.println
			("\n" + messageDigest.getProvider().getInfo());
		messageDigest.update(plainText);
		byte[] md = messageDigest.digest();
		System.out.println("\nDigest: ");
		System.out.println(new String(md, "UTF8"));
		// 生成RSA密钥对
		System.out.println("\nStart generating RSA key");
		KeyPairGenerator keyGen=KeyPairGenerator.getInstance("RSA");
		keyGen.initialize(1024);
		KeyPair key = keyGen.generateKeyPair();
		System.out.println("Finish generating RSA key");
		// 得到RSA cipher同时列出算法的提供人
		Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");
		System.out.println("\n" + cipher.getProvider().getInfo());
		// 将信息加密并且利用RSA私钥进行签名
		System.out.println("\nStart encryption");
		cipher.init(Cipher.ENCRYPT_MODE, key.getPrivate());
		byte[] cipherText = cipher.doFinal(md);
		System.out.println("Finish encryption: ");
		System.out.println(new String(cipherText, "UTF8"));
		// 利用RSA公钥进行解密
		System.out.println("\nStart decryption");
		cipher.init(Cipher.DECRYPT_MODE, key.getPublic());
		byte[] newMD = cipher.doFinal(cipherText);
		System.out.println("Finish decryption: ");
		System.out.println(new String(newMD, "UTF8"));
		// 重新建立信息明文
		System.out.println("\nStart signature verification");
		messageDigest.reset();
		messageDigest.update(plainText);
		byte[] oldMD = messageDigest.digest();
		// 检查签名前后数据是否相同
		int len = newMD.length;
		if (len > oldMD.length)
		{
			System.out.println("Signature failed, length error");
			System.exit(1);
		}
		for (int i = 0; i < len; ++i)
		{	
			if (oldMD[i] != newMD[i])
			{
				System.out.println("Signature failed, element error");
				System.exit(1);
			}
		}
		System.out.println("Signature verified");
	}
}

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值