Ir al contenido principal

Entradas

Mostrando las entradas de noviembre, 2008

Ley contra el SPAM

Leo en el periodo la Nación ( http://www.nacion.com/ln_ee/2008/noviembre/28/pais1788837.html ) la divulgación acerca de una ley para castigar a las entidades o personas que realicen SPAM, ya sea mediante llamadas telefónicas, mensajes de texto (SMS), etc. Una buena practica, cuando recibimos un correo electrónico basura, es rastrear la IP y enviársela a Racsa detallando el delito, en el caso de mensajes de texto o llamadas no deseadas, se puede notificar al ICE. Por otro lado, sería interesante crear un "black list", para denunciar y exponer a los sitios, números de teléfono o personas que se dedican a este tipo de actividades.

Impensando acerca de las referencias en Java

Fue hace ya algún tiempo que pase un rato discutiendo con algunos compañeros acerca de si existe o no el paso por referencia; el discurso fue mucho hacia que en Java el comportamiento, en el supuestamente pasamos por referencia un objeto y por valor los objetos primitivos creo mucha polémica. Para ubicarnos en contexto veamos el siguiente ejemplo. public static void main(String[] args) { int value = 10; changeValue(value); System.out.println("value = " + value); User user = new User(); Name name = new Name(); user.setName(name); name.setName("jsanca"); name.setLastName("XXX"); user.setPassword("123queso"); System.out.println("user: " + user.getName().getName() + ", " + user.getName().getLastName() + ", " + user.getPassword()); changeValue1(user); System.out.println("user: " + user.getName().getName() + ", " + user.getName().getLastName() + ", " + user.ge

Labor de mantenimiento

Como parte mi labor de mantenimiento, se han adherido nuevos elementos al blog; Se agrego un icono para el usuario de debugmodeon y mi perfil de linkedin . Se cambio el "look & feel" y la estrategia adSense . Se agrego un nuevo elemento llamado: Que hay de nuevo en blogger, el mismo tiene las actualizaciones mis blogs. La sección de visitalos fue actualizada y refactorizada. La sección de foto fue eliminada, por no contar con ninguna hasta el momento. Del primer punto, solo decir que ambos iconos los tome del sitio debugmodeon y los agregue como un nuevo elemento HTML/JavaScript. El segundo punto fue cambiado después de leer algunos artículos en adsense en español ; este sitio además fue agregado a que hay de nuevo y les recomiendo visitarlo regularmente, pues contiene información y artículos muy interesantes acerca de Google AdSense . El tercer elemento me gusta bastante y muestra de una manera muy agradable los blog con las entradas mas recientes. Mi ultimo y cuart

Utilizando expresiones regulares en Java

A continuación muestro un ejemplo de como utilizar expresiones, no se pretende cubrir extensivamente ni mucho menos, el uso de expresiones regulares. Nuestro ejemplo, simplemente muestra como buscar los matches, de una cadena dentro de otra. Nota: Tanto el objeto Pattern como Matcher, se encuentra alojados en el paquete java.util.regex del SDK Java Standard. public static int countMatches (String string, String patternToFind) { Pattern pattern = null; Matcher matcher = null; int countMatches = 0; pattern = Pattern.compile(patternToFind); matcher = pattern.matcher(string); while (matcher.find()) { countMatches +=1; } matcher = null; pattern = null; return countMatches; } // countMatches System.out.println(countMatches("hola ?,?,?,?,?)", "\\?")); System.out.println(countMatches("hola)", "\\?")); Resultado: 5 0 El ejemplo simplemente compila una cadena, una vez compilado y siendo valido, solicitamos los matches

Open CSV

http://opencsv.sourceforge.net/ trata de un framework muy simple y sin mas dependencias de acople que el mismo SDK, a continuación muestro como encapsular mediante Spring, la librería y a su vez leer un archivo csv. import java.io.Closeable; import java.io.IOException; /** * Common interface to read CSV file extension. * @author jsanca * */ public interface CsvReaderGenericDAO extends Closeable { /** * Return the next row in the CSV file, * null if not has next. * @return String [] */ String [] next () throws IOException; } // E:O:F:CsvReaderGenericDAO. Esta clase será nuestra interface común para el lector de Csv. Como puedes ver, simplemente lee la siguiente fila y retorna un vector de cadenas, null en caso que ya no existan mas filas. import java.io.IOException; import au.com.bytecode.opencsv.CSVReader; /** * http://opencsv.sourceforge.net/ implementation wrapper. * @author jsanca * */ public class OpenCsvReaderGenericDAOImpl implements CsvReaderGenericDAO { private CSV

Revisa tu ortografía

En los últimos días y como todos los blogueros se darán cuenta, el corrector ortográfico de blogger, no esta funcionando de la manera correcta, encontré este otro sitio donde puedes checar en línea tu ortografía; http://revisor.com.ar/ , funciona bastante bien y es mejor que tener que abrir el open office o el Abi.

http://portableapps.com/

http://portableapps.com/ es un sitio Web, donde puedes conseguir gran cantidad de software en principio portable (i.e no ocupa instalarse) y entre sus filas milita mucho software free o open, yo lo estoy evaluando el sitio y hasta el momento me parece muy completo.

My Cow parade

http://www.mycowparade.net Full recomendado, este sitio conserva una de las más grandes colecciones de las vaquitas que se formaron parte de la muestra de arte, del cowparade, San José y que si mas no me equivoco, ahora se encuentran en las ruinas de Cartago. Excelente recopilación y sin mas, mis sinceras felicitaciones al creador!

Algunas cosas acerca de Herencia, sobre escritura y métodos estaticos

A continuación vamos a realizar un pequeño estudio, acerca de dos cosas, la primera de ellas es probar que pasa cuando ponemos los keywords, final y static al mismo tiempo en una clase, la segunda es determinar el comportamiento de las clases cuando se sobre escribe un método estático. 1) Tomando en cuenta que una clase final no puede ser extendida y una clase abstract debe ser extendida, cuando intentamos hacer: public final abstract class ImposibleAbstractClass { public abstract void doSomething (); } El compilador nos muestra el siguiente error de compilación: "The class ImposibleAbstractClass can be either abstract or final, not both" Osea, no se puede hacer. 2) Que pasa cuando sobre cargamos un método estático: Veamos el siguiente código: public class A { public static void a () { System.out.println("A"); } public void b () { System.out.println("a"); } } public class B extends A { public static

Test de eficiencia en concatenación de Java String.

El siguiente código resulta muy interesante, en el grado que nos permite experimentar con diferentes implementaciones de CharSequence, para concatenar caracteres (string con +, string utilizando el método concat, StringBuilder, StringBuffer y una biblioteca de terceros que implementa un nuevo objeto llamado Ropes, el cual asegura ser mas rápido y eficiente que el StringBuffer y el simple String (+ info: http://ahmadsoft.org/ropes/). Los resultados a la vista son muy interesantes, el StringBuilder gana la lucha en eficiencia y eficacia. Y la razón del resultado recae en la estrategia de bufereo y que el objeto no sea sincronizado, muy cerca le sigue el StringBuffer el cual utiliza la misma estrategia de buffering, sin embargo es un objeto sincronizado, seguido por la biblioteca propietaria Ropes, la utilizaron del método String.concat() se encuentra de penúltima, la ultima y altamente no recomendable es la utilización del operador + para concatenar; esta operación no solo es lenta, tamb

Comparación de cadenas en Java

El siguiente código nos muestra diferentes formas y métodos para realizar comparaciones de cadenas. La primera comparación con el operador (==), se realiza simplemente a nivel de referencia de memoria. El método (equals) permite realizar una comparación carácter a carácter de dos strings. (equalsIgnoreCase) funciona igual que (equals) descartando las diferencias entre mayúsculas y minúsculas. (CompareTo) permite comparar dos cadenas, con la diferencias que si la clase es igual retorna 0, si la primera cadena es mayor retorna la diferencia (un numero positivo), si la cadena es menor retorna también la diferencia (un numero negativo). Por ultimo se utilizan métodos para realizar comparaciones de pre y pos cadenas, obtener un índice, etc. public void comparisonEqual () { String s1 = "Hello Word"; String s2 = "Hello Word"; String s3 = s1; // Equal examples... System.out.println((s1 == s2)?s1 + " = " + s3: s1 + " != " + s3); System.out

String en Java

Ahora nos centraremos en objetos CharSequence, esta interface es implementada por varios objetos, tales como; String, StringBuilder, StringBuffer, CharBuffer. Ahora nos centraremos en los primeros 3 objetos, pero tomando más importancia al objeto String. String s = "Hello Word"; System.out.println("chartAt: " + s.charAt((s.length() - 1) / 2)); System.out.println("codePointAt: " + s.codePointAt((s.length() - 1) / 2)); System.out.println("isEmpty: " + s.isEmpty()); System.out.println("split: " + java.util.Arrays.toString(s.split("o"))); System.out.println("toCharArray: " + java.util.Arrays.toString(s.toCharArray())); System.out.println("toCharArray: " + s.replace('o', 'a') ); System.out.println("toCharArray: " + s.replace("Hello", "Good bye") ); El método CharAt, nos permite obtener el carácter en una posición determinada. El método codePointAt,

Transformando fechas a diferentes zonas horarias (TimeZone)

Ya es sabido por todo programador Java, que uno de los puntos mas bajos, recae en el uso de las fechas, las mismas se encuentran super mal diseñadas y algunos objetos como el caso de Date, practicamente no son usables, pues toda su API esta deprecada (cosa que siento debería de dejar de ponerla deprecada, pues van por la versión 6 y aun la conservan). Recientemente me encontré con el siguiente problema; resulta que al poner un sistema en otro servidor, el cual aparentemente tiene una diferencia horaria configurada, obtenemos como seria de esperar resultados no esperados, cuando realizamos consultas con fechas a la base de datos. La primera solución que se nos ha ocurrido es implementar un convertidor de fechas a diferentes zonas horarias, a continuación coloco el método necesario para realizar la operación: public static Date convertToTimeZoneDate(Date date, TimeZone timeZone) { Date newTimeZoneDate = null; Calendar foreignCalendar = null; // Create a Calendar object with the local ti

Un viaje a través de los Vectores en Java

import java.util.ArrayList; import java.util.List; public class Arrays { public void example1() { int i = 0; // Diferentes formas de declarar un array. Object[] objectArray = null; String[] stringArray = new String[10]; int[] intArray = new int[] { i++, i++, i++, i++, i++, i++, i++, i++, i++, i++ }; Character[] characterArray = { 'a', 'b', 'c' }; char[] charArray = new char[26]; for (int j = 0; j < stringArray.length; j++) { stringArray[j] = String.valueOf(j); } List listString = java.util.Arrays.asList(stringArray); System.out.println("listString = " + listString); System.out .println("java.util.Arrays.binarySearch(characterArray, 'c') = " + java.util.Arrays.binarySearch(characterArray, 'c')); System.out .println("java.util.Arrays.binarySearch(characterArray, 'd') = " + java.util.Arrays.binarySearch(characterArray, 'd')); System.out .println("java.util.Arrays.equals(characterArray, new char [

Creando un TLD dinamicamente con tobago apt plugin y Struts

Una de las tareas tediosas en JEE, es la de mantener nuestros TLD (definición de  librerías de Tag), cada vez que se cambia o agrega algo. Hace poco publique un post donde se explicaba como realizar taglibs utilizando el API de componentes de Struts , pues ahora se mostrara un plugin para Maven, mediante el cual podemos generar automáticamente un TLD, como observación interesante, cuando el TLD se almacena bajo el “META-INF”, no hay necesidad de agregarlo al “web.xml”, ni necesidad de tenerlo en bajo la estructura de directorios del WEB-INF. Lo primero que debemos hacer, es agregar la carpeta “META-INF”, bajo main/resources, una nota al pie; Maven filtra cualquier directorio que no tenga ningún archivo, por lo tanto puedes agregar bajo “META-INF”, un archivo “README.txt”, con un mensaje como este (yo lo copie de Struts 2) TLD file is generated inside META-INF after compilation. If META-INF is empty, Maven will not copy it to the "target/classes" folder. Please do not remove M

Uso aplicado de la instrucción "For"

A continuación se presenta una pequeña aplicación, donde se utiliza la instrucción de control " For ". Este ejemplo muestra como construir un Applet y como dibujar sobre ella (utilizando para ello la instrucción " For "), una seria de rombos, existen dos prototipos (métodos), el primer " paintRomboLine ", resulta mas fácil de entender, pero necesita mas código para funcionar (4 instrucciones " for "), el segundo prototipo solo ocupa una instrucción " for ", y realiza una serie de cálculos por cuadrantes. import java.awt.Dimension; import java.awt.Graphics; import java.awt.HeadlessException; import javax.swing.JApplet; /**  * Simple class to paint a rombo based in lines.  *   * @author jsanca  *   */ public class DrawRombo extends JApplet { private static final long serialVersionUID = 7677516509658561962L; public DrawRombo() throws HeadlessException { super(); setSize(new Dimension(1200, 1200)); } // DrawCircularLine. @Overrid

Al fin MTV reconoce el potencial de la Internet

Después de mucha lucha y denuncias públicas y demás pleitos para llamar la atención, la cadena mundial de música por televisión mas grande el mundo MTV , abren toda su biblioteca (bueno casi toda, el material en ingles por el momento), al publico. Aseguran tener conciertos, espectáculos acústicos , más todos sus vídeos y a diferencia de YouTube (que es mantenida por una comunidad en buena parte), esta es soportada por MTV , lo que le proporciona idéntica calidad a cada uno de sus temas ( vídeos ), el sitio en donde han publicado el contenido le llaman MTV Music , y yo debo reconocer que estoy como chiquito con juguete nuevo, jejeje . El sitio ofrece una gran cantidad de música , como señale anteriormente y además realiza sugerencias acerca de música o vídeos relacionados, en las búsquedas , te de la oportunidad de ir a un perfil del artista o directamente a los vídeos . Buena noticia y supongo que a MTV le paso como dicta el viejo adajio , " si no puedes vencerlos, unet

Creando e integrando "custom taglibs" con Struts 2.x, Spring y FreeMarker

Creando un taglib, extendido de los componentes de Struts. Recientemente surgió la necesidad de crear un “taglib”, para un proyecto en el cual estoy trabajando, hasta ahí todo bien. El problema inicia cuando deseamos reutilizar los componentes de Struts (utilizamos la versión 2.x). Después de investigar un poco, nos encontramos con el “tag” (“<s:component />”), este permite pasarle un nombre de plantilla (de Velocity o FreeMaker) y renderizar el resultado en nuestro Html, por ejemplo, si tenemos: <component template="/my/custom/component.vm”>     <s:param name="key1" value="value1"/>     <s:param name="key2" value="value2"/> </s:component> Esto invocará una plantilla de Velocity e introduce al contexto de Velocity, un Mapa llamado “parameters”, del cual podemos obtener los parámetros que anteriormente insertamos en el JSP. Más o menos, algo así: ${parameters.key1} Este enfoque esta bastante bien, sin

Nuevo libro (JSF)

Un nuevo recurso para mi biblioteca personal, se trata del libro Core Java Server Faces , apenas lo recibí esta semana y ya estoy avanzando por el primer capitulo, la lectura hasta el momento resulta simple y muy facíl de entender, espero terminarlo tan pronto sea posible e ir colocando aquí , en el blog, las diferentes impresiones acerca del mismo. En cuanto a Faces, en realidad mi experiencia con esta especificación, a pesar de ser el estándar propuesto por Sun , nunca ha sido mas allá de algunos artículos . Conozco su utilidad y el concepto detrás del mismo, sin embargo espero que al final de la lectura, pueda contar con los recursos tecnicos necesarios para poder enfrentar una aplicación con JSF . Personalmente siempre me ha gustado el enfoque de Struts o SpringMVC , actualmente me encuentro trabajando con Struts 2 y fuera de algunos bugs y la poca documentación , comparandola con su predecesor ( Struts 1), la potencia e integración tanto con Spring , como con bibliote

Ejecución de varios select con JDBC

Buenas lectores, Días atrás , me estuvo dando lata un problema, que describo a continuación; resulta que deseaba enviar una serie de consultas, tipo " select " a una base de datos MySQL, para ahorrar tiempo y conexión de red. Mi primera idea, al checkar el API de JDBC era utilizar el método, java.sql.Statement.addBatch(String sql ), para agrupar un conjunto de instrucciones " select " y después invocar al método executeBatch , de esa misma clase. Una vez ejecutados los " selects ", podría obtener el primer resultSet , recorrerlo y solicitar el siguiente resultSet , utilizando para ello el método getMoreResult (siempre en la misma clase), el cual itera sobre el siguiente ResultSet (resultado del siguiente select ), en caso de que este exista, de lo contrario, retorna un " false ". A la luz de los resultados, surgieron los siguientes problemas: El primer problema fue el MySQL en si, resulta que la conexión por defecto no tiene soporte para e

Instrucciones de control

A continuación se presenta un ejemplo, con los diferentes usos para estructuras condicionales y de iteración. El ejemplo es totalmente funcional y nos muestra en el método "ifCondicionalStatement()" las  instrucciones condicionales, las diferentes formas de utilizar la sentencia, if, else, switch y una forma opcional de implementar un switch con un mapa, con la ventaja de poder switchear valores mas alla de los primitivos. El método "iterateStatement()" contiene diferentes ejemplo para utilizar, while, for, además de instrucciones como; continue, break, etc. package com.avventa.training.java.class4; import java.util.Arrays; import java.util.HashMap; import java.util.Map; public class ControlStatements { public static void main(String[] args) { System.out.println("** ifCondicionalStatement **"); ifCondicionalStatement(); System.out.println("** iterateStatement **"); iterateStatement(); } /** * Some examples of conditional stateme