RSA 算法实现

作者: Chunkit_Lau | 来源:发表于2019-06-17 15:26 被阅读0次

密码学基础

密码技术用于保证电子数据的安全性,完整性和真实性。

  1. 保密性:对数据进行加密,使得非法用户无法读懂数据信息,而合法用户可以用密钥读取信息;
  2. 完整性:对数据进行鉴别,已确认是否被非法篡改;
  3. 真实性:保证数据来源的真实性。


    RSA algorithm process.png

加密算法描述

加密算法分成两种,对称加密和非对称加密。

  1. 对称加密:双份都使用共同密钥,不论发送方对信息加密还是接收方对信息解密,都是使用同一个密钥;
    a. 如果这个密钥被非法获取,则加密毫无意义;
    b. 另外,如何传送密钥也是一个难题。
  2. 非对称加密 (RSA): 两把密钥:公开密钥,保密私钥。
    a. 两个成对出现。如果通过公钥加密,则只能通过私钥解密;Vice Versa;

RSA 算法的原理及应用

RSA 的原理

  1. 密钥的产生:
    • 随机选取两个长度相等的大素数:q & p;
    • n = p \times q\ , \ \ t = (p - 1) \times (q - 1),\ \ where \ \ t = \phi(n)
    • 随机在 (0, t) 中取一个数 e, 并且 d \times e \equiv 1 \ mod \ n,继而我们可以得到 d (我们通过拓展欧几里得算法找 d
    • 公钥:(n, d) 密钥:(q, p, e)
  2. 加密算法过程:
    • 已知明文 x, \ x < n,我们可以将 x 分成不同符块 x_i, 使得每个符块 x_i < n。 然后得到密文:C = \sum_{i = 1}^m x_i ^ e \ (mod \ n)
  3. 解密算法实现:
    • 已知密文 C 以及私钥 (n, e),可以计算出明文 x = C^d (mod \ n)
  4. RSA 算法举例:(MATLAB)
clear; clc;
p = 67; q = 71; 
n = p * q; 
t = (p - 1) * (q - 1); 
e = 101; d = 1601;
message = [228, 184, 173];
encrpyted_message = mod(sym(message) .^ e, n);
decrpyted_message = mod(sym(encrpyted_message) .^ d, n);

fprintf('the original message is: %d\n', message)
fprintf('the encrpyted message is: %d\n', encrpyted_message)
fprintf('the decrpyted message is: %d\n', decrpyted_message)

相关文章

  • RSA算法原理(作者: 阮一峰)

    RSA算法原理(一) RSA算法原理(二) RSA C算法实现【 看雪安全论坛】

  • 计算机安全学-第四次实践作业-2018/4/17

    [new] 1、用Python或Sage实现RSA算法的加密、解密、签名/验证签名使用sage实现RSA算法进行加...

  • RSA非对称加解密原理及示例代码

    RSA非对称加解密可以实现安全传输,本文简单介绍一下其原理和实现代码 RSA加密算法 RSA加密算法是一种非对称加...

  • RSA加密算法(java版)

    算法简介 RSA加密算法是一种非对称加密算法,在公开密钥加密和电子商业中RSA被广泛使用。 算法实现 1、RSAU...

  • RSA算法实现

    1 非对称加密算法 (1)乙方生成两把密钥(公钥和私钥)。公钥是公开的,任何人都可以获得,私钥则是保密的。(2)甲...

  • RSA 算法实现

    密码学基础 密码技术用于保证电子数据的安全性,完整性和真实性。 保密性:对数据进行加密,使得非法用户无法读懂数据信...

  • JAVA加解密16-非对称加密算法-RSA算法

    一、概述1.RSA是基于大数因子分解难题。目前各种主流计算机语言都支持RSA算法的实现2.java6支持RSA算法...

  • # RSA 公钥加密算法

    # RSA 公钥加密算法 # RSA 公钥加密算法

  • RSA加密

    RSA加密为非对称加密实现 对称加密:加密解密使用同一个算法 非对称加密:加密和解密使用不同算法 rsa加密原理 ...

  • 6.1 密码学专题 - 非对称加密算法 - RSA 算法

    密码学专题 - 非对称加密算法 - RSA 算法 6.1 RSA 算法 第一个较完善的非对称加密算法 RSA,它既...

网友评论

    本文标题:RSA 算法实现

    本文链接:https://www.haomeiwen.com/subject/dpuafctx.html