2017-01-30 11 views
1

は、私はその兆候提供されるデータ以下のような方法があります:なぜRSA秘密鍵を使ってデータを署名するRSA鍵フォーマットはPythonではサポートされていませんか?

def sign_data(self, private_key_loc, data): 
     """ 
     param: private_key_loc Path to your private key 
     param: package Data to be signed 
     return: base64 encoded signature 
     """ 
     key = open(private_key_loc, "r").read() 
     print(key) 
     rsakey = RSA.importKey(key) # This raise an error!!!! 
     print(rsakey) 
     signer = PKCS1_v1_5.new(rsakey) 
     digest = SHA256.new() 
     # It's being assumed the data is base64 encoded, so it's decoded before updating the digest 
     digest.update(data) 
     sign = signer.sign(digest) 
     return b64encode(sign) 

秘密鍵のフォーマットは以下の通りです:

<RSAKeyValue><Modulus>nEWZmLeK0zgEWysFFcpcT6lnYpzYcXFf+r43wD73ko+CjR5EmwDsmlKqKS5y3rpIHQrj+xE+yiNGlcPFNwFl3cCcHPkeI0hqaPPYxE2XeP6Wa0keegny2AWWK2Cuv61YHVz4XgxTPBX7B/19ClN4wzI5CoNc9jkx0PIXEo5iWLk=</Modulus><Exponent>AQAB</Exponent><P>0b5D6oI3mOKKIHgfCrl03vfUTo91UeJyvpZ1l6F6NzUzPDhCG3Sin5dXtxEFejPayLsgLOIMMuqobOzI9wJpBQ==</P><Q>vrxvorDFE3g1cj2kWWWZc2BS7UMf+xxnPhtBR3x3T/DyTEnkEXvGLdRBuUGWKhxUpRcBkcBfAadJjhYUqYBvJQ==</Q><DP>SKYKiDPKZh4xkcWJmwFZxdE5rGxsSoyRCgq7eGXqGy1GLdmerDveCEE3lKVErGtBoL2QC3vQleJJrFDn2wbusQ==</DP><DQ>sIoTPd8lmd6ygVnCq6fZPywRtV9i03a3rIlng3YVrN1UNv5RZUlN5g9HAeRNzA5K3j8MCc6nYQ1ojGWtnDGvLQ==</DQ><InverseQ>rQzqbkXZ9Tmno3ElcliX57Xv4AXyF6yFO1kH4LHwkc8jN5dB9XYEdBIgm43yHFIznvOdc2L9Nkl2nHbFCeAKmg==</InverseQ><D>XA7IN+XP2zPBpS9HlJmcHbWO2NHK07FVODH8R70QPP9bieRNx/4YY6TU5uOc+cZFGw7CVLHJCm0TdMBaGlgxeC/GTwMrCJigxUgaxbvDmxuSpqYqkjoZhgoZAuUct8RaZUN8zNdEsXCqRhbU61U2Ey587RyPQ7varg9hkPicVHE=</D></RSAKeyValue> 

注:PRIVATE KEYは

TESTの何のためにIS旅行の一番

XMLフォーマットで作成されたようです。エラーは以下のように提起されRSA.importKey(key)ラインで

ValueError: RSA key format is not supported 

は、どのように私は、秘密鍵は、データに署名することを養う必要がありますか?

私もXMLを解析することにより、RSAキーを形成し、以下のような何かをしようとした:

rsakey = Crypto.PublicKey.RSA.construct((root.find('Modulus').text, root.find('Exponent').text,root.find('D').text)) 

それはのようなエラーを与える:

assert isinstance(n, long) 
AssertionError 
+0

あなたはおそらく今、そのキーを処分しなければなりません。 –

+0

公開されたWebサイトに秘密鍵を公開しました。もう貴重なものに使うべきではありません。 –

+0

@JonasWielickiテスト目的です。価値あるもの – ALH

答えて

0

RSAがためにPEMファイル形式を必要としますサインデータ。私の秘密鍵は重要ではなかったので!私はXMLPEM)に変換するオンラインサイトを使用しました。これは本当のプライベートキーではしないでください:|)。今すぐ動作します。

マイPEMファイルは現在、以下の通りです:

-----BEGIN RSA PRIVATE KEY----- 
MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBAJxFmZi3itM4BFsr 
BRXKXE+pZ2Kc2HFxX/q+N8A+95KPgo0eRJsA7JpSqikuct66SB0K4/sRPsojRpXD 
xTcBZd3AnBz5HiNIamjz2MRNl3j+lmtJHnoJ8tgFlitgrr+tWB1c+F4MUzwV+wf9 
fQpTeMMyOQqDXPY5MdDyFxKOYli5AgMBAAECgYBcDsg35c/bM8GlL0eUmZwdtY7Y 
0crTsVU4MfxHvRA8/1uJ5E3H/hhjpNTm45z5xkUbDsJUsckKbRN0wFoaWDF4L8ZP 
AysImKDFSBrFu8ObG5KmpiqSOhmGChkC5Ry3xFplQ3zM10SxcKpGFtTrVTYTLnzt 
HI9Du9quD2GQ+JxUcQJBANG+Q+qCN5jiiiB4Hwq5dN731E6PdVHicr6WdZehejc1 
Mzw4Qht0op+XV7cRBXoz2si7ICziDDLqqGzsyPcCaQUCQQC+vG+isMUTeDVyPaRZ 
ZZlzYFLtQx/7HGc+G0FHfHdP8PJMSeQRe8Yt1EG5QZYqHFSlFwGRwF8Bp0mOFhSp 
gG8lAkBIpgqIM8pmHjGRxYmbAVnF0TmsbGxKjJEKCrt4ZeobLUYt2Z6sO94IQTeU 
pUSsa0GgvZALe9CV4kmsUOfbBu6xAkEAsIoTPd8lmd6ygVnCq6fZPywRtV9i03a3 
rIlng3YVrN1UNv5RZUlN5g9HAeRNzA5K3j8MCc6nYQ1ojGWtnDGvLQJBAK0M6m5F 
2fU5p6NxJXJYl+e17+AF8heshTtZB+Cx8JHPIzeXQfV2BHQSIJuN8hxSM57znXNi 
/TZJdpx2xQngCpo= 
-----END RSA PRIVATE KEY----- 
関連する問題