数字签名编程与实现

本文详细介绍了使用Java实现RSA算法生成数字签名的过程,并通过验证数据签名来确保数据的完整性和不可抵赖性。

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

package com.alex.security;

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.Signature;

public class DigitalSignature {


	public static void main(String[] args) throws Exception{
		//得到keyPairGenerator 的实例对象,并调用其generateKeyPair()方法得到KeyPair对象	
		KeyPair keyPair= KeyPairGenerator.getInstance("RSA").generateKeyPair();
		//调用KeyPair对象的getPrivate和getPublic方法,分别得到PrivateKey对象和PublicKey对象。
		PrivateKey privateKey = keyPair.getPrivate();
		PublicKey publicKey = keyPair.getPublic();
		sign(privateKey);
		verifySign(publicKey);
	}
	
	private static void verifySign(PublicKey publicKey) throws Exception{
		//调用Signature对象的initVerify()方法和指定PublicKey对象,然后调用update方法和verify()方法对原始数据的签名进行验证
		Signature signature = Signature.getInstance("SHA1withRSA");
		signature.initVerify(publicKey);
		signature.update("这是数字签名".getBytes());
		byte[] verifyData = readData("D:/signature.data");
		System.out.println("数字签名检验结果:"+signature.verify(verifyData));
	}

	private static void sign(PrivateKey privateKey) throws Exception {
		//得到Signature的实例对象,调用其initSign()方法和指定PrivateKey对象,然后调用update方法和sign方法产生签名
		Signature signature = Signature.getInstance("SHA1withRSA");
		signature.initSign(privateKey);
		signature.update("这是数字签名".getBytes());
		byte[] signData = signature.sign();
		savaData(signData,"D:/signature.data");
		
	}
	
	private static void savaData(byte[] data,String dataPath) throws Exception{
		FileOutputStream fos = new FileOutputStream(dataPath);
		fos.write(data);
		fos.close();
		
	}
	
	private static byte[] readData(String dataPath) throws Exception{
		FileInputStream fis = new FileInputStream(dataPath); 
		byte[] src = new byte[fis.available()];
		int total=0;
		int len = 0;
		while(total<src.length){
			total = total+len;
			len=fis.read(src, total, src.length-total);
		}
		fis.close();
		return src;
	}

}

运行结果:

数字签名检验结果:true

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值