python openssl對資料進行簽名

2021-08-31 13:32:24 字數 1874 閱讀 4160

4. php簽名版

在資訊傳遞的過程中為了保證資料是由確定的一方傳送的,需要通過某種方式驗證資料傳送方的身份。目前大家比較常用的可能是是用openssl生成乙個私鑰,然後根據私鑰生成對應的公鑰,這個過程可以通過下述兩個命令完成:

openssl genrsa -out rsa_private_key.pem 1024

openssl rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem

這兩者的工作機制是,通過公鑰加密的資料只能通過對應的私鑰才能解密檢視。而通過私鑰加密的資料如果能被對應的公鑰解開則可斷定資料由該私鑰的所有者傳送。前乙個機制可以用於加密訊息的傳遞,後乙個則可以用於身份的確認,凡事通過公鑰a能解密的資料一定是私鑰a的所有者傳送的資料。

這裡身份確認一般需要經過以下幾個步驟:

先來安裝pyopenssl

$pip install pyopenssl
base64是用python內建的就可以了

#!/usr/bin/env python

# -*- coding:utf-8 -*-

# author:pengjian05

# datetime:2018/11/9 10:41

# software: pycharm

import openssl.crypto as ct

import base64

class

certificate

: _privatekey =

''def

__init__

(self, private_key_content)

: self._privatekey = private_key_content

defget_sig

(self, content)

:"""

生成簽名

/** * 生成簽名

* @param string $content

* @return string|boolean

*/public

function

getsig

($content

)$privatekey

=openssl_pkey_get_private

($this

->

privatekey,''

);if(

$privatekey

)return

false;}

}

提示要安裝Python OpenSSL

pyopenssl是openssl的python介面,用於提供加密傳輸支援 ssl 如果沒用該模組,會導致goagent無法生成證書而影響使用。若系統沒有openssl,先安裝openssl,一般系統都已安裝,可以忽略此步 wget tar zxvf openssl 1.0.1c.tar.gz cd...

解決python openssl版本過低的坎坷路程

valueerror could not unserialize key data問題連線 為了解決這個問題我從端午節google到今天,一直都沒有完整的解決問題。都是wget openssl的壓縮包然後解壓,然後編譯。雖然最後在命令列下面輸入openssl version 能得到正確的安裝版本號但...

對數和指數

參考 這就相當於先發明減法符號,再發明加法符號。1614年,納皮爾發明了對數和對數表。1637年,法國數學家笛卡兒發明了指數,比對數晚了20多年。1770年,尤拉才第乙個指出 對數源於指數 這時對數和指數已經發明一百多年了。我認為造成這個現象的原因有三個 納皮爾首先發現的是大數運算中有對應比例關係,...