数字签名
它是确定交换消息的通信方身份的第一个级别。A通过使用公钥加密数据后发给B,B利用私钥解密就得到了需要的数据,问题来了,由于都是使用公钥加密,那么如何检验是A发过来的消息呢?上面也提到了一点,私钥是唯一的,那么A就可以利用A自己的私钥进行加密,然后B再利用A的公钥来解密,就可以了;数字签名的原理就基于此,而通常为了证明发送数据的真实性,通过利用消息摘要获得简短的消息内容,然后再利用私钥进行加密散列数据和消息一起发送。
import java.security.KeyPair; import java.security.KeyPairGenerator; import java.security.Signature; import java.security.SignatureException; public class DigitalSignature { public static void main(String[] args) throws Exception { byte[] srcText = "digital Signature test".getBytes("UTF8"); // 形成RSA公钥对 KeyPairGenerator keyGen = KeyPairGenerator.getInstance("RSA"); keyGen.initialize(1024); KeyPair key = keyGen.generateKeyPair(); // 使用私鈅签名 Signature sig = Signature.getInstance("SHA1WithRSA"); sig.initSign(key.getPrivate()); sig.update(srcText); byte[] signature = sig.sign(); System.out.println(sig.getProvider().getInfo()); System.out.println(new String(signature, "UTF8")); // 使用公鈅验证 sig.initVerify(key.getPublic()); sig.update(srcText); try { if (sig.verify(signature)) { System.out.println("Signature verified"); } else System.out.println("Signature failed"); } catch (SignatureException e) { System.out.println("Signature failed"); } } }