密码学–数字签名Digital Signature五种分类

密码学–数字签名Digital Signature五种分类

  • 基于数字签名用途的分类
  • 基于数学难题的分类
  • 基于密码体制的分类
  • 基于数字签名安全性的分类
  • 基于签名用户的个数分类

A. 基于数字签名用途的分类

分为常规数字签名和特殊数字签名方法

常规数字签名

建立在公共密钥体制基础上,是公共密钥加密技术的另一种应用,现在已经具有大量数字签名算法,例如

  1. RSA签名
  2. ElGamal 签名
  3. Fiat-Shamir 数字签名算法
  4. Guillou-Quisquarter 数字签名算法
  5. Schnorr 数字签名算法
  6. 美国的数字签名标准算法(DSS/DSA)
  7. 椭圆曲线数字签名算法(Elliptic Curve Digital Signature Algorithm)
  8. 有限自动机数字签名算法
特殊数字签名方法

1. 盲签名(Blind Signature)[1982]
建立在ElGamal 签名方案上签名方案

  • 盲消息签名
  • 盲参数签名
  • 弱盲签名
  • 强盲签名

2. 代理签名(Proxy signature)

  • 一次性代理签名方案
  • 代理多重签名
  • 盲代理签名

3. 群签名(Group signature)[1991]
– 1991年由David Chaum和Eugene van Heyst提出,某个群组内一个成员可以代表群组进行匿名签名,签名可以验证来自于该群组,但是无法准确的追踪到签名的是哪个成员,群签名需要存在一个群管理员来添加新的群成员,因此存在群管理员可能追踪到签名成员身份的危险

4. 多签名(Multi-signture)[1983]
– 多签名机制允许多个签名人对消息进行签名且生成的签名比各个签名人独立签名生成的签名值集合更简短。多签名机制可用于区块链等对多方签名有需求且对签名长度敏感的应用。

5. 聚合签名(Aggregate Signature)
– 聚合签名可以将多个签名压缩为一个签名。聚合签名进一步可分为通用聚合签名如和顺序聚合签名如 等。

5. 环签名(Ring Signature)[2001]
– 由Rivest、Shamir和Tauman三位密码学家在2001年首次提出,
– 简化的群签名。 只有环成员,没有管理员,不需要环成员之前的合作
– 签名者首先选定了一个临时的签名者集合,集合中包括签名者本身。然后卡名这利用自己的私钥和签名集合中其他人的公钥就可以单独的产生签名,无需其他人的帮助。签名者集合中的其他成员可能并不知道自己被包含在其中

6. 广播签名(Broadcast Signature)
7. 不可否认签名(Undeniable Signature)
8. 故障停止式签名(Fail-stop Signature)等

B. 基于数学难题的分类

  1. 基于素因子分解问题 : RSA签名算法
  2. 基于有限域上的离散对数问题的签名方案 : ElGmal签名算法
  3. 基于椭圆曲线上离散对数我呢提的签名方案 : ECDSA签名算法
  4. 基于二次剩余问题的签名方案
  5. 基于格上困难问题的签名方案

C. 基于密码体制的分类

  1. 基于证书的数字签名方案(PKI)
  2. 基于身份的数字签名方案(Id-based)
  3. 基于属性的数字签名方案(Attribute-based)
  4. 基于无证书的数字签名方案(CLS)
  5. 基于多变量的数字签名方案()

D. 基于数字签名安全性的分类

  1. 无条件安全数字签名(Unconditionally Secure)
  2. 计算上安全的数字签名(Computational Security)

F. 基于签名用户的个数分类

  1. 单个用户参与签名的数字签名方案
  2. 多个用户参与签名的数字签名方案(又称为多重数字签名方案)
  • 1
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要在Java中将数字签名添加到PDF,可以使用以下步骤: 1. 安装Bouncy Castle库,它是一个Java密码学库,提供了数字签名和加密等功能。 2. 创建一个KeyStore对象,用于存储数字证书和私钥。 3. 加载证书和私钥到KeyStore对象中。 4. 创建一个PdfReader对象,以便读取PDF文档。 5. 创建PdfStamper对象,以便向PDF文档添加数字签名。 6. 创建PdfSignatureAppearance对象,设置签名的外观,如位置、大小和颜色等。 7. 创建一个Bouncy Castle的实现类,用于数字签名的生成和验证。 8. 生成数字签名,并将其添加到PDF文档中。 以下是一个简单的Java代码示例,用于将数字签名添加到PDF: ``` // 加载Bouncy Castle库 Security.addProvider(new BouncyCastleProvider()); // 创建KeyStore对象 KeyStore ks = KeyStore.getInstance(KeyStore.getDefaultType()); ks.load(new FileInputStream("keystore.jks"), "password".toCharArray()); // 加载证书和私钥 String alias = (String) ks.aliases().nextElement(); PrivateKey key = (PrivateKey) ks.getKey(alias, "password".toCharArray()); Certificate[] chain = ks.getCertificateChain(alias); // 创建PdfReader对象 PdfReader reader = new PdfReader("input.pdf"); // 创建PdfStamper对象 PdfStamper stamper = PdfStamper.createSignature(reader, new FileOutputStream("output.pdf"), '\0', null, true); // 创建PdfSignatureAppearance对象 PdfSignatureAppearance appearance = stamper.getSignatureAppearance(); appearance.setReason("Digital signature"); appearance.setLocation("China"); appearance.setVisibleSignature(new Rectangle(100, 100, 200, 200), 1, "signature"); // 创建Bouncy Castle实现类 ExternalDigest digest = new BouncyCastleDigest(); ExternalSignature signature = new PrivateKeySignature(key, "SHA-256", "BC"); // 生成数字签名 MakeSignature.signDetached(appearance, digest, signature, chain, null, null, null, 0, MakeSignature.CryptoStandard.CMS); // 关闭PdfStamper对象和PdfReader对象 stamper.close(); reader.close(); ``` 请注意,此代码示例仅提供了一种可能的实现方式,具体实现方式可能因不同的应用场景而有所不同。在实际应用中,还需要考虑数字证书的验证、PDF文档的安全性等问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值