El cifrado César, también conocido como cifrado por desplazamiento o código de César, es una de las técnicas de cifrado más simples la cual implementaremos en este post utilizando el lenguaje de programación Kotlin.
Es un tipo de cifrado por sustitución en el que una letra en el texto original es reemplazada por otra letra que se encuentra un número fijo de posiciones más adelante en el alfabeto. Por ejemplo, con un desplazamiento de 3, la A sería sustituida por la D (situada 3 lugares a la derecha de la A), la B sería reemplazada por la E, etc. Este método debe su nombre a Julio César, que lo usaba para comunicarse con sus generales. [Santa Wikipedia]
Cifrado Cesar en Kotlin
1 fun main(args : Array<String>){ 2 3 val ALFABETO:String = "abcdefghijklmnopqrstuvwxyz" 4 5 /** 6 * determina si un texto dado pertenece al abcedario 7 * @param texto 8 * @return boolean 9 */ 10 fun esLetra(texto:String):Boolean{ 11 return texto.matches("[a-z]+".toRegex()) 12 } 13 14 /** 15 * Cifra mensaje utilizando el Codigo Cesar 16 * @param mensaje 17 * @param desplazamiento 18 * @return String Texto cifrado 19 */ 20 fun encriptar(mensaje:String, desplazamiento:Int):String{ 21 var textoCesar:String="" 22 for( i in 0..mensaje.length-1){ 23 if(esLetra(mensaje.toLowerCase().get(i).toString())){ 24 //Obtiene posicion del caracter "i" del mensaje en el alfabeto 25 var posicionActual:Int = ALFABETO.indexOf(mensaje.toLowerCase().get(i)) 26 //Obtiene nueva posicion 27 var nuevaPosicion:Int = ((desplazamiento + posicionActual) % 26) 28 //Obtiene nuevo caracter y concatena en mensaje 29 textoCesar += ALFABETO.get(nuevaPosicion) 30 }else{//ignora y concatena caracter original en mensaje 31 textoCesar += mensaje.toLowerCase().get(i).toString() 32 } 33 } 34 return textoCesar 35 } 36 37 /** 38 * Descifra mensaje utilizando el Codigo Cesar 39 * @param mensajeCifrado 40 * @param desplazamiento 41 * @return String mensaje descifrado 42 */ 43 fun desencriptar(mensajeCifrado:String, desplazamiento:Int):String{ 44 var mensaje:String="" 45 for( i in 0..mensajeCifrado.length-1){ 46 if(esLetra(mensajeCifrado.toLowerCase().get(i).toString())){ 47 var posicionActual:Int = ALFABETO.indexOf(mensajeCifrado.toLowerCase().get(i)) 48 var nuevaPosicion:Int = ((posicionActual - desplazamiento) % 26) 49 if (nuevaPosicion < 0) 50 { 51 nuevaPosicion = ALFABETO.length + nuevaPosicion 52 } 53 mensaje += ALFABETO.get(nuevaPosicion) 54 }else{//ignora y concatena en mensaje 55 mensaje += mensajeCifrado.toLowerCase().get(i).toString() 56 } 57 } 58 return mensaje 59 } 60 61 // 62 var mensaje:String = "6 de Agosto de 1825: Independencia de la República de Bolivia" 63 println("Original : " + mensaje) 64 var cifrado:String = encriptar(mensaje,3) 65 println("Cifrado : " + cifrado) 66 println("Descifrado: " + desencriptar(cifrado,3)) 67 68 }
Ejecutando el código anterior tenemos:
enjoy!!!
Un algoritmo de búsqueda binaria se emplea para buscar un valor en particular en un arreglo previamente ordenado. Para i[...]
En este tutorial veremos la forma de conectarse a una base de datos de Firebird utilizando el lenguaje Java y el IDE Net[...]
El método Bífido es un cifrado fraccionario. Es decir que cada letra viene representada por una o más letras o símbolos,[...]
Si tenemos una aplicación android que estemos desarrollando en el IDE Eclipse y queremos cambiar el icono de la aplicaci[...]
Java Printing nos permite hacer uso de las impresoras del sistema para, valga la redundancia 🙂 imprimir los gráficos de[...]
Un Fragment representa un comportamiento o una parte de la interfaz de usuario en una Activity. Puedes combinar múltiple[...]