Dicas e Tutoriais - MySQL

Lendo dados criptografados no MySQL


Agora vou falar sobre um problema comum, que é quando tentamos ler, no ASP.Net, um campo criptografado com a função AES_ENCRYPT do MySQL.
Como essa função transforma a string enviada em um dado binário, a leitura dos dados pode retornar algo ilegível ou apenas identificado como um vetor de bytes. Portanto, se o retorno do seu DataReader ou seu DataSet é System.Byte[], saiba que o motivo é esse, mas a solução é simples.
Vejam esse trecho de código:


String strComando = "SELECT AES_DECRYPT(senha, '" + chave + "') as senha FROM clientes
WHERE email like '" + strEmailUsuario + "'";

MySqlConnectionminhaConexao = new MySqlConnection(strStringConexao);
MySqlCommandmeuComando = new MySqlCommand(strComando, minhaConexao);
minhaConexao.Open();
MySqlDataReaderdr;

dr = meuComando.ExecuteReader();
String strSenha;

try
{
while (dr.Read())
{
strSenha = dr.GetString("senha");
}
}
finally
{
minhaConexao.Close();
}


O método GetString consegue identificar e retornar o conteúdo correto, ou seja, a string contida no campo criptografado.
Claro que para isso o comando AES_DECRYPT precisa ter a sintaxe correta e a chave de criptografia precisa ser a mesma usada no momento de gravação do dado no banco. Caso não tenha ficado claro, crie algo como:

DataSetds = newDataSet();
strSenha= ds.Tables[0].Rows[0]["senha"].ToString();

Você verá que o retorno não será a String, mas apenas System.Byte[].
Ou seja, se vai ler algo gravado num campo criptografado, use o bom e velho GetString().



Gostou desta dica? Compartilhe-a em suas redes sociais!

Você sabia?
Você Sabia?

O famoso título Final Fantasy, da Square Enix, tem este nome exatamente porque se tratava da última esperança da empresa, que estava à beira da falência quando o lançou. Clique aqui e conheça detalhes dessa história.

Você Sabia?

O primeiro computador a conseguir rodar o jogo Spacewar era o PDP-1, que custava 120 mil dólares e pertencia ao Massachusetts Institute of Technology. O jogo demorou 200 horas para ser desenvolvido, em 1962, e seu criador foi um cientista da computação chamado Steve Russel.

Algumas notícias

Como conversar com alguém no WhatsApp sem adicionar o número aos contatos

Como conversar com alguém no WhatsApp sem adicionar o número aos contatos

Este processo pode, à primeira vista, parecer um pouco confuso para usuários que não são muito experientes usando seu smartphone. Mas uma vez que você conclua o processo , vai entender o método e parecerá mais fácil. 1. Abra o seu navegador preferido no seu smartphone e digite o seguinte link na...

Ler Notícia Completa

O que acontece com o cérebro no exato momento em que morremos

O que acontece com o cérebro no exato momento em que morremos

O que passa em nossa cabeça no momento da morte? Não se sabe exatamente e, embora os cientistas tenham alguma resposta, a resposta continua sendo um grande mistério. Além de difícil solução, tentar respondê-la pode criar implicações éticas. No entanto, uma equipe de cientistas da Universidade...

Ler Notícia Completa

Operada e devolvida ao útero, menina que nasceu duas vezes hoje 'acorda sorrindo toda manhã'

Operada e devolvida ao útero, menina que nasceu duas vezes hoje 'acorda sorrindo toda manhã'

Um bebê pode nascer duas vezes? Não é o caso da absoluta maioria das crianças, mas foi assim para a pequena Lynlee Boemer. Em outubro de 2015, sua mãe, Margaret Boemer, descobriu que estava grávida de gêmeos. Ela sofreu um aborto espontâneo, mas um dos bebês sobreviveu. Com dez semanas de ges...

Ler Notícia Completa

Médicos dizem estar perto de chegar a exame de sangue para todos os tipos de câncer

Médicos dizem estar perto de chegar a exame de sangue para todos os tipos de câncer

Cientistas dizem que estão mais perto de criar um exame de sangue universal, capaz de identificar todos os tipos de câncer. Estudo conduzido com 1.005 pacientes por uma equipe da Universidade Johns Hopkins, dos Estados Unidos, testou um método que detecta oito tipos de proteínas e 16 mutações ge...

Ler Notícia Completa