`
yjhexy
  • 浏览: 331215 次
  • 性别: Icon_minigender_1
  • 来自: 火星
社区版块
存档分类
最新评论

DSA算法原理

阅读更多

Digital Signature Algorithm (DSA)是Schnorr和ElGamal签名算法的变种,被美国NIST作为DSS(DigitalSignature Standard)。算法中应用了下述参数:

p:L bits长的素数。L是64的倍数,范围是512到1024;
q:p - 1的160bits的素因子;
g:g = h^((p-1)/q) mod p,h满足h < p - 1, h^((p-1)/q) mod p > 1;
x:x < q,x为私钥 ;
y:y = g^x mod p ,( p, q, g, y )为公钥;
H( x ):One-Way Hash函数。DSS中选用SHA( Secure Hash Algorithm )。
p, q, g可由一组用户共享,但在实际应用中,使用公共模数可能会带来一定的威胁。签名及验证协议如下:

1. P产生随机数k,k < q;
2. P计算 r = ( g^k mod p ) mod q
s = ( k^(-1) (H(m) + xr)) mod q
签名结果是( m, r, s )。
3. 验证时计算 w = s^(-1)mod q
u1 = ( H( m ) * w ) mod q
u2 = ( r * w ) mod q
v = (( g^u1 * y^u2 ) mod p ) mod q
若v = r,则认为签名有效。

  DSA是基于整数有限域离散对数难题的,其安全性与RSA相比差不多。DSA的一个重要特点是两个素数公开,这
样,当使用别人的p和q时,即使不知道私钥,你也能确认它们是否是随机产生的,还是作了手脚。RSA算法却作不到。

分享到:
评论

相关推荐

    dsa.zip_dsa_zip

    二、DSA算法原理 1. 参数设定:DSA算法需要三个参数p、q和g,其中p和q是两个大素数,且p-1被q整除,g是模p的乘法群中的一个生成元。这些参数在算法开始时由权威机构生成并分发。 2. 私钥生成:私钥是随机选择的一...

    DSA-Test.zip_dsa

    1. **DSA算法原理:**DSA是基于离散对数问题的,由美国国家标准和技术研究所(NIST)制定,主要由三个参数构成:p(大素数)、q(p的因子)、g(模p的乘法群的生成元)。它包括签名和验证两部分,签名过程涉及私钥,...

    实验三 DSA数字签名算法.doc

    DSA 算法原理: DSA 算法是基于整数有限域离散对数难题的,其安全性与 RSA 相比差不多。该算法的安全性主要基于两个大素数p和q的安全性。p是L bits 长的素数,L 是 64 的倍数,范围是 512 到 1024;q是p - 1 的 160...

    DSA.rar_DSA算法,matlab_dsa

    DSA算法的核心思想是随机搜索和接受概率,它通过在解空间中进行随机跳转,避免陷入局部最优。在初始阶段,算法允许较大范围的跳转,随着迭代次数增加,跳转的概率逐渐减小,最终收敛到一个稳定状态,即全局最优解。 ...

    liuzhigao.rar_DSA实现_DSA算法_dsa_dsa用C实现

    标题"liuzhigao.rar_DSA实现_DSA算法_dsa_dsa用C实现"中,核心关键词是“DSA实现”、“DSA算法”以及“C实现”,这表明这是一个关于使用C语言实现数字签名算法(Digital Signature Algorithm,简称DSA)的项目。...

    DSA.rar_DSA algorithm_DSA 源代码_DSA算法_dsa算法c_加密

    在给定的压缩包中,`DSA算法`可能是包含DSA算法实现的源代码文件,可能包含C语言或者其他编程语言的实现。`www.pudn.com.txt`可能是一个链接或说明文件,提供了获取更多资源的指引。 ### 应用场景 DSA常用于以下...

    DSA.rar_DSA数字签名_DSA算法_dsa_java dsa_数字签名

    在Java中实现DSA算法,可以帮助开发者构建安全的应用程序,保障网络通信的安全。 DSA的核心概念包括三个主要元素:公钥、私钥和签名。公钥是可以公开的,用于验证签名;私钥则是保密的,用于生成签名。DSA的工作...

    JAVA_DSA.rar_DSA算法_dsa

    DSA(Digital Signature Algorithm)是一种基于离散对数...综上所述,Java实现DSA算法涉及了数论基础、密码学原理以及Java安全框架的应用。通过理解和实践这些知识点,可以有效地进行数字签名,保障数据传输的安全性。

    rsa-elgamal-dsa.rar_DSA算法_ELGAMAL_dsa_dsa签名算法_elgamal java

    1. DSA算法: DSA是一种基于离散对数难题的数字签名算法,由美国国家安全局(NSA)设计,并在FIPS PUB 186中被标准化。它主要由两个部分组成:签名生成和签名验证。在Java中,`java.security.Signature`类提供了DSA...

    DSA签名算法的Java实现

    1. **DSA原理**: DSA基于数学上的离散对数问题,包含一对密钥:公钥和私钥。私钥由用户保管,用于创建签名;公钥则公开,用于验证签名。签名过程包括两个步骤:哈希计算和模运算。验证过程与之相反,通过公钥、...

    dsa数字签名算法的验证及实现

    在你提供的压缩包文件中,"liuzhigao"可能是代码文件或相关资料的名称,可能包含实现DSA算法的源代码或者验证过程的详细说明。如果你能够理解并分析这些代码,将有助于你更深入地理解DSA的工作原理,并可能帮助你在...

    公钥算法RSA与DSA的证明推导

    证明推导了公钥加密算法RSA和签名算法DSA,RSA和DSA是SSL/TLS的基础,理解算法的数学原理,有助于加深对网络安全的理解

    易语言实现RSA,ECC,DES,AES,DSA算法

    在这个主题中,我们将深入探讨如何在易语言中实现几种重要的加密算法:RSA,ECC,DES,AES以及DSA。 **RSA** 是一种非对称加密算法,由Ron Rivest、Adi Shamir和Leonard Adleman于1977年提出。在RSA中,数据使用...

    java AES,DES,3DES,RAS,DSA 加密算法实现

    以下将详细介绍这些加密算法的原理及Java中的实现。 1. **AES(高级加密标准)** AES全称为Advanced Encryption Standard,是一种对称加密算法,因其高效性和安全性被广泛使用。它基于128位的块大小和可变长度的...

    RSA,DES,ElGamal,DSA,MD5,BLOWFISH加密算法原理详解

    本文将详细介绍几种常见的加密算法,包括RSA、DES、ElGamal、DSA、MD5和Blowfish,主要关注RSA算法的原理。 RSA是一种非对称加密算法,由Ron Rivest、Adi Shamir和Leonard Adleman三位科学家于1977年提出,因其名字...

    DSA.zip_dsa_zip

    标签"dsa zip"进一步确认了文件的内容是关于DSA算法的,并且以ZIP格式打包。 在压缩包内的文件名称列表中: 1. FGInt.pas:这可能是一个Pascal语言编写的源代码文件,用于处理整数操作,可能是DSA算法的基础数学...

    DSA算法源代码

    本文将详细介绍DSA算法的核心概念及其Java实现。 #### 二、核心概念 1. **DSAGroup**:表示DSA算法中的参数组,包括素数P、素数Q和基G。 - P是一个大素数,一般长度为512位或更长。 - Q是P的一个大素因子,通常...

    DSA黄金版最新数据

    "DSA黄金版最新数据"的标题表明这是一个关于DSA算法的特别版本,可能包含了优化的实现、增强的安全性或者额外的功能。 描述中的“版本219,2012年12月14日更新”揭示了这个软件或库的特定迭代,版本号219意味着这是...

    DSA Tools v13

    **DSA算法的工作原理** DSA算法主要包括三个步骤:签名生成、签名验证和密钥生成。 1. **密钥生成**:DSA首先需要生成一对密钥,即私钥和公钥。私钥由用户保管,不对外公开;公钥则可分享给其他人,用于验证签名。...

    DSA基本原理01031.pdf

    在DSA的基本原理中,首先介绍的是时域与频率域以及傅利叶转换的概念。时域是指信号随时间变化的表达方式,而频率域则是指信号随频率变化的表达方式。傅利叶变换是信号处理的核心工具之一,它允许我们将复杂的信号...

Global site tag (gtag.js) - Google Analytics