RSA加密

RSA加密为非对称加密实现

  • 对称加密:加密解密使用同一个算法
  • 非对称加密:加密和解密使用不同算法

rsa加密原理

  • 应用原理:明文(公钥加密) --> 密文 --> 明文(私钥解密)


    rsa工作过程

简单来说描述如下

  1. 服务器生成公钥+私钥,将公钥给到客户端
    2.客服端 【明文--> 公钥加密 -->密文】 ==> 【服务器】
    3.服务器 【密文--> 私钥解密 -->明文】
  • 数学原理
    关于底层的算法实现涉及到一系列的数学转换步骤,这里简单列举

1.欧拉定理:m^Φ(n) % n ≡ 1
2.费小马定理:m^(n-1) % n ≡ 1

  1. 由1、2经过一顿神操作:m^(e*d) % n = m
    该公式就是rsa基础,至于怎么来的感兴趣的可以去看看密码学相关书籍
    将3中的公式分解可得到欧拉加密解密算法
    rsa加密:m^e % n = c, rsa解密:c^d % n = m

所以
1)m^e % n = c 可以看出是公钥算法(用于加密)
2)c^d % n = m 可以看出是秘钥算法(用于解密)
2)中间变量 “c” 可以看出是密文
这个过程就是rsa算法的基础

生成rsa公钥、秘钥、证书等

这里以MacOSX为例,描述rsa算法的使用过程
OpenSSL是操作rsa相关算法的一个应用,在MacOSX环境下可以直接使用

OpenSSL 常用工具,Mac自带OpenSSL,打开终端直接进行rsa相关操作
genrsa:生成并输入rsa私钥
rsautl:使用rsa秘钥进行加密、解密、签名和验证运算等操作
rsa:处理rsa秘钥的格式转换等

  1. 生成rsa秘钥(数字可选:512、1024、2048,越大越难破解,但是过大导致加解密过程很慢,一搬使用1024,以目前计算的硬件性能基本不可能破解)
 openssl genrsa -out private.pem 1024

2.从私钥中提取公钥

 openssl rsa -in private.pem -pubout -out public.pem

3.将私钥转换成明文

 openssl rsa -in private.pem -text -out private.txt

此处可以使用cat查看文本信息:cat private.txt

4.公钥加密数据

1)生成明文文件:
vi message.txt
2)查看文件内容:
cat message.txt
3)公钥加密:
openssl rsautl -encrypt -in message.txt -inkey public.pem -pubin -out enc.txt
4)私钥解密:
openssl rsautl -decrypt -in enc.txt -inkey private.pem -out dec.txt

也可以通过私钥加密、公钥解密

3)私钥加密:
openssl rsautl -sign -in message.txt -inkey private.pem -out enc.txt
4)公钥解密:
openssl rsautl -verify -in enc.txt -inkey public.pem -pubin -out dec.txt

5.生成证书,由于公钥私钥文件在代码中不直接使用,而是使用证书方式

1)生成证书请求文件:
openssl req -new -key private.pem -out rsacert.csr
依次输入:国家名(cn)、省份名、机构名(xx.inc) ..密码,邮箱等
2) 用该请求文件去证书颁发机构(rsa认证机构)请求证书:
openssl x509 -req -days 3650 -in  rsacert.csr -signkey private.pem -out rsacert.crt
该过程其实是一个认证过程,相当于让该机构“盖个章”
  1. 提取证书供代码使用

通常在代码中会使用公钥文件.der 和私钥文件 .p12
可通过以下命令直接导出

提取公钥文件der:
openssl x509 -outform der -in rsacert.crt -out rsacert.der
提取私钥文件p12(可设置密码):
openssl pkcs12 -export -out p.p12 -inkey private.pem -in rsacert.crt 
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,053评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,527评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,779评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,685评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,699评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,609评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,989评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,654评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,890评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,634评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,716评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,394评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,976评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,950评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,191评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,849评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,458评论 2 342

推荐阅读更多精彩内容