我正在开发一个登录teamcity的useragent,我正在尝试将密码加密从js移到c#。
名为rsa.js和encrypt.js的部分很重要。他们用
进行函数调用rsa.setPublic(publicKey,"10001");
指数看起来像十六进制数x10001,据我所知是65537 base10
请注意,以下帐户不属于teamcity的演示网站
此测试验证加密文本是否等于使用公钥加密的明文。
[Test]
public void should_be_able_to_encode_a_string() {
string public_key = "00b46e5cd2f8671ebf2705fd9553137da082b2dd3dbfa06f254cdfeb260fb21bc2c37a882de2924d7dd4c61eb81368216dfea7df718488b000afe7120f3bbbe5b276ac7f2dd52bd28445a9be065bd19dab1f177e0acc035be4c6ccd623c1de7724356f9d6e0b703d01583ebc4467d8454a97928b5c6d0ba3f09f2f8131cc7095d9";
string expected = "1ae1d5b745776f72172b5753665f5df65fc4baec5dd4ea17d43e11d07f10425b3e3164b0c2ba611c72559dc2b00149f4ff5a9649b1d050ca6a5e2ec5d96b787212874ab5790922528a9d7523ab4fe3a002e8f3b66cab6e935ad900805cf1a98dc6fcb5293c7f808917fd9015ba3fea1d59e533f2bdd10471732cccd87eda71b1";
string data = "scott.cowan";
string actual = new EncryptionHelper().Encrypt(public_key, data);
Assert.AreEqual(expected,actual);
}
到目前为止,实现看起来像
public string Encrypt(string public_key, string data)
{
rsa = new RSACryptoServiceProvider();
rsa.FromXmlString(String.Format("<RSAKeyValue>{0}</RSAKeyValue>",public_key));
byte[] plainbytes = System.Text.Encoding.UTF8.GetBytes(data);
byte[] cipherbytes = rsa.Encrypt(plainbytes,false);
return Convert.ToBase64String(cipherbytes);
}
但是抱怨
System.Security.Cryptography.CryptographicException
Message: Input string does not contain a valid encoding of the 'RSA' 'Modulus' parameter.
谢谢你的任何帮助都会让这个圣诞快乐
编辑:看起来我的测试存在缺陷,因为每个播种时间会生成不同的encryptedPassword
答:我打开访客访问权限,绕过了这个问题,但我还是想解决它
答案 0 :(得分:3)
您RSAKeyValue XML格式错误,格式正确 http://www.w3.org/TR/xmldsig-core/#sec-RSAKeyValue
你的函数应该看起来像(假设public_key和exponent是八位字符串......)
public string Encrypt(string public_key,string exponent, string data)
{
RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();
rsa.FromXmlString(String.Format("<RSAKeyValue><Modulus>{0}</Modulus><Exponent>{1}</Exponent></RSAKeyValue>",public_key,exponent));
byte[] plainbytes = System.Text.Encoding.UTF8.GetBytes(data);
byte[] cipherbytes = rsa.Encrypt(plainbytes,false);
return Convert.ToBase64String(cipherbytes);
}
在你的情况下你的指数是10001。
因为在你的情况下看起来你没有八位字符串
public string Encrypt(string public_keyHex,uint exp,string data)
{
byte[] bytes = new byte[public_keyHex.Length / 2];
for (int i = 0; i < public_keyHex.Length-1; i+=2)
{
bytes[i / 2] = byte.Parse(public_keyHex.Substring(i, 2),System.Globalization.NumberStyles.HexNumber);
}
string public_key=Convert.ToBase64String(bytes);
return Encrypt(public_key,Convert.ToBase64String(BitConverter.GetBytes(exp)),data);
}
我希望有帮助,我还没有测试过。我今天回家时会的。
答案 1 :(得分:3)
由于加密使用PKCS#1随机填充,因此生成的“encryptedPassword”必须始终不同。 这里的关键字是“随机填充”; - )