ここで、秘密鍵を使用して文字列を解読しようとすると、次のようなエラーが発生します。
入力は有効な Base-64 文字列ではありません。非 Base 64 文字、3 つ以上の埋め込み文字、または埋め込み文字の間に非空白文字が含まれているためです。
私が解読しようとしている文字列(つまり、文字列authenticationString)は次のとおりです。
Z7W7ja7G+NB3+QsbNnsz7zCkt1xeZ1PQC606wZzQG2McjExT6WjFPDWNpVSqcw1X+K6TERZUK4677m5Z6x9TuxLxyA8h8LmB4dwcJsQZGoVg0mOLsxO6GZmdThLyQOxQgnA7sk4KHLv6DrVswtVzjM/gJouvDKHTC7+NZmjhWwA=
私のコードは次のとおりです。
internal virtual Credentials Extract(string basicAuthenticationCredentials)
{
string authenticationString = RemoveBasicFromAuthenticationString(basicAuthenticationCredentials);
string privateKeyPath = @"D:\Bala\MVC\RestService\RestClient\Scripts\PrivateKey.xml";
myRsa.LoadPrivateFromXml(privateKeyPath); // Loading the Private key
RSACryptoServiceProvider localRsa = new RSACryptoServiceProvider();
localRsa.FromXmlString(File.ReadAllText(privateKeyPath));
byte[] decMessage = Convert.FromBase64String(authenticationString);
byte[] message = null;
// Calling the right decryption method according to the user selection
message = myRsa.PrivateDecryption(decMessage);
string au = Encoding.UTF8.GetString(message);
return extractor.Extract(decoder.Decode(au));
}
文字列au
では、次のような値を取得しています。
d��!���u�I|�3��iaȴ{ȱ��q��A��z��ta �i8?�-�[�#�*&��Y^l,�v ������ā�\�f�$R�V����&g;�</p>
特定のユーザー名パスワードに対してのみこのエラーが発生しています。他は正常に動作しています。なにか提案を?
編集:この行でエラーがスローされています byte[] decodedStringInBytes = Convert.FromBase64String(encodedValue);
internal virtual string Decode(string encodedValue)
{
byte[] decodedStringInBytes = Convert.FromBase64String(encodedValue);
return Encoding.ASCII.GetString(decodedStringInBytes);
}
編集2:
internal class DecodedCredentialsExtractor
{
internal virtual Credentials Extract(string credentials)
{
if (!string.IsNullOrEmpty(credentials))
{
string[] credentialTokens = credentials.Split(':');
//string securityToken = string.Empty;
if (credentialTokens.Length == 2)
{
return new Credentials(credentialTokens[0], credentialTokens[1]);
}
}
throw new ArgumentException("The supplied credential string is invalid, it should comply to [username:password]", "credentials");
}
}