Ir al contenido principal

Cifrar campos en MySQL

Al crear una base de datos hay ocasiones en que se necesita cifrar un campo para que al realizar una consulta el valor original no sea visible a los usuarios, por ejemplo cuando se crea una tabla que almacene usuarios y contraseñas.
Existen diferentes tipos de cifrado que varían su grado de seguridad, entre los cuales están los siguientes:

MD5
Este cifrado utiliza un campo de 32 caracteres alfanuméricos, el algoritmo MD5 no puede ser revertido, (Se ha mostrado que si es posible, pero es proceso es muy complejo), es decir una vez que se ha cifrado no se puede regresar al valor original.

La forma de hacerlo es la siguiente:

mysql> INSERT INTO usuarios(usurio,clave) VALUES('usuario',MD5('clave'));

SHA o SAH1

Al igual que MD5 una vez que se ha cifrado el campo con ella no puede ser revertido, SHA utiliza un cheksum de 160 bits mientras que MD5 es de 128 bits, por lo que es más seguro su uso y necesita 40 caracteres para almacenarse.

La forma de hacerlo es la siguiente:

mysql> INSERT INTO usuarios(usurio,clave) VALUES('usuario',SHA('clave'));

AES

Este a diferencia de los dos anteriores si puede ser revertido a su valor original, y el campo donde se almacena debe ser de tipo BLOB, y se encuentra implementado desde MySQL 4.0.2

Para cifrar:

mysql> INSERT INTO usuarios (usurio,clave) VALUES('usuario',AES_ENCRYPT('contraseña','clave'));

Para descifrar:

mysql> INSERT INTO usuarios (usuario,clave) VALUES('usuario',AES_DECRYPT('contraseña','clave'));

Comentarios

Entradas más populares de este blog

Creación de Librerías en Java

Creación de Librerías en Java   Las librerías son un conjunto de clases con funciones especificas que ayudan a desarrollar aplicaciones más complejas de una forma sencilla, por ejemplo si se requiere realizar cálculos matemáticos y emplear el funciones como el Seno o Coseno, simplemente se importa la librería Math y se utilizan estos métodos, en lugar de desarrollarlos. Java cuenta con una extensa lista de librerías disponibles dentro del JDK o desarrolladas por terceros, pero también existe la posibilidad de desarrollar librerías propias para reutilizar de forma más eficiente el código, por ejemplo si se trabaja de forma cotidiana con conexión a base de datos, se pueden desarrollar métodos genéricos que realicen la conexión, que validen las consultas, etc. de forma que su uso reduzca el tiempo de desarrollo e incremente la productividad. Para este tutorial se van a crear dos proyectos en NetBeans, uno sera la librería y el otro proyecto hará uso de esta.

Elegir la clase a ejecutar en NetBeans, MVC

Elegir la clase a ejecutar en NetBeans Para que java pueda ejecutar una aplicación esta debe tener un método conocido como punto de entrada, este método tiene la sintaxis: void static void main(String [] sax){ //código } En ocasiones en una aplicación tiene varios puntos de entrada, que pueden servir para probar diferentes partes de la aplicación sin tener que recorrer o pasar por varias clases, para esto se puede seleccionar directamente en las propiedades del proyecto que clase será la principal.

Librerías JOptionPane para generar ventanas de entrada y salida de datos

Para poder introducir datos leídos desde el teclado existen varias formas, una de ellas hace uso de la librería javax.swing.JOptionPane que entre otras opciones permite mostrar ventanas para introducir datos, y ventanas para mostrar valores. Con el uso de esta librería se crean pequeñas interfaces definidas por el sistema, pero ya se hace uso de las librerías graficas swing, que se verán más adelante.