Java加密和数字签名4数字签名

来源:java认证发布时间:2012-11-12 13:06:04java认证视频

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

  编辑特别推荐:

  Java核心API需要掌握的程度

  Java编程实例:Java版农历和阳历转换源码

  Java认证辅导:非阻塞I/O简介

  Tomcat内存溢出的三种情况及解决办法分析

  Java输入数据流详解

视频学习

我考网版权与免责声明

① 凡本网注明稿件来源为"原创"的所有文字、图片和音视频稿件,版权均属本网所有。任何媒体、网站或个人转载、链接转贴或以其他方式复制发表时必须注明"稿件来源:我考网",违者本网将依法追究责任;

② 本网部分稿件来源于网络,任何单位或个人认为我考网发布的内容可能涉嫌侵犯其合法权益,应该及时向我考网书面反馈,并提供身份证明、权属证明及详细侵权情况证明,我考网在收到上述法律文件后,将会尽快移除被控侵权内容。

最近更新

社区交流

考试问答