数字签名

原创 2006年05月27日 22:32:00

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

/**

*DigitalSignature2Example.java

*Copyright 2005-2-16

*/

import java.security.Signature;

import java.security.KeyPairGenerator;

import java.security.KeyPair;

import java.security.SignatureException;

 

/**

*数字签名,使用RSA私钥对对消息摘要签名,然后使用公鈅验证 测试

*/

public class DigitalSignature2Example{

 public static void main(String[] args) throws Exception{

  if(args.length!=1){

   System.err.println("Usage:java DigitalSignature2Example <text>");

   System.exit(1);

  }

 

  byte[] plainText=args[0].getBytes("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");

  //使用私鈅签名

  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("/nSignature:");

  System.out.println(new String(signature,"UTF8"));

 

  //使用公鈅验证

  System.out.println("/nStart 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");

   }

  }

}

 

相关文章推荐

数字签名防篡改

  • 2014年09月03日 14:13
  • 1.67MB
  • 下载

公钥与私钥 数字签名的理解

 作者:David Youd 翻译:阮一峰 原文网址:http://www.youdzone.com/signature.html 1. 鲍勃有两把钥匙,一把是公钥,另一把是...
  • slwsww
  • slwsww
  • 2014年06月25日 11:03
  • 2394

CA数字签名认证系统解决方案

  • 2014年08月21日 10:28
  • 531KB
  • 下载

数字签名工具

  • 2015年08月25日 17:07
  • 1.21MB
  • 下载

【graceup系列】--基于Java带数字签名的邮件收发系统

公钥和私钥就是俗称的不对称加密方式,使用公钥与私钥的目的就是实现安全的电子邮件,必须实现如下目的: 1.我发送给你的内容必须加密,在邮件的传输过程中不能被别人看到。 2.必须保证是我发送的邮件,不是别...
  • graceup
  • graceup
  • 2014年08月25日 18:58
  • 2164

数字签名算法

  • 2015年05月30日 14:43
  • 180KB
  • 下载

数字签名是什么?https加密通信的理解。

数字签名是什么? 作者: 阮一峰 日期: 2011年8月 9日 今天,我读到一篇好文章。 它用图片通俗易懂地解释了,"数字签名"(dig...
  • samxx8
  • samxx8
  • 2015年07月22日 13:55
  • 1195

xml数字签名 封装模式

  • 2016年09月30日 16:02
  • 3KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:数字签名
举报原因:
原因补充:

(最多只允许输入30个字)