数字签名标准算法——DSA

  • 1. 算法简述
  • 2.模型分析
  • 3. 代码实现
    • 3.1 算法实现
    • 3.2 测试代码
    • 3.3 运行结果

1. 算法简述

RSA为经典数字签名算法
数字签名标准(Digital Signature Standard, DSS), DSS本质是ElGamal数字签名算法,DSS使用的算法成为数字签名算法(Digital Signature Algorithm, DSA)。

DSA与RSA是数字证书不可或缺的两种算法。DSA算法仅包含数字签名算法,使用DSA算法的数字证书无法进行加密通信,而RSA算法既包含加密/解密算法,同时兼具数字签名算法。

2.模型分析

Alice与Bob作为消息交互双方,签名/验签流程如下

3. 代码实现

Java及Bouncy Castle对RSA实现细节

算法 密钥长度 密钥默认长度 签名长度 备注
SHA1withDSA 512~1024位(64倍数) 1024 - Java
SHA224withDSA、SHA256withDSA 、SHA384withDSA、SHA512withDSA 512~1024位(64倍数) 1024 - Bouncy Castle实现

3.1 算法实现

下面是Java的DSA算法实现

package com.calvin.android.demo2.secrity;import java.security.Key;
import java.security.KeyFactory;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.SecureRandom;
import java.security.Signature;
import java.security.interfaces.DSAPrivateKey;
import java.security.interfaces.DSAPublicKey;
import java.security.spec.PKCS8EncodedKeySpec;
import java.security.spec.X509EncodedKeySpec;
import java.util.HashMap;
import java.util.Map;/*** Author:cl* Email:lhzheng@grandstream.cn* Date:20-10-21*/
public class DSACoder {/*** 数字签名密钥算法*/public static final String KEY_ALGORITHM = "DSA";/*** 数字签名* 签名/验证算法*/public static final String SIGNATURE_ALGORITHM = "SHA1withDSA";//公钥 Map Keyprivate static final String PUBLIC_KEY = "DSAPublicKey";//私钥Map keyprivate static final String PRIVATE_KEY = "DSAPrivateKey";/*** DSA密钥长度,默认1024位,密钥长度必须是64的倍数,范围512~1024位之间*/private static final int KEY_SIZE = 1024;/*** 签名* @param data 待签名数据* @param privateKey 私钥* @return byte[] 数字签名* @throws Exception 异常*/public static byte[] sign(byte[] data, byte[] privateKey) throws Exception {//转换私钥材料PKCS8EncodedKeySpec pkcs8KeySpec = new PKCS8EncodedKeySpec(privateKey);//实例化密钥工厂KeyFactory keyFactory = KeyFactory.getInstance(KEY_ALGORITHM);//取私钥对象PrivateKey priKey = keyFactory.generatePrivate(pkcs8KeySpec);//实例化SignatureSignature signature = Signature.getInstance(SIGNATURE_ALGORITHM);//初始化Signaturesignature.initSign(priKey);//更新signature.update(data);//签名return signature.sign();}/*** 校验* @param data 待校验数据* @param publicKey 公钥* @param sign 数字签名* @return boolean 校验成功返回true,校验失败返回false* @throws Exception*/public static boolean verity(byte[] data, byte[] publicKey, byte[] sign) throws  Exception{//转换公钥材料X509EncodedKeySpec keySpec = new X509EncodedKeySpec(publicKey);//实例化密钥工厂KeyFactory keyFactory = KeyFactory.getInstance(KEY_ALGORITHM);//生成公钥PublicKey pubKey = keyFactory.generatePublic(keySpec);//实例化SignatureSignature signature = Signature.getInstance(SIGNATURE_ALGORITHM);//初始化Signaturesignature.initVerify(pubKey);//更新signature.update(data);//校验证return signature.verify(sign);}public static Map<String, Object> initKey() throws Exception {//实例化密钥对生成器KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance(KEY_ALGORITHM);//初始化密钥对生成器keyPairGen.initialize(KEY_SIZE, new SecureRandom());//生成密钥对KeyPair keyPair = keyPairGen.generateKeyPair();//公钥DSAPublicKey publicKey = (DSAPublicKey)keyPair.getPublic();//私钥DSAPrivateKey privateKey = (DSAPrivateKey)keyPair.getPrivate();//封装密钥Map<String, Object> keyMap = new HashMap<>(2);keyMap.put(PUBLIC_KEY, publicKey);keyMap.put(PRIVATE_KEY, privateKey);return keyMap;}public static byte[] getPublicKey(Map<String, Object> keyMap){return  ((Key)keyMap.get(PUBLIC_KEY)).getEncoded();}public static byte[] getPrivateKey(Map<String, Object> keyMap){return  ((Key)keyMap.get(PRIVATE_KEY)).getEncoded();}
}

3.2 测试代码

 @Testpublic void dsaSignTest() throws Exception {//初始化密钥Map<String, Object> keyMap = DSACoder.initKey();byte[] publicKey = DSACoder.getPublicKey(keyMap);byte[] privateKey = DSACoder.getPrivateKey(keyMap);System.out.println("公钥:\t"+Base64.encodeToString(publicKey, Base64.DEFAULT));System.out.println("私钥:\t"+Base64.encodeToString(privateKey, Base64.DEFAULT));String inputStr = "DSA数字签名";byte[] data = inputStr.getBytes();//产生签名byte[] sign = DSACoder.sign(data, privateKey);System.out.println("签名:\t"+ Hex.toHexString(sign));//验证签名boolean status = DSACoder.verity(data, publicKey, sign);System.out.println("验签状态:\t"+ status);assertTrue(status);}

3.3 运行结果

2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: 公钥:    MIIBtjCCASsGByqGSM44BAEwggEeAoGBALp0XqBwHX0xv8pzTPn1vYI9xC5eshO2gPWPXOhjNSWY
2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: El4u3aLJcOWW9zrvb9Zzm6jjH316keUqnhbd1A007N3sXIW43YVjsPcqQLw5g45PTxK83UPsVGck
2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: ucwOx38Z1ByI0HW/Hgt8ym3GZ6YRsBNFoJ6AV7ECbHeg9FQ/XvhTAhUAoCMUYSx3rXCqIs7ykNak
2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: JapM0G0CgYBo66ouj4XZz0S3FQaoknrOuSxlYj0UidiXx3NjqEwzSf6gUEVRur+O+xee0pIZ7Ywf
2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: wzGfUqjP+Mmn6huQDCRyk5eO9u2NbsRKdBYRGndMbwAO1vyNehtW0TUuxddC1vcdXCUctYAMH49H
2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: RIoXg2z+s8KO0BTli2H9Igy69g2ZtwOBhAACgYAsVYqi4LJcuZp8iNKjrPI4jiFxfekwuIx2vmrI
2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: v8yL1602hHirLP85/ibNR8ICGTJK3tkt/FO7nk0DOlLTkct5gXOpzGvp/UuPEONZosxgPHHbf0zQ
2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: NFOWkk6UrOUV4BWcDU6u2OFMf3GAQ4JwUgElTXEI/iyV8m6aD8VCasltcA==
2020-10-21 15:06:08.631 15896-15911/com.calvin.android.demo2 I/System.out: 私钥:   MIIBSgIBADCCASsGByqGSM44BAEwggEeAoGBALp0XqBwHX0xv8pzTPn1vYI9xC5eshO2gPWPXOhj
2020-10-21 15:06:08.631 15896-15911/com.calvin.android.demo2 I/System.out: NSWYEl4u3aLJcOWW9zrvb9Zzm6jjH316keUqnhbd1A007N3sXIW43YVjsPcqQLw5g45PTxK83UPs
2020-10-21 15:06:08.631 15896-15911/com.calvin.android.demo2 I/System.out: VGckucwOx38Z1ByI0HW/Hgt8ym3GZ6YRsBNFoJ6AV7ECbHeg9FQ/XvhTAhUAoCMUYSx3rXCqIs7y
2020-10-21 15:06:08.631 15896-15911/com.calvin.android.demo2 I/System.out: kNakJapM0G0CgYBo66ouj4XZz0S3FQaoknrOuSxlYj0UidiXx3NjqEwzSf6gUEVRur+O+xee0pIZ
2020-10-21 15:06:08.631 15896-15911/com.calvin.android.demo2 I/System.out: 7YwfwzGfUqjP+Mmn6huQDCRyk5eO9u2NbsRKdBYRGndMbwAO1vyNehtW0TUuxddC1vcdXCUctYAM
2020-10-21 15:06:08.631 15896-15911/com.calvin.android.demo2 I/System.out: H49HRIoXg2z+s8KO0BTli2H9Igy69g2ZtwQWAhQg4fIBUelmYm8aJvyPOqLadXBAtg==
2020-10-21 15:06:08.636 15896-15911/com.calvin.android.demo2 I/System.out: 签名:   302c0214404e14880800664e6cd8cb1f8d7c9cfb692c789702144c7ecdfe4128001f838042a913ea714eeced0d12
2020-10-21 15:06:08.640 15896-15911/com.calvin.android.demo2 I/System.out: 验签状态: true

数字签名标准算法——DSA相关推荐

  1. 数字签名标准(DSS)

    0x01 数字签名标准 数字签名标准 (DSS) 是美国国家安全局开发的一种数字签名算法,作为电子文档的身份验证手段. DSS 创建后,于 1994 年由美国国家标准与技术研究院出版,此后成为美国政府 ...

  2. 密码学---数字签名和认证协议---数字签名标准

    数字签名标准 DSS的基本方式 RSA签名过程 DSS签名过程 数字签名算法DSA 全局公钥 用户私钥x 用户公钥y 用户为待签消息选取的秘密数k 签名过程 验证过程 数字签名标准(Digital S ...

  3. java 签名 ecdsa_Java数字签名——ECDSA算法

    ECDSA 例如微软产品的序列号的验证算法. Elliptic Curve Digital Signature Algorithm,椭圆曲线数字签名算法. 速度快,强度高,签名短 ---------- ...

  4. mbedtls学习(9)数字签名RSA、DSA、ECDSA

    数字签名作用 数字签名是为了识别消息是否被篡改并验证消息可靠性,也可以防止否认.这里注意下和消息验证码的不同,数字签名还可以防止否认,因为数字签名的私钥只有签名者才持有,而消息认证码中的密钥是双方都有 ...

  5. 美国NIST公布首批后量子密码标准算法

    导读 随着量子计算技术的发展,相关运算操作在理论上实现从指数级向多项式级别的转变,量子计算机有望攻破现有的公钥密码体制.为应对出现的新型威胁,后量子密码(PQC)应运而生,旨在研究密码算法在量子环境下 ...

  6. 数字签名标准(DSS)工作原理指南

    正如我们所研究的, 签名是一种验证来自受信任个人的数据的方法.同样, 电子签名是一种对来自可信来源的数字数据进行身份验证的方法. 数字签名标准(DSS)是联邦信息处理标准(FIPS), 它定义了用于在 ...

  7. 浅析国家商用密码标准算法

    浅析国家商用密码标准算法 中国商用密码概况 概况 国产商密算法是我国自主研发.具有自主知识产权的一系列密码算法,具有较高安全性,由国家密码局公开并大力推广.我国公开的国产商用密码算法包括SM1.SM2 ...

  8. dss数字签名技术java_DSS数字签名标准

    DSS数字签名标准 签名过程: graph TD; id2 -.Signature.-> id12 subgraph Signature Generation; id0(Message/Data ...

  9. Java数字签名——RSA算法

    数字签名:带有密钥(公钥,私钥)的消息摘要算法. 验证数据的完整性,认证数据的来源,抗否性 OSI参考模型 私钥签名,公钥验证 签名算法:RSA,DSA,ECDSA 算法1 :RSA MD,SHA两类 ...

最新文章

  1. ECS TAG功能详解
  2. Android入门(十二)SQLite事务、升级数据库
  3. spring beans源码解读之--BeanFactory进化史
  4. 关于4.8节第一个例子
  5. python websocket库 安装_Python WebSocket
  6. STM32串口在首次发送字符的时候,首字符丢失解决办法
  7. 绝地求生大逃杀最新服务器,《绝地求生大逃杀》将建立该国家或地区玩家的专有服务器!...
  8. Oracle命令--alter 操作
  9. 输入快捷键显示未知命令_「干货」华为VRP基础和常用命令了解一下
  10. Java 容器源码分析之Queue
  11. 如何修改WAMP中mysql默认空密码重新登录phpmyadmin
  12. 零空间追踪 matlab,中国科学院自动化研究所
  13. 如何使用JMeter 对Dubbo接口进行测试
  14. oracle sequence nextval,SOS!!! Sequence.nextval 的问题
  15. MAC的delete键与Windows的对应关系
  16. 知了Excel教你vlookup反向查询,就是这么简单
  17. 影响微信公众号排名的因素
  18. win10出现打印机无法打印,而其他显示正常,重启没反应
  19. [KITTI] EVO评价前端里程计精度
  20. Java里面的同步和异步

热门文章

  1. 20170118修改商品流水
  2. 使用BERT的两层encoder实现tweet sentiment extraction
  3. 这是我见过描写天津女孩中最真实的
  4. python简单笔试题_python编程简单笔试题
  5. 个人博客站点添加谷歌联盟Google Adsense
  6. 蓝光影视媒体菜单结构浅析[原版加字幕保留花絮/主菜单/弹出菜单并分割对应PS3]...
  7. 信息学竞赛有什么好的比赛网站?
  8. 经验分享——本科非技术女
  9. 苏黎世大学研发了一种算法 可让无人机像汽车一样在街道上行驶
  10. 【项目--Hi3559A】Hi3559A平台仿真功能操作介绍