Creando mi sitio un con hosting gratuito : )

30 04 2011

Llevaba muchisisisisimo tiempo sin escribir ni hacer nada interesante… hasta deje vencer el hosting que tenia, pero bueno esa es otra historia… hoy decidí crear un nuevo sitio donde seguiré documentando algunas cosas y talvez pueda ser de mucha ayuda para la comunidad :D .

¿Buscando un buen hosting + dominio free?

- Luego de preguntar varias veces al papá google, encontre una página que me pareció excelente, por las caracteristicas que ofrecia y la rápidez para crear la cuenta y empezar a jugar.  Para no entrar en detalles,  la URL es  :

https://x10hosting.com/

Listo!!! eso es todo por el momento, cambio y fuera :

Hakuna Matata





Objetivos de la SCJP (CX-310-065)

5 07 2010

Objetivos de la certitificación :

La certificación está basada sobre los siguientes objetivos.

Section 1: Declarations, Initialization and Scoping

  1. Develop code that declares classes (including abstract and all forms of nested classes), interfaces, and enums, and includes the appropriate use of package and import statements (including static imports).
  2. Develop code that declares an interface. Develop code that implements or extends one or more interfaces. Develop code that declares an abstract class. Develop code that extends an abstract class.
  3. Develop code that declares, initializes, and uses primitives, arrays, enums, and objects as static, instance, and local variables. Also, use legal identifiers for variable names.
  4. Given a code example, determine if a method is correctly overriding or overloading another method, and identify legal return values (including covariant returns), for the method.
  5. Given a set of classes and superclasses, develop constructors for one or more of the classes. Given a class declaration, determine if a default constructor will be created, and if so, determine the behavior of that constructor. Given a nested or non-nested class listing, write code to instantiate the class.

Section 2: Flow Control

  1. Develop code that implements an if or switch statement; and identify legal argument types for these statements.
  2. Develop code that implements all forms of loops and iterators, including the use of for, the enhanced for loop (for-each), do, while, labels, break, and continue; and explain the values taken by loop counter variables during and after loop execution.
  3. Develop code that makes use of assertions, and distinguish appropriate from inappropriate uses of assertions.
  4. Develop code that makes use of exceptions and exception handling clauses (try, catch, finally), and declares methods and overriding methods that throw exceptions.
  5. Recognize the effect of an exception arising at a specified point in a code fragment. Note that the exception may be a runtime exception, a checked exception, or an error.
  6. Recognize situations that will result in any of the following being thrown: ArrayIndexOutOfBoundsException,ClassCastException, IllegalArgumentException, IllegalStateException, NullPointerException, NumberFormatException, AssertionError, ExceptionInInitializerError, StackOverflowError or NoClassDefFoundError. Understand which of these are thrown by the virtual machine and recognize situations in which others should be thrown programatically.

Section 3: API Contents

  1. Develop code that uses the primitive wrapper classes (such as Boolean, Character, Double, Integer, etc.), and/or autoboxing & unboxing. Discuss the differences between the String, StringBuilder, and StringBuffer classes.}
  2. Given a scenario involving navigating file systems, reading from files, writing to files, or interacting with the user, develop the correct solution using the following classes (sometimes in combination), from java.io: BufferedReader, BufferedWriter, File, FileReader, FileWriter, PrintWriter, and Console.
  3. Use standard J2SE APIs in the java.text package to correctly format or parse dates, numbers, and currency values for a specific locale; and, given a scenario, determine the appropriate methods to use if you want to use the default locale or a specific locale. Describe the purpose and use of the java.util.Locale class.
  4. Write code that uses standard J2SE APIs in the java.util and java.util.regex packages to format or parse strings or streams. For strings, write code that uses the Pattern and Matcher classes and the String.split method. Recognize and use regular expression patterns for matching (limited to: . (dot), * (star), + (plus), ?, \d, \s, \w, [], ()). The use of *, +, and ? will be limited to greedy quantifiers, and the parenthesis operator will only be used as a grouping mechanism, not for capturing content during matching. For streams, write code using the Formatter and Scanner classes and the PrintWriter.format/printf methods. Recognize and use formatting parameters (limited to: %b, %c, %d, %f, %s) in format strings.

Section 4: Concurrency

  1. Write code to define, instantiate, and start new threads using both java.lang.Thread and java.lang.Runnable.
  2. Recognize the states in which a thread can exist, and identify ways in which a thread can transition from one state to another.
  3. Given a scenario, write code that makes appropriate use of object locking to protect static or instance variables from concurrent access problems.

Section 5: OO Concepts

  1. Develop code that implements tight encapsulation, loose coupling, and high cohesion in classes, and describe the benefits.
  2. Given a scenario, develop code that demonstrates the use of polymorphism. Further, determine when casting will be necessary and recognize compiler vs. runtime errors related to object reference casting.
  3. Explain the effect of modifiers on inheritance with respect to constructors, instance or static variables, and instance or static methods.
    Given a scenario, develop code that declares and/or invokes overridden or overloaded methods and code that declares and/or invokes superclass, or overloaded constructors.
  4. Develop code that implements “is-a” and/or “has-a” relationships.

Section 6: Collections / Generics

  1. Given a design scenario, determine which collection classes and/or interfaces should be used to properly implement that design, including the use of the Comparable interface.
  2. Distinguish between correct and incorrect overrides of corresponding hashCode and equals methods, and explain the difference between == and the equals method.
  3. Write code that uses the generic versions of the Collections API, in particular, the Set, List, and Map interfaces and implementation classes. Recognize the limitations of the non-generic Collections API and how to refactor code to use the generic versions. Write code that uses the NavigableSet and NavigableMap interfaces.
  4. Develop code that makes proper use of type parameters in class/interface declarations, instance variables, method arguments, and return types; and write generic methods or methods that make use of wildcard types and understand the similarities and differences between these two approaches.
  5. Use capabilities in the java.util package to write code to manipulate a list by sorting, performing a binary search, or converting the list to an array. Use capabilities in the java.util package to write code to manipulate an array by sorting, performing a binary search, or converting the array to a list. Use the java.util.Comparator and java.lang.Comparable interfaces to affect the sorting of lists and arrays. Furthermore, recognize the effect of the “natural ordering” of primitive wrapper classes and java.lang.String on sorting.

Section 7: Fundamentals

  1. Given a code example and a scenario, write code that uses the appropriate access modifiers, package declarations, and import statements to interact with (through access or inheritance) the code in the example.
  2. Given an example of a class and a command-line, determine the expected runtime behavior.
  3. Determine the effect upon object references and primitive values when they are passed into methods that perform assignments or other modifying operations on the parameters.
  4. Given a code example, recognize the point at which an object becomes eligible for garbage collection, determine what is and is not guaranteed by the garbage collection system, and recognize the behaviors of the Object.finalize() method.
  5. Given the fully-qualified name of a class that is deployed inside and/or outside a JAR file, construct the appropriate directory structure for that class.
  6. Given a code example and a classpath, determine whether the classpath will allow the code to compile successfully.
    Write code that correctly applies the appropriate operators including assignment operators (limited to: =, +=, -=), arithmetic operators (limited to: +, -, *, /, %, ++, –), relational operators (limited to: <, <=, >, >=, ==, !=), the instanceof operator, logical operators (limited to: &, |, ^, !, &&, ||), and the conditional operator ( ? : ), to produce a desired result. Write code that determines the equality of two objects or two primitives.

A medida que vaya cubriendo cada objetivo ire haciendo modificaciones sobre este topic.

[D-m-K]

[D-m-K]




Certificaciones JAVA

5 07 2010

Bien de acuerdo a la página de SUN (Que por cierto, ahora es de Oracle por su compra) dispone de las siguientes certificaciones JAVA.

Las siguientes certificaciones de la tecnologia JAVA estan disponibles :
Sun Certified Java Associate (SCJA)
Sun Certified Java Programmer (SCJP) —> Esta es la prioridad y la razón de los temas de este blog.
Sun Certified Java Developer (SCJD)
Sun Certified Web Component Developer (SCWCD)
Sun Certified Business Component Developer (SCBCD)
Sun Certified Developer For Java Web Services (SCDJWS)
Sun Certified Mobile Application Developer (SCMAD)
Sun Certified Enterprise Architect (SCEA)

En una versión Beta se encuentran :
Sun Certified JSP and Servlette Developer for the Java EE6 Platform
Sun Certified EJB Developer for the Java EE6 Platform

Un poco más de información sobre la Sun Certified Java Programmer (SCJP) (Exam CX-310-065)

- Está basada en la edición 6 (Es decir que recoge información de las anteriores ediciones y se enfoca en las nuevas caracteristicas de esta versión).
- No necesita de la SCJA para presentar el examen.

Número de examen : CX-310-065
Precio : 281.775 (Pesos colombianos)
Institución : Prometric
Nro. Preguntas : 60
Tiempo límite : 180 Minutos
% para pasar : 58.33 %
Ejemplo preguntas : http://education.oracle.com/pls/web_prod-plq-dad/db_pages.getpage?page_id=303&p_certName=SQ1Z0-851

Fuentes de información interesantes para mejorar la calidad de estudio :

Guia de estudio SCJP (ISO)

Head First Java

Coleccion de Libros Head First





Una mirada a Symfony : Cambiando la cultura del desarrollo plano

8 06 2010

Manejo del Framework SYMFONY

Luego de seguir al pie de la letra una maquetación precambrica, simple y hasta un poco tediosa decidí documentarme un poquito más sobre el manejo de Framework para el desarrollo de sitios coquetos y complejos, ya que el enfoque que le estoy dando a mi estudio está sobre PHP, me incline por Symfony (ya que es uno de los más poderosos y sencillos de usar) para luego meterme de lleno con Zend Framework.

Ventajas de usar Symfony

  • Simplifica el desarrollo
  • Estructura de código fuente más legible.
  • Encapsula operaciones complejas en instrucciones sencillas.
  • Separa la lógica del negocio, lógica del servidor y presentación de la aplicación.
  • No se debe reinventar la rueda.

Características de Symfony

  • Fácil de Instalar.
  • Independiente del gestor de bases de datos.
  • Es sencillo de usar pero permite crear sitios Web complejos. Está basado en la premisa “Convenir en vez de configurar”
  • Sigue la mayoría de las mejores prácticas para la Web.
  • Código fácil de leer que incluye comentarios phpDocumentor y permite un mantenimiento sencillo
  • Los formularios incluyen validación automatizada y relleno automático de datos “repopulation”.
  • Los datos incluyen mecanismos de escape que permiten una mejor protección contra los ataques producidos por datos corruptos. (Por ejemplo los famoso XSS y el tipo de datos corruptos en los (blind) SQL Injection).
  • El sistema de enrutamiento y las URL limpias permiten considerar las direcciones de las páginas como parte de la interfaz, además de estar optimizada para los buscadores.
  • Las interacciones con Ajax son fáciles de implementar mediante los helpers que permiten encapsular los efectos de JavaScript compatibles con todos los navegadores en una única línea de código.

Conceptos básicos implementados en Simfony

  • PHP 5.
  • Programación Orientada a Objetos (POO).
  • Manejo de métodos mágicos (estos son usados en PHP)
  • PEAR (PHP Extension and Application Repository) : Framework creado para componentes de PHP reutilizables.
  • Mapeo de Objetos a Bases de Datos (ORM) Object Relational Mapping: Permite traducir la lógica de los objetos a la lógica relacional.
  • Desarrollo rapido de aplicaciones (RAD) : Conceptos de KISS (Keep It Simple, Stupid), (Don’t Repeat Yourself : No te repitas), TDD (Test-Drive Developer: Desarrollo Basado en Pruebas), XP (Extreme Programming : Programación Extrema)
  • YAML (YAML Ain’t Another Markup Language ) : Formato para serializar datos que es fácil de procesar por las maquinas, fácil de leer por las personas y fácil de interactuar los lenguajes de script. Es similar a la descripción de datos en XML pero con una sintaxis mucho más sencilla.

Requisitos para Usar Symfony

Bien para entender Symfony y vivir una experiencia al extremo solo es necesario manejar los conceptos básicos de la programación moderna (POO), el mapeo de objetos a bases de datos (ORM) y desarrollo de aplicaciones (RAD). El único requisito obligatorio es manejar PHP 5 :) .

Fuentes de información

Como la gran fuente para documentarme en este tema esto siguiente la lectura de un excelente libro : http://www.librosweb.es/symfony_1_2/





Leer directorios con PHP y la clase dir

10 05 2010

Tema: Manejo de archivo en PHP
Pregunta: ¿Como listar los archivos o elementos de un directorio con PHP?
Respuesta:

Se necesita realizar tres pasos basicos :
1. Definir la ruta del directorio a leer y abrirlo.
2. Leer todos los elementos del directorio con un while hasta que no encuentre mas.
3. Cerrar el directorio abierto.

Para este ejemplo se hace uso de la clase Clase dir

<?php
/*
 * Nombre      : leerDirectorio.php
 * Descripcion : Lee un directorio especifico y muestra todos sus elementos
 * @autor      : D-m-K
 * @Fecha      : 9 Mayo 2010
 * Referencias :
 *  - http://www.desarrolloweb.com/articulos/935.php
 *  - http://co.php.net/manual/es/function.opendir.php
 *  - http://co.php.net/manual/es/class.dir.php
 */

/***
 * Parametros
 *  - $path     : Ruta del directorio a leer
 * Uso la clase dir, instanciando un objeto y asi trabajar sus atributos y metodos
 *  - path     : Atributo que muestra la ruta especificada para el directorio
 *  - dir(path): Constructor que abre el directorio
 *  - read()   : Metodo que lee cada uno de los elementos del directorio avanzando en el puntero
 *  - rewind() : Metodo que devuelve el puntero del objeto al inicio
 *  - close()  : Metodo que cierra el directorio.
 * Colores usados en el ejemplo
 *  - Azul  : Para directorios
 *  - Verde : Para archivos
 ***/
function leerDirectorio($path) {
    //Creo un objeto del tipo dir, abriendo el directorio de una vez
    $dir = dir($path);
    //Muestro informacion de la ruta del directorio
    echo '


             Leyendo la ruta > ' . $dir->path . '
         

';

    //Comienzo a leer y a mostrar cada uno de los elementos del directorio
    while($element = $dir->read()){
        $color = "#77f"; //Defino  el color por defecto para los directorios
        if(is_dir($dir->path . $element)) //Si es un archivo
            $color = "#383";              //Cambia el color a mostrar
        //Muestro el elemento del directorio evaluado con su respectivo color
        echo "" . $element . " ";
    }
    //Cierro el directorio
    $dir->close();
}
?>

        Ejemplo de como leer un directorio usando PHP

Ver ejemplo : AQUI





Cifra de Vigenere en PHP

23 12 2009

Clase Vigenere

<?php
/******************************************************************************
 * Nombre : Vigenere.php
 * Clase para el cifrado de Vigenere para Project-RIC. Este es un cifrado de
 * sustitución polialfabetico, siendo una variación del cifrado de cesar. La diferencia
 * es que usa una palabra como semilla, la cual cada caracter representa el indice
 * del charset a ser sumado en las operaciones modulares. Esta semilla se repita cuantas
 * veces sea necesario hasta cifrar/descifrar toda la cadena.
 * @copyLeft  : Project-RIC
 * @package   : RiCrypt
 * @author      : D-m-K, d4rk.m0nk3y@gmail.com, my.opera.com/d-m-k
 ******************************************************************************/
class Vigenere {

charset = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";	//Definicion del charset
		$this->txt    = strtoupper($s);
		$this->seed   = strtoupper($seed);
    }

	/************************************************************************************
	* Funcion :  encode
	* Cifra la cadena pasada como parametro realizando una sustitucion
	* polialfabetica a traves de sumas modulares dependiendo el indice de cada caracter de la semilla
	* @param  $seed = Semilla con la que sera cifrado el mensaje
	* @return $result = Mensaje cifrado
	************************************************************************************/
    function encode(){
		$result = "";						//Cadena donde queda el resultado
		$x = 0;								//Indice de la semilla
		$p = 0;								//Posicion para relizar la operacion modular
		for($i=0; $itxt); $i++){
			if(strstr($this->charset, $this->txt{$i})){//Evaluo si existe el caracter en el charset
				$x = strpos($this->charset, $this->seed{($p % strlen($this->seed))});
				$result .= $this->rotate($this->txt{$i}, $x);	//Invoco funcion que hace la rotacion
				$p++; //Aumento el indice para la operacion modular
			}else{//Si no existe dejo el caracter evaluado
				$result .= $this->txt{$i};
				continue;
			}
		}
        return $result;						//Devuelvo la cadena Cifrada =)
    }

 	/************************************************************************************
	* Funcion  :  decode
	* DesCifra la cadena pasada como parametro realizando una sustitucion
	* polialfabetica a traves de sumas modulares dependiendo el indice de cada caracter de la semilla
	* @param  $seed = Semilla con la que sera cifrado el mensaje
	* @return $result = Mensaje cifrado
	************************************************************************************/
    function decode(){
		$result = "";						//Cadena donde queda el resultado
		$x = 0;								//Indice de la semilla
		$p = 0;								//Posicion para relizar la operacion modular
		for($i=0; $itxt); $i++){
			if(strstr($this->charset, $this->txt{$i})){//Evaluo si existe el caracter en el charset
				$x = strpos($this->charset, $this->seed{($p % strlen($this->seed))});
				$result .= $this->rotate($this->txt{$i}, -$x);	//Invoco funcion que hace la rotacion
				$p++; //Aumento el indice para la operacion modular
			}else{//Si no existe dejo el caracter evaluado
				$result .= $this->txt{$i};
				continue;
			}
		}
        return $result;						//Devuelvo la cadena DesCifrada =)
    }

	/*****************************************************************************
	* Funcion : rotate
	* Realiza la rotacion de un caracter sobre el charset dependiendo el valor de la semilla
	* de la cadena original la cantidad de veces definida en el parametro
	* @param  $s = Cadena original
	*                 $n = Cantidad de rotaciones
	* @return  $result = Valor del nuevo caracter de acuerdo al indice
	*****************************************************************************/
	function rotate($c, $n){
        $result = "";			//Texto de salida
        $tamC = strlen($this->charset); //Longitud de la cadena del charset
		$k = 0; 				//Indice para sustitucion de la cadena con el charset
		$n %= $tamC;			//Semilla ó rotacion
		$c = strtoupper($c);	//Convierto a mayuscula el caracter
		//Realizo la sustitución de cada caracter
        //Evaluo si el caracter en la posicion $i existe, de lo contrario
        //Dejo el caracter que esta por defecto
		if(strstr($this->charset, $c)){
			$k = (strpos($this->charset, $c) + $n);
			if($k charset{$k};
		}else{
			$result .= $c;
		}
		return $result;
	}
}
?>

Implementacion Cifra vigenere en PHP

encode();
		}
		//DESCIFRADO DEL MENSAJE
		if($_POST['tarea'] == "DesCifrar"){
			$cipher    = new Vigenere($mensaje, $semilla);
			$salida = $cipher->decode();
		}
	}
?>

		 .:: Implementacion de la cifra de vigenere ::. 

Vigenere


Mensaje a cifrar / descifrar : Semilla : <input type="text" name="semilla" style="width:150px;border:1px solid #555" value=""> | | <?php //Muestro el mensaje de salida if($salida != ""){ echo " Resultado del criptograma \n"; echo "
" . $salida . "
"; } ?>

Greetings to all and happy Bandwith :)





Solucionando Cuadraticas – Max Speed

22 10 2009

Este código hace parte de un reto de sinfocol, básicamente lo que hace es lo siguiente :
- Lee un fichero linea por linea, donde cada linea representa una ecuacion cuadratica.
- Resuelve la ecuación cuadratica evaluando los resultados de x1 y x2 para tomar el valor entero. (Un valor entero es aquel que no tiene punto flotante)
- Suma todos los valores enteros y arroja en un archivo “salida.txt” el resultado de la suma de todas las ‘x’ enteras y la cantidad de operaciones realizadas.

No siendo más aqui esta el código un poco documentado :)

/* Codigo mejorado :)
 * Encuentra la suma de todos los valores enteros de la solucion de las
 * formulas cuadraticas tomadas de un archivo
 * @author  DMK
 * Agradecimientos especiales al señor HaDeS por su buen reto =)
 */

import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;
import java.math.*;

public class Cuadraticas2 {
    public static void main(String args[]) throws IOException, ArrayIndexOutOfBoundsException{
        //String archivo = "quadratic.txt";
		try{
			String archivo = args[0];
			sumarCuadraticasEnteras(archivo);
		}catch(ArrayIndexOutOfBoundsException ex){
			System.out.println("Por favor ingrese el nombre del fichero a procesar :P ");
			System.out.println("Ejemploe : java Cuadraticas2 miFichero.txt");
		}
    }

    public static void sumarCuadraticasEnteras(String archivo) throws IOException{
        //Variables de control
        int necuaciones     = 0;
        String formulaError = "";
        //Variables para la formula
        long a,b,c,suma = 0;     //Valores de la ecuacion cuadratica
        int pos;        //Posicion para el substring
        String chunk;   //Trozo que va guardando la operacion
        double x1 = 0, x2 = 0, h = 0, raiz = 0; //Valores de salida

        //Verifico si el archivo existe
        try{
            //Variables para el manejo de archivos
            //Fichero de entrada
            File fe = new File(archivo);
            BufferedReader br = new BufferedReader(new FileReader(fe));
            //Fichero de salida
            PrintWriter out = new PrintWriter(new FileWriter("salida.txt"));

            //Leo el fichero
            String linea = "";
            while( (linea = br.readLine())!= null){
                //Remplazo caracteres en blanco

                linea = linea.replace("	", "");
                linea = linea.replace("--", "+");
                linea = linea.replace("x+-", "x-");
                linea = linea.replace("x--", "x+");
                linea = linea.replace("x++-", "x-");
                linea = linea.replace("+++", "+");      

                //Obtengo el valor de a
                pos = linea.indexOf("x^2");
                chunk = linea.substring(0, pos);
                a = Long.parseLong(chunk);
                //System.out.println(a);

                //Obtengo el valor de b
                pos = linea.indexOf("+");
                chunk = linea.substring((pos + 1),linea.indexOf("x",pos));
                if(chunk.length() == 0)
                    b = 1;
                else
                    b = Long.parseLong(chunk);

                //Obtengo el valor de c
                pos = linea.indexOf("x",pos);
                if(linea.indexOf("x+",pos) > 1)
                    chunk = linea.substring((pos + 2),linea.length());
                else
                    chunk = linea.substring((pos + 1),linea.length());

                if(chunk.length() == 0)
                    c = 0;
                else
                    c = Long.parseLong(chunk);

               //Realizo operacion de la raiz
               h = (b*b - 4*a*c);
               //Evaluo si h es negativo
                if(h >  x1  " + x1 + "   ==    x2: " + x2);

                //Realizo la suma de los numeros sin parte decimal
                if(x1 % 1 == 0){
                    necuaciones++;
                    suma += (long)x1;
                    out.println("#" + necuaciones + " : " + x1);
                }

                //Sumo los valores enteros de x1 y x2
                //Imprimo resultados
                if(x2 % 1 == 0){
                    necuaciones++;
                    suma += (long)x2;
                    out.println("#" + necuaciones + " : " + x2);
                }
                if( (x1 % 1 != 0 && x2 % 1 != 0)){
                    necuaciones++;
                    formulaError = "#" + necuaciones + " : " + linea + "\n";
                }

                //out.println(linea);
            }
            br.close();         //Cierro el archivo de lectura

            //Muestro varios resultados para comparar la respuesta
            out.println("Total de ecuaciones identificadas : " + necuaciones);
            out.println("La suma de los numeros es : " + suma);
            out.println("Las siguientes formulas tienen error : " + formulaError);

            out.flush();
            out.close();
        }catch(FileNotFoundException ex){
            System.out.println(" ERROR : Lo siento tio, pero el archivo "  + archivo + " no esta en ");
        }
    }
}

Hakuna matata!, Greetings to all and happy Bandwidth.





Cifrado por sustitución – 1

22 10 2009

Hola parceros, bueno luego de terminar la solución del reto de yashira “Trial Version”, aqui expongo el código que use para tal reto. Adicional a esto pues me pareció muy interesante la forma de cifrar y descifrar datos =).

Si pueden observar el código tiene cositas adicionales, como un menú, lee un archivo “entrada.txt” y arroja una “salida.txt”. No siendo más ahora si vamos a la acción :) . He colocado algunos comentarios documentando el código, sin embargo creo que esta muy claro ;)

/****
 *  msg : /&4=91 5)?1= 5$35==14& 5$ {$1 31)31=1 45 ${5+ - )5$?9=m5 =5- 45 {$ 5)/139& 9$69$9?&
 *  @description : Reto para yashira
 *  @author       :  D-m-K
 ***/

import java.io.File;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.PrintWriter;
import java.io.IOException;
import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.InputStreamReader;

public class TrialRamon {
    //Miembros de clase

    static BufferedReader br;
    //Patron de cadenas para cifrar y descifrar
    public final static String str1 = "1234567890!#$%&/(=)?{¡@*-+";
    public final static String str2 = "abcdefghijklnñopqrstuvwxyz";
    public static File fe;
    public static boolean abierto;

    //Main :P
    public static void main(String[] args) throws IOException {
        //Instacio y defino los datos de entrada
        fe = new File("entrada.txt");
        BufferedReader entrada = new BufferedReader(new InputStreamReader(System.in));
        int op;
        do{
            System.out.println(" 1. Cifrar datos");
            System.out.println(" 2. Descifrar datos");
            System.out.println(" 3. Salir :P ");
            System.out.print("    Opcion >>");
            op = Integer.parseInt(entrada.readLine());
            //Evaluo la opcion ingresada
            switch(op){
                case 1:
                    Criptar();
                    break;
                case 2:
                    DesCriptar();
                    break;
                case 3:
                    System.out.println("Hasta luego!");
                    System.exit(0);
                    break;
            }
        }while(op != 3);
    }

    //Codifico los datos del fichero de entrada
    public static void Criptar() throws IOException {
        //Evaluo si el fichero pudo ser abierto
        if(fe.exists()){
            br = new BufferedReader(new FileReader(fe));
            abierto = true;
        }else{
			System.out.println("El archivo no existe");
		}
        if(abierto){
            //Creo el fichero de salida
            PrintWriter out = new PrintWriter(new FileWriter("salida.txt"));
            //Realizo el cifrado de los datos
            String linea = "";
            while ((linea = br.readLine()) != null) {
                System.out.println(linea);
                for (int i = 0; i < str1.length(); i++) {
                    linea = linea.toLowerCase();
                    linea = linea.replace(str2.charAt(i), str1.charAt(i));
                }
                System.out.println(linea);
                //Escribo la linea cifrada en el archivo
                out.println(linea);
            }
            //Aseguro los datos de salida y cierro los ficheros
            br.close();
            out.flush();
            out.close();
        }else{
            System.out.println("\n ERROR : El archivo no pudo ser abierto");
        }
        System.out.println("leyendo");
    }

    //Decodifica los datos del fichero de entrada
    public static void DesCriptar() throws IOException{
    //Evaluo si el fichero pudo ser abierto
        if(fe.exists()){
            br = new BufferedReader(new FileReader(fe));
            abierto = true;
        }else{
			System.out.println("El archivo no existe");
		}
        if(abierto){
            //Creo el fichero de salida
            PrintWriter out = new PrintWriter(new FileWriter("salida.txt"));
            //Realizo el cifrado de los datos
            String linea = "";
            while ((linea = br.readLine()) != null) {
                System.out.println(linea);
                for (int i = 0; i < str1.length(); i++) {
                    linea = linea.toLowerCase();
                    linea = linea.replace(str1.charAt(i), str2.charAt(i));
                }
                System.out.println(linea);
                //Escribo la linea cifrada en el archivo
                out.println(linea);
            }
            //Aseguro los datos de salida y cierro los ficheros
            br.close();
            out.flush();
            out.close();
        }else{
            System.out.println("\n ERROR : El archivo no pudo ser abierto");
        }
        System.out.println("leyendo");
    }
}

Hakuna Matata! Greetings to all and happy bandwidth.





A la espera de un segundo

27 06 2009

Hoy es el final trágico de la historia que siempre estuvo maquinando
en la mente de este noble guerrero (Fantasia). Hoy la realidad muestra
su verdadero rostro ante el arquetipo elaborado de un sencillo plan
maestro (Conquista). Hoy se manifiestan los sentimientos de odio en una
sola palabra que genera temor a esta insulsa humanidad (Desilución),
tal vez mis creaturas han decido aceptar ser los oidos y el cuerpo de
un instinto fraternal e inevitable (Amor). Hoy es un día cualquiera,
en un lugar indeterminable, de una vida sin precedentes, donde los
personajes han sido simplemente, títeres seleccionados al azar de una
obra con un contenido vacuo.

¿El guionista?….

El mismo que escribe estas palabras y deja un sabor amargo en cada espacio que concluye al terminar. Solo el punto final marcará el comienzo de una nueva historia y el pensamiento creativo e inmune de todo sentimiento.

¿El dilema?…

Saber que por cualquier medio, habiendo hecho lo correcto y lo incorrecto, sin importar la morfológica apariencia que se muestre ante ese ser omnisciente (Ella), sin tener en cuenta las justificaciones de cualquier realidad o fantasia de este mundo, SIEMPRE se llegara a la misma conclusion, en pocas palabras mi estimado lector, yo le llamaria la cuspide de la ironía.

“Nada me pertenece y aun asi, quiero dejar de ser EL esclavo de este “TODO” que se vuelve mas obsesivo por poseerme…”

Greetings to All and Happy BandWidth.
By [D-m-K]





Jugando con ASCII V.0.1

29 04 2009

Bueno este es un simple codigo que saque por una duda que tenia referente a los ASCII

//*********************************************
// Ingresa una serie de caracteres y devulve
// su codificaci¢n en ASCII
//*********************************************

#include
#include

using namespace std;

void getAscii(char *);

int main(){

   char phrase[200];

   system("cls");
   cout<> ";
   cin.getline(phrase,200);
   getAscii(phrase);    //Function for get the code ASCII
   system("pause>nul");
   return 0;
}

//*********************************************
// Funcion : getAscii()
// Recibe como parametro un arreglo de chars
// y convierte los caracteres a ASCII
//*********************************************
void getAscii(char *msg){

   int i;
   cout<<"\n\tCONVERSION CHARS TO ASCII \n";
   cout<<"\t------------------------------------\n";

   cout<<"\n\t [ORIGINAL]\n\t ";
   i = 0;
   while(true){
     cout<<msg[i];
     i++;
     if(msg[i] == '')   break;
     if(i%15 == 0)        cout<<"\n\t ";
     cout<<"-";
   }

   cout<<"\n\n\t [ASCII]\n\t ";
   i = 0;
   while(true){
     cout<<(int)msg[i];
     i++;
     if(msg[i] == '')   break;
     if(i%15 == 0)        cout<<"\n\t ";
     cout<<"-";
   }

   cout<<"\n\n\t------------------------------------";
   cout<<"\n\t # Chars : "<<i;
   //# The END :P #
}

Greetings to all and happy Bandwidth








Seguir

Get every new post delivered to your Inbox.