北半球的孤单 發表於 2019-8-24 15:46:00

python实现RSA加密和签名以及分段加解密的方案

<h1 class="md-end-block md-heading"><span class="md-plain">1、前言</span></h1>
<p class="md-end-block md-p md-focus"><span class="md-tab"> <span class="md-plain md-expand">很多朋友在工作中,会遇到一些接口使用RSA加密和签名来处理的请求参数,那么遇到这个问题的时候,第一时间当然是找开发要加解密的方法,但是开发给加解密代码,大多数情况都是java,c++,js等语言实现的,加解密的代码虽然有了,但是咱们身为一个测试,使用python做的自动化,并不是什么语言都会,这个时候就会比较尴尬了,看着这一团加解密的代码,自己却不知从何下手,再去找开发给写个python版本的,开发估计不一定搭理你,就算搭理你,开发也未必会python,那么今天咱们就来讲讲如何通过python来实现RSA加解密和签名</span></span></p>
<p class="md-end-block md-p md-focus"><span class="md-tab"><span class="md-plain md-expand"><img src="https://img2018.cnblogs.com/blog/1639980/201908/1639980-20190824153957816-1270959658.png"></span></span></p>
<p class="md-end-block md-p"><span class="md-image md-img-loaded" data-src="C:%5C%E8%AF%BE%E4%BB%B6%5Cimages%5C1565083714493.png"><img src="C:%5C%E8%AF%BE%E4%BB%B6%5Cimages%5C1565247640520.png"><img alt=""></span></p>
<h2 class="md-end-block md-heading"><span class="md-plain"><img alt="" data-src="https://img2018.cnblogs.com/blog/1639980/201908/1639980-20190824154024098-1347669577.png"></span></h2>
<h2 class="md-end-block md-heading"><span class="md-plain">3、python实现RSA加解密和签名加解签</span></h2>
<p class="md-end-block md-p"><span class="md-plain">接下来我们就来使用python来实现RSA加密与签名,使用的第三方库是Crypto具体实现的代码如下:</span></p>
<h3 class="md-end-block md-heading"><span class="md-plain">1、生成秘钥对</span></h3>
<p class="md-end-block md-p"><span class="md-plain">在这边为了方面演示,手动生成一个密钥对(项目中的秘钥对由开发来生成,会直接给到我们)</span></p>
<p class="md-end-block md-p"><span class="md-plain"> 生成秘钥对的时候,可以指定生成秘钥的长度,一般推荐使用1024bit, 1024bit的rsa公钥,加密数据时,最多只能加密117byte的数据),数据量超过这个数,则需要对数据进行分段加密,但是目前1024bit长度的秘钥已经被证明了不够安全,尽量使用2048bit长度的秘钥。2048bit长度的秘钥,最多245byte长度的数据</span></p>
<p class="md-end-block md-p"><span class="md-plain">计算公式如下:</span></p>
<div id="mathjax-n22" class="mathjax-block md-end-block md-math-block md-rawblock">
<div class="md-rawblock-container md-math-container">
<div class="MathJax_SVG_Display"><span id="MathJax-Element-1-Frame" class="MathJax_SVG">秘钥长度最大加密量(单位:)</span></div>
</div>
</div>
<p class="md-end-block md-p"><span class="md-plain">下面生成一对1024bit的秘钥</span></p>
<div class="cnblogs_code">
<pre><span style="color: rgba(0, 0, 255, 1)">from</span> Crypto <span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> Random
</span><span style="color: rgba(0, 0, 255, 1)">from</span> Crypto.PublicKey <span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> RSA

</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 伪随机数生成器</span>
random_gen =<span style="color: rgba(0, 0, 0, 1)"> Random.new().read

</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 生成秘钥对实例对象:1024是秘钥的长度</span>
rsa = RSA.generate(1024<span style="color: rgba(0, 0, 0, 1)">, random_gen)

</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 获取公钥,保存到文件</span>
private_pem =<span style="color: rgba(0, 0, 0, 1)"> rsa.exportKey()
with open(</span><span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(128, 0, 0, 1)">private.pem</span><span style="color: rgba(128, 0, 0, 1)">'</span>, <span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(128, 0, 0, 1)">wb</span><span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(0, 0, 0, 1)">) as f:
    f.write(private_pem)

</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 获取私钥保存到文件</span>
public_pem =<span style="color: rgba(0, 0, 0, 1)"> rsa.publickey().exportKey()
with open(</span><span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(128, 0, 0, 1)">public.pem</span><span style="color: rgba(128, 0, 0, 1)">'</span>, <span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(128, 0, 0, 1)">wb</span><span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(0, 0, 0, 1)">) as f:
    f.write(public_pem)</span></pre>
</div>
<p>&nbsp;</p>
<h5 class="md-end-block md-heading"><span class="md-plain">公钥格式:</span></h5>
<p><span class="md-plain"><img src="https://img2018.cnblogs.com/blog/1639980/201908/1639980-20190824154052441-209622743.png"></span></p>
<p class="md-end-block md-p"><span class="md-image md-img-loaded" data-src="C:%5C%E8%AF%BE%E4%BB%B6%5Cimages%5C1565250571688.png"><img src="https://img2018.cnblogs.com/blog/1639980/201908/1639980-20190824154111823-1308340980.png"></span></p>
<p class="md-end-block md-p"><span class="md-image md-img-loaded" data-src="C:%5C%E8%AF%BE%E4%BB%B6%5Cimages%5C1565250603868.png"><img alt=""></span></p>
<h3 class="md-end-block md-heading"><span class="md-plain">2、加密与解密</span></h3>
<h5 class="md-end-block md-heading"><span class="md-plain">1、公钥加密</span></h5>
<div class="cnblogs_code">
<pre><span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> base64
</span><span style="color: rgba(0, 0, 255, 1)">from</span> Crypto.PublicKey <span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> RSA
</span><span style="color: rgba(0, 0, 255, 1)">from</span> Crypto.Cipher <span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> PKCS1_v1_5


msg </span>= <span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">待加密明文内容</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">

</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 读取文件中的公钥</span>
key = open(<span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(128, 0, 0, 1)">public.pem</span><span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(0, 0, 0, 1)">).read()
publickey </span>=<span style="color: rgba(0, 0, 0, 1)"> RSA.importKey(key)
</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 进行加密</span>
pk =<span style="color: rgba(0, 0, 0, 1)"> PKCS1_v1_5.new(publickey)
encrypt_text </span>=<span style="color: rgba(0, 0, 0, 1)"> pk.encrypt(msg.encode())
</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 加密通过base64进行编码</span>
result =<span style="color: rgba(0, 0, 0, 1)"> base64.b64encode(encrypt_text)
</span><span style="color: rgba(0, 0, 255, 1)">print</span>(result)</pre>
</div>
<p>&nbsp;</p>
<h5 class="md-end-block md-heading"><span class="md-plain">2、私钥解密</span></h5>
<div class="cnblogs_code">
<pre><span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> base64
</span><span style="color: rgba(0, 0, 255, 1)">from</span> Crypto.PublicKey <span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> RSA
</span><span style="color: rgba(0, 0, 255, 1)">from</span> Crypto.Cipher <span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> PKCS1_v1_5
</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 密文</span>
msg=<span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(128, 0, 0, 1)">bAlnUNEJeDLnWikQs1ejwqPTo4qZ7RWxgFwoO4Bfg3C7EY+1HN5UvJYJ2h6047K6vNjG+TiIxc0udTR7a12MivSA+DwoGjwFIb25u3zc+M8KTCaCT5GdSumDOto2tsKYaVDKCPZpdwYdzYwlVijr6cPcchQTlD1yfKk2khhNchU=</span><span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(0, 0, 0, 1)">

</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> base64解码</span>
msg =<span style="color: rgba(0, 0, 0, 1)"> base64.b64decode(msg)
</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 获取私钥</span>
privatekey = open(<span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(128, 0, 0, 1)">private.pem</span><span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(0, 0, 0, 1)">).read()
rsakey </span>=<span style="color: rgba(0, 0, 0, 1)"> RSA.importKey(privatekey)
</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 进行解密</span>
cipher =<span style="color: rgba(0, 0, 0, 1)"> PKCS1_v1_5.new(rsakey)
text </span>= cipher.decrypt(msg, <span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(128, 0, 0, 1)">DecryptError</span><span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(0, 0, 0, 1)">)
</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 解密出来的是字节码格式,decodee转换为字符串</span>
<span style="color: rgba(0, 0, 255, 1)">print</span>(text.decode())</pre>
</div>
<p>&nbsp;</p>
<h5 class="md-end-block md-heading"><span class="md-plain">3、分段加密和解密</span></h5>
<p class="md-end-block md-p"><span class="md-tab"> <span class="md-plain">上面生成秘钥的时候提到过在我们加密的时候,如果数据长度超过了当前秘钥的所能处理最大长度,则需要进行分段加密,</span></span></p>
<h6 class="md-end-block md-heading"><span class="md-plain">分段加密:通俗易懂的讲就是把原来一长串的数据,分割成多段,每段的大小控制在秘钥的最大加密数量之内,加密完了之后再把数据进行拼接。</span></h6>
<h6 class="md-end-block md-heading"><span class="md-plain">分段解密:经过分段加密的数据,在进行解密的时候我们也要将它进行分成多段,然后解密之后再进行拼接就能得到原来的数据内容。</span></h6>
<p class="md-end-block md-p"><span class="md-plain">分段加密和解密的代码如下:</span></p>
<div class="cnblogs_code">
<pre><span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> base64
</span><span style="color: rgba(0, 0, 255, 1)">from</span> Crypto.PublicKey <span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> RSA
</span><span style="color: rgba(0, 0, 255, 1)">from</span> Crypto.Cipher <span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> PKCS1_v1_5



</span><span style="color: rgba(0, 0, 255, 1)">def</span><span style="color: rgba(0, 0, 0, 1)"> cipher(msg):
    </span><span style="color: rgba(128, 0, 0, 1)">"""</span><span style="color: rgba(128, 0, 0, 1)">
    公钥加密
    :param msg: 要加密内容
    :return:加密之后的密文
    </span><span style="color: rgba(128, 0, 0, 1)">"""</span>
    <span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 获取公钥</span>
    key = open(<span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(128, 0, 0, 1)">public.pem</span><span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(0, 0, 0, 1)">).read()
    publickey </span>=<span style="color: rgba(0, 0, 0, 1)"> RSA.importKey(key)
    </span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 分段加密</span>
    pk =<span style="color: rgba(0, 0, 0, 1)"> PKCS1_v1_5.new(publickey)
    encrypt_text </span>=<span style="color: rgba(0, 0, 0, 1)"> []
    </span><span style="color: rgba(0, 0, 255, 1)">for</span> i <span style="color: rgba(0, 0, 255, 1)">in</span> range(0,len(msg),100<span style="color: rgba(0, 0, 0, 1)">):
      cont </span>= msg
      encrypt_text.append(pk.encrypt(cont.encode()))
    </span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 加密完进行拼接</span>
    cipher_text = b<span style="color: rgba(128, 0, 0, 1)">''</span><span style="color: rgba(0, 0, 0, 1)">.join(encrypt_text)
    </span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> base64进行编码</span>
    result =<span style="color: rgba(0, 0, 0, 1)"> base64.b64encode(cipher_text)
    </span><span style="color: rgba(0, 0, 255, 1)">return</span><span style="color: rgba(0, 0, 0, 1)"> result.decode()


</span><span style="color: rgba(0, 0, 255, 1)">def</span><span style="color: rgba(0, 0, 0, 1)"> decrypt(msg):
    </span><span style="color: rgba(128, 0, 0, 1)">"""</span><span style="color: rgba(128, 0, 0, 1)">
    私钥进行解密
    :param msg: 密文:字符串类型
    :return:解密之后的内容
    </span><span style="color: rgba(128, 0, 0, 1)">"""</span>
    <span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> base64解码</span>
    msg =<span style="color: rgba(0, 0, 0, 1)"> base64.b64decode(msg)
    </span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 获取私钥</span>
    privatekey = open(<span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(128, 0, 0, 1)">private.pem</span><span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(0, 0, 0, 1)">).read()
    rsakey </span>=<span style="color: rgba(0, 0, 0, 1)"> RSA.importKey(privatekey)
    cipher </span>=<span style="color: rgba(0, 0, 0, 1)">PKCS1_v1_5.new(rsakey)
    </span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 进行解密</span>
    text =<span style="color: rgba(0, 0, 0, 1)"> []
    </span><span style="color: rgba(0, 0, 255, 1)">for</span> i <span style="color: rgba(0, 0, 255, 1)">in</span> range(0,len(msg),128<span style="color: rgba(0, 0, 0, 1)">):
      cont </span>= msg
      text.append(cipher.decrypt(cont,</span>1<span style="color: rgba(0, 0, 0, 1)">))
    text </span>= b<span style="color: rgba(128, 0, 0, 1)">''</span><span style="color: rgba(0, 0, 0, 1)">.join(text)
    </span><span style="color: rgba(0, 0, 255, 1)">return</span> text.decode()</pre>
</div>
<h3 class="md-end-block md-heading"><span class="md-plain">3、签名和验签</span></h3>
<h5 class="md-end-block md-heading"><span class="md-plain">1、私钥签名</span></h5>
<div class="cnblogs_code">
<pre><span style="color: rgba(0, 0, 255, 1)">from</span> Crypto.Hash <span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> SHA
</span><span style="color: rgba(0, 0, 255, 1)">from</span> Crypto.Signature <span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> PKCS1_v1_5 as Sig_pk
</span><span style="color: rgba(0, 0, 255, 1)">from</span> Crypto.PublicKey <span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> RSA
</span><span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> base64

</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 待签名内容</span>
name = <span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">musen</span><span style="color: rgba(128, 0, 0, 1)">"</span>
<span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 获取私钥</span>
key = open(<span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(128, 0, 0, 1)">private.pem</span><span style="color: rgba(128, 0, 0, 1)">'</span>, <span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(128, 0, 0, 1)">r</span><span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(0, 0, 0, 1)">).read()
rsakey </span>=<span style="color: rgba(0, 0, 0, 1)"> RSA.importKey(key)
</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 根据sha算法处理签名内容(此处的hash算法不一定是sha,看开发)</span>
data =<span style="color: rgba(0, 0, 0, 1)"> SHA.new(name.encode())
</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 私钥进行签名</span>
sig_pk =<span style="color: rgba(0, 0, 0, 1)"> Sig_pk.new(rsakey)
sign </span>=<span style="color: rgba(0, 0, 0, 1)"> sig_pk.sign(data)
</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 将签名后的内容,转换为base64编码</span>
result =<span style="color: rgba(0, 0, 0, 1)"> base64.b64encode(sign)
</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 签名结果转换成字符串</span>
data =<span style="color: rgba(0, 0, 0, 1)"> result.decode()
</span><span style="color: rgba(0, 0, 255, 1)">print</span>(data)</pre>
</div>
<p>&nbsp;</p>
<h5 class="md-end-block md-heading"><span class="md-plain">2、公钥验签</span></h5>
<div class="cnblogs_code">
<pre><span style="color: rgba(0, 0, 255, 1)">from</span> Crypto.Hash <span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> SHA
</span><span style="color: rgba(0, 0, 255, 1)">from</span> Crypto.Signature <span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> PKCS1_v1_5 as Sig_pk
</span><span style="color: rgba(0, 0, 255, 1)">from</span> Crypto.PublicKey <span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> RSA
</span><span style="color: rgba(0, 0, 255, 1)">import</span><span style="color: rgba(0, 0, 0, 1)"> base64


</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 签名之前的内容</span>
name = <span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">musen</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">

</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 签名数据</span>
data=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">X3Gg+wd7UDh4X8ra+PGCyZFUrG+6jDeQt6ajMA0EjwoDwxlddLzYoS4dtjQ2q5WCcRhxcp8fjEyoPXBmJE9rMKDjEIeE/VO0sskbJiO65fU8hgcqdWdgbVqRryhOw+Kih+I6RIeNRYnOB8GkGD8Qca+n9JlOELcxLRdLo3vx6dw=</span><span style="color: rgba(128, 0, 0, 1)">"</span>
<span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> base64解码</span>
data =<span style="color: rgba(0, 0, 0, 1)"> base64.b64decode(data)
</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 获取公钥</span>
key = open(<span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(128, 0, 0, 1)">public.pem</span><span style="color: rgba(128, 0, 0, 1)">'</span><span style="color: rgba(0, 0, 0, 1)">).read()
rsakey </span>=<span style="color: rgba(0, 0, 0, 1)"> RSA.importKey(key)
</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 将签名之前的内容进行hash处理</span>
sha_name =<span style="color: rgba(0, 0, 0, 1)"> SHA.new(name.encode())
</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 验证签名</span>
signer =<span style="color: rgba(0, 0, 0, 1)"> Sig_pk.new(rsakey)
result </span>=<span style="color: rgba(0, 0, 0, 1)"> signer.verify(sha_name, data)
</span><span style="color: rgba(0, 128, 0, 1)">#</span><span style="color: rgba(0, 128, 0, 1)"> 验证通过返回True   不通过返回False</span>
<span style="color: rgba(0, 0, 255, 1)">print</span>(result)</pre>
</div>
<p>&nbsp;</p>
<pre class="md-fences md-end-block ty-contain-cm modeLoaded"><span><span class="cm-keyword"><span class="cm-variable"><span class="cm-property"><span class="cm-keyword"><span class="cm-variable"><span><span class="cm-keyword"><span class="cm-variable"><span class="cm-property"><span class="cm-keyword"><span class="cm-variable"><span class="cm-keyword"><span class="cm-variable"><span><span class="cm-keyword"><span class="cm-variable"><span class="cm-property"><span class="cm-keyword"><span class="cm-variable"><span><span class="cm-keyword"><span class="cm-variable"><span><span><span><span><span><span class="cm-comment"><span><span class="cm-variable"><span class="cm-string"><span><span><span><span class="cm-comment"><span><span class="cm-variable"><span class="cm-string"><span><span class="cm-comment"><span><span class="cm-variable"><span class="cm-variable"><span class="cm-property"><span class="cm-variable"><span><span class="cm-comment"><span><span class="cm-variable"><span class="cm-builtin"><span class="cm-string"><span class="cm-property"><span><span class="cm-variable"><span class="cm-variable"><span class="cm-property"><span class="cm-variable"><span><span class="cm-comment"><span><span class="cm-variable"><span class="cm-variable"><span class="cm-property"><span class="cm-variable"><span class="cm-property"><span><span class="cm-comment"><span><span class="cm-variable"><span class="cm-variable"><span class="cm-property"><span class="cm-variable"><span><span class="cm-variable"><span class="cm-variable"><span class="cm-property"><span class="cm-variable"><span class="cm-variable"><span><span class="cm-comment"><span><span class="cm-builtin"><span class="cm-variable"><span><span><span><span>&nbsp;</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></pre>

</div>
<div id="MySignature" role="contentinfo">
    <font color="red">=====请大家尊重原创,如要转载,请注明出处:转载自:https://www.cnblogs.com/nmb-musen/,谢谢!!===== </font><br>
<li><font color="red">=====有任何疑问,欢迎加微信 MoX66999(请备注:博客园-木森)=====</font></li><br><br><br>
来源:https://www.cnblogs.com/nmb-musen/p/11404889.html
頁: [1]
查看完整版本: python实现RSA加密和签名以及分段加解密的方案