Estou tentando "decodificar" esta seguinte seqüência Base64:
OBFZDTcPCxlCKhdXCQ0kMQhKPh9uIgYIAQxALBtZAwUeOzcdcUEeW0dMO1kbPElWCV1ISFFKZ0kdWFlLAURPZhEFQVseXVtPOUUICVhMAzcfZ14AVEdIVVgfAUIBWVpOUlAeaUVMXFlKIy9rGUN0VF08Oz1POxFfTCcVFw1LMQNbBQYWAQ ==
Isto é o que eu sei sobre a própria string:
A cadeia original é passada primeiro pelo seguinte código:
private static string m000493(string p0, string p1) { StringBuilder builder = new StringBuilder(p0); StringBuilder builder2 = new StringBuilder(p1); StringBuilder builder3 = new StringBuilder(p0.Length); int num = 0; Label_0084: while (num < builder.Length) { int num2 = 0; while (num2 < p1.Length) { if ((num == builder.Length) || (num2 == builder2.Length)) { MessageBox.Show("EH?"); goto Label_0084; } char ch = builder[num]; char ch2 = builder2[num2]; ch = (char)(ch ^ ch2); builder3.Append(ch); num2++; num++; } } return m0001cd(builder3.ToString()); }
A
p1
parte do código deve ser a sequência "_p0lizei.
".Em seguida, é convertido em uma seqüência de caracteres Base64 pelo seguinte código:
private static string m0001cd(string p0) { string str2; try { byte[] buffer = new byte[p0.Length]; str2 = Convert.ToBase64String(Encoding.UTF8.GetBytes(p0)); } catch (Exception exception) { throw new Exception("Error in base64Encode" + exception.Message); } return str2; }
A questão é: como decodificar a string Base64 para descobrir qual é a string original?
Respostas:
Simples:
fonte
O
m000493
método parece executar algum tipo de criptografia XOR. Isso significa que o mesmo método pode ser usado para criptografar e descriptografar o texto. Tudo o que você precisa fazer é reverterm0001cd
:com
return m0001cd(builder3.ToString());
alterado parareturn builder3.ToString();
.fonte