返回顶部
首页 > 资讯 > 精选 >java中怎么实现数字签名系统
  • 719
分享到

java中怎么实现数字签名系统

2023-06-03 05:06:49 719人浏览 安东尼
摘要

本篇文章为大家展示了java中怎么实现数字签名系统 ,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1。生成密钥对 生成密钥对可用Java提供的类KeyPairGenerator,用其中的getIns

本篇文章为大家展示了java中怎么实现数字签名系统 ,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。


1。生成密钥对
生成密钥对可用Java提供的类KeyPairGenerator,用其中的getInstance方法创建KeypairGenerator对象,在用initialize进行初始化,最后用generateKeyPair生成密钥对,密钥对生成后,就可以将其写入文件中。通过网络或其他方式公告用户,用户接收到数据文件和签名文件后,就可以使用公约来校验数据文件的数字签名,

;判断数据在网络中的传输是否被非法修改。
////GenerateKeyPair.java/////////////
import java.io.*;
import java.security.*;
public class GenerateKeyPair{
public static void main(String[] args){
boolean bHelp=false;//sign for show help.
FileOutputStream fileOut;//输出密钥到文件
byte[] pubkey;//存储已编码的公钥字节
byte[] privKey;//存储已编码的私钥字节
if(args.length!=1){
System.out.println("Usage:GenerateKeyPair

;
System.out.println("Option:");
System.out.println(":The key name that using to genera
te filename.");
System.exit(0);
}
try{
System.out.println("Generating a key pair.....");
KeyPairGenarator keyGen=KeyPairGenerator.getInstance("DSA");//使用DSA算法
KeyGen.initialize(1024,new SecureRandom());
KeyPair pair=keyGen.generateKeyPair();
PublicKey pub=pair.getPublic();
PrivateKey priv=pair.getPrivate();
pubkey=pub.getEncoded();
privateKey= priv.getEncoded();
fileOut=new FileOutputStream("PublicKey_"+args[0]);
fileOut.write(pubKey);
fileOut.close();
fileOut=new FileOutputStream("privateKey_"+args[0]):
fileOut.write(privateKey);
file.out.close();
System.out.println("OK!");
}catch(Exception e){
}
}
}
}

2.生成数字签名
从私钥文件读取数据文件并将其转换为PrivateKey对象,可以使用KeyFactory类和PKCS8EncodeKeySpec类。KeyFactory可以利用给定的蜜月规范来建立不透明的密钥对象,也可以适当的格式取出蜜月对象中的密钥信息。 Signature是个引擎类,提供了诸如DSA或是RSA with MD5这样的数字签名算法。密
码学上安全的签名算法可接受任意大小的输入和一个私月,并产生一个比较短的(常常是固定大小的)前名字揭穿。并且,签名和公钥部反映有关私钥的任何内容。Signature对象即可用于数据签名,也可用于校验某个签名是否为预制关联的数据的真实签名。

签名或教研签名的第一步是创建signature实例,为特定类型的签名算法或取signature对象的途径是调用signature德getInstance静态方法
初始化方法有两个,取决于Signature的用途:
initSign(...)////用于签名
initVerify(.....)//用于校验
如果sigature初始化为签名,则可将带钱数据通过update方法提供给对象在调用sign来产生签名即可。
下面以一个实例来说明。
///////////////////SignData.java////////////////
import java.io.*;
import java.security.*;
import java.security.spec.*;
public class SignData{
public static void main(String [] args)
{
FileOutputStream fileOut;
byte b;
if(args.length!=3)
{
System.out.println("Usage:SignData");
System.out.println("Option:");
System.out.println(":The file name of the private Key.");
System.out.println(": The filename that want to signature.");
System.out.println(":the filename containing signture data.");
}
try{
System.out.println("Generating a digital signature....");
FileInputStream fileIn=new FileInputStream(args[0]);
byte[] encodedprivateKey=new byte[fileIn.available()];

finleIn.read(encodedprivateKey);
fileIn.close();

PKCS8EncodeKeySpec privKeySpec=
new PKCS8EncodeKeySpec(encodedprivateKey);
KeyFactory keyFactory=KeyFactory.getInstance("DSA");
PrivateKey privKey=keyFactory.generatePrivate(privateKeySpec);
Signature dsa=Signature.getInstance("SHA/DSA");
dsa.initSign(privKey);
FileInputStream fis=new FileInputStream(args[1]);
while(fis.available()!=0){
b=(byte)fis.read();
dsa.update(b);
}
fis.close();
byte[] sig=dsa.sign();
fileOut=new FileOutputStream(args[2]);
fileOut.write(sig);
fileOut.close();
System.out.println("OK");
}catch(Exception e){
/////////
}
}
}
///////////////////////End of SignData.java//////////////////
SignData.java从文津中读取已编码的私钥字节,利用PKCS8EncodeKeySpec对象将已编码的四月字节转换为PrivateKey对象,然后利用Signature签名数据文件,生成签名数据,并将签名数据写道文件中。

//////VerifySign.java/////////////
import java.io.*;
import java.security.*;
import java.security.spec.*;
public class VerifySign{
public static void main(String [] args)
{
if(args.length!=3){
System.out.println("Usage:VerifySign");
System.out.println("Option:");
System.out.println("The filename of the public key.");
System.out.println("The filename that want to signature");
System.out.println(":The file name containing signature data.");
System.exit(0);
}
try{
FileInputStream fileIn=new FileInputStream(args[0]);
byte[] encodedpubKey =new byte[fileIn.available()];
fileIn.read(encodedpubKey);
fileIn.close();
X509EncodedKeySpec pubKeySpec=
new X509EncodedKeySpec(encodedpubKey);
KeyFactory keyFactory=KeyFactory.getInstance("DSA");
PublicKey pubKey=keyFactory.generatePublic(pubKeySpec);
FileInputStream sigStream=new FileInputStream(args[2]);
byte[] signature=new byte[sigStream.available()];
sigStream.read(signature);
sigStream.close();
signature siGobj=Signature.getInstance("SHA1WithDSA");
sigObj.initVerify(pubKey);
fileIn=new FileInputStream(args[1]);
byte b;
while(fileIn.available())!=0)
{
b=(byte)fileIn.read();
sigObj.update(b);
};
fileIn.close();
boolean verifies=sigObj.verify(signature);
System.out.println("Signature verifies:"+verifies);
}catch(Exception e){/////////////
}
}
}

上述内容就是java中怎么实现数字签名系统 ,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网精选频道。

--结束END--

本文标题: java中怎么实现数字签名系统

本文链接: https://lsjlt.com/news/232932.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • java中怎么实现数字签名系统
    本篇文章为大家展示了java中怎么实现数字签名系统 ,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1。生成密钥对 生成密钥对可用Java提供的类KeyPairGenerator,用其中的getIns...
    99+
    2023-06-03
  • windows7系统数字签名怎样关闭windows7系统数字签名怎样关闭方式介绍
    windows7系统数字签名怎样关闭是个简单的问题,数字签名作用是可以协助客户辨别电子信息,进而鉴别软件是否位原装软件进而明确真假,不过有些软件工具由于有过开展修改因此必须根据关闭数字签名作用才能运作,那么实际如何操作就需要通过下列wind...
    99+
    2023-07-18
  • 怎么用Java实现添加、验证PDF数字签名
    这篇文章主要讲解了“怎么用Java实现添加、验证PDF数字签名”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用Java实现添加、验证PDF数字签名”吧!目录Jar文件获取及导入方法:在设...
    99+
    2023-06-20
  • DSA数字签名算法怎么实现
    本篇内容介绍了“DSA数字签名算法怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、DSA概述为了确保数据传输的安全性,不得不采取一...
    99+
    2023-06-04
  • 怎么在Win8系统中安装无数字签名驱动
    这篇文章给大家介绍怎么在Win8系统中安装无数字签名驱动,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。方法如下:按电脑的Win+C键,会出现如图所示画面,也可以将鼠标放在电脑的最右边也会出现这个画面。点击设置进入如图所...
    99+
    2023-06-14
  • Java怎么实现抠图片文字或签名
    本篇内容介绍了“Java怎么实现抠图片文字或签名”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!java抠图片文字或签名运行原理第一步 遍历像...
    99+
    2023-07-02
  • 接口签名怎么用Java实现
    java实现接口签名 为了保证数据传输的安全性,跟其他系统进行数据交互时,双方应该约定好密钥,把数据进行加密,接口签名,这样双方调用接口时,验证接口签名一致时就表明数据传输过程中没有...
    99+
    2024-04-02
  • 使用Java怎么添加数字签名到excel
    使用Java怎么添加数字签名到excel?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1. 添加签名import com.spire.xls.*;import&nbs...
    99+
    2023-06-14
  • java签名校验功能怎么实现
    要实现Java签名校验功能,你可以按照以下步骤进行: 获取签名证书:首先,你需要获取要校验的文件的签名证书。可以使用Java的Ke...
    99+
    2023-10-26
    java
  • PHP 对PDF文件实现数字签名
    PHP通过TCPDF库对生成的PDF文件进行数字签名。 效果如下: 这个是因为签名证书不在可信任证书列表中。 目录 准备数字证书 1.申请数字证书 2.自签名证书 安装TCPDF 证书签名 设置证书路径 设置证书信息 设置文档签名...
    99+
    2023-08-31
    pdf PHP 数字签名
  • win10系统无法验证文件数字签名(0xcoooo428)。
    今天我们来谈谈win10系统无法验证文件数字签名(0xcooo428)的解决方案。按主机上的电源按钮(按笔记本电脑键盘上的电源按钮)-关机,关机后按电源按钮重新启动,然后按键盘Ctrl打开电源进入【选择操作系统】界面,点击:更改默认值或选择...
    99+
    2023-07-15
  • Android 系统签名实现的三种方式
    Android 系统签名可以通过以下三种方式实现:1. 使用 Android Studio 自带的签名工具:Android Stud...
    99+
    2023-10-12
    Android
  • Python如何实现elgamal数字签名算法
    要实现ElGamal数字签名算法,可以按照以下步骤:1. 生成密钥对:- 选择一个大素数p作为模数。- 选择一个生成元g,确保g是p...
    99+
    2023-10-10
    Python
  • Java实现添加、验证PDF数字签名的方法示例
    目录Jar文件获取及导入方法:在设置文档内容保护的方法中,除了对文档加密、添加水印外,应用数字签名也是一种有效防伪手段。数字签名的文件比较容易验证,并且具有较高的权威性和可信度。在P...
    99+
    2024-04-02
  • Javascript怎么实现oss签名
    这篇文章主要讲解了“Javascript怎么实现oss签名”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Javascript怎么实现oss签名”吧!引入SDK首先需要引入阿里云的oss-sd...
    99+
    2023-07-06
  • 怎么用python实现数据签名验证
    这篇文章主要讲解了“怎么用python实现数据签名验证”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用python实现数据签名验证”吧!# 请求数据处理方法def b...
    99+
    2023-06-02
  • Android系统签名实现的方式有哪几种
    Android系统签名实现的方式有以下几种: 使用自签名证书:开发者可以使用自己生成的私钥和证书进行签名,这种方式比较简单,但可...
    99+
    2023-10-26
    Android
  • gitlab怎么修改系统名字
    GitLab是一个开源的代码托管平台,它支持所有常见的 Git 操作,例如 push、pull 和 commit 等。GitLab的使用非常方便,可以轻松实现团队协作开发、代码管理和版本控制等功能。在GitLab中,我们可以修改系统名字来方...
    99+
    2023-10-22
  • Ubuntu文件数字签名怎么应用
    本篇内容主要讲解“Ubuntu文件数字签名怎么应用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Ubuntu文件数字签名怎么应用”吧!提示:“数字签名”是一种采用公钥加密算法对电子信息进行签名的...
    99+
    2023-06-16
  • Java中怎么实现实现一个简单得数据响应系统
    这篇文章主要介绍“Java中怎么实现实现一个简单得数据响应系统”,在日常操作中,相信很多人在Java中怎么实现实现一个简单得数据响应系统问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java中怎么实现实现一个...
    99+
    2023-06-25
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作