欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

数字签名

程序员文章站 2022-07-09 12:37:20
...

数字签名,它是确定交换消息的通信方身份的第一个级别。上面A通过使用公钥加密数据后发给B,B利用私钥解密就得到了需要的数据,问题来了,由于都是使用公钥加密,那么如何检验是A发过来的消息呢?上面也提到了一点,私钥是唯一的,那么A就可以利用A自己的私钥进行加密,然后B再利用A的公钥来解密,就可以了;数字签名的原理就基于此,而通常为了证明发送数据的真实性,通过利用消息摘要获得简短的消息内容,然后再利用私钥进行加密散列数据和消息一起发送。java中为数字签名提供了良好的支持,java.security.Signature类提供了消息签名

 

package com.ijo.security;

import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.Signature;
import java.security.SignatureException;

public class DigitalSignature2Example {

	public static void main(String[] args) throws Exception {
		byte[] plainText = "Hello china".getBytes("UTF8");
		// 形成RSA公钥对
		System.out.println("Start generating RSA key");
		KeyPairGenerator ****** = KeyPairGenerator.getInstance("RSA");
		******.initialize(1024);
		KeyPair key = ******.generateKeyPair();
		System.out.println("Finish generating RSA key");
		// 使用私鈅签名
		Signature sig = Signature.getInstance("SHA1WithRSA");
		sig.initSign(key.getPrivate());
		sig.update(plainText);
		byte[] signature = sig.sign();
		System.out.println(sig.getProvider().getInfo());
		System.out.println("Signature:");
		System.out.println(new String(signature, "UTF8"));
		// 使用公鈅验证
		System.out.println("Start signature verification");
		sig.initVerify(key.getPublic());
		sig.update(plainText);
		try {
			if (sig.verify(signature)) {
				System.out.println("Signature verified");
			} else
				System.out.println("Signature failed");
		} catch (SignatureException e) {
			System.out.println("Signature failed");
		}
	}

}

 

相关标签: Security Java

上一篇: 求原根

下一篇: Document Schemas¶