2016-09-28 47 views
0

私は、ecryptedデータをサービスに送るために、C#プロジェクトでRSA暗号を使用する必要があります。 サービスは、私にこのような公開鍵与えた:私はこのコードで使用するbase64文字列に変換するにはどうすればよいRSA公開鍵への公開鍵c#

-----BEGIN PUBLIC KEY----- 
MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAjU/bq6YZD2H0DUhbtEBg 
JIyiurM8eX3aH02/ZWr6VZ27WF93ylWC4cGAe50sSgiA8NCW0G/UL77kAkebJQrJ 
jVdt7SvDypSPk1mXNK0i9cI9DrdmAHLGLlYJx7eeY6h4JShLhOBnKRghi0S4uL5N 
L7W4OUgCeUlGWcmz8ssNEQ5w17rfUF9TxYEFVKFMGN/SSaYNUr4znGt2r97YPsPy 
0Sk4dGHhMXr1QGR05UQeVuU43OuRAFxA71YbuCRUYg5ENwKM/1RnNcu8v7kXFA4L 
qGV9AncHLIZEOqWgY+4balVXlKIcMVN6W+PXKJpowOyB9QIq1Ec3OMaJ3sGpOppx 
KQIDAQAB 
-----END PUBLIC KEY----- 

を?私は解決策を見つけた

public static string EncryptData(string publicKey, string clearText) 
{ 
    IBuffer keyBuffer = CryptographicBuffer.DecodeFromBase64String(publicKey); 
    AsymmetricKeyAlgorithmProvider asym = AsymmetricKeyAlgorithmProvider.OpenAlgorithm(AsymmetricAlgorithmNames.RsaPkcs1); 
    CryptographicKey key = asym.ImportPublicKey(keyBuffer, CryptographicPublicKeyBlobType.Capi1PublicKey); 
    IBuffer plainBuffer = CryptographicBuffer.ConvertStringToBinary(clearText, BinaryStringEncoding.Utf8); 
    IBuffer encryptedBuffer = CryptographicEngine.Encrypt(key, plainBuffer, null); 
    byte[] encryptedBytes; 
    CryptographicBuffer.CopyToByteArray(encryptedBuffer, out encryptedBytes); 
    return Convert.ToBase64String(encryptedBytes); 
} 
+0

の可能性のある重複します。http([C#/。NET暗号のBase64を使用したRSA署名を検証するための公開鍵をエンコード]: //stackoverflow.com/questions/9283716/c-sharp-net-crypto-using-base64-encoded-public-key-to-verify-rsa-signature) –

答えて

0

、それは簡単だった:私が使用する必要が :

CryptographicKey key = asym.ImportPublicKey(keyBuffer, CryptographicPublicKeyBlobType.X509SubjectPublicKeyInfo);