lunes, 26 de octubre de 2009

Por donde comenzar con Scrum

domingo, 25 de octubre de 2009

UML

Tema2

Caso Practico UML

CasoPracticoVideoclubResuelto

Diseño Orientado a Objetos con UML

Desarrollo Orientado a Objetos con UML [libro-book-español-spanish] height="500" width="100%" > value="http://d1.scribdassets.com/ScribdViewer.swf?document_id=2458870&access_key=key-sjbj63aumlx2obn8rwa&page=1&version=1&viewMode=list">

miércoles, 14 de octubre de 2009

Servidor vinculado SQL Server 2005 y PostgreSQL

Pasos:
1. Descargarse e instalarse la version odbc mas actual para PostgreSQL de: http://www.postgresql.org/ftp/odbc/versions/msi/psqlodbc_08_04_0100.zip

2. Crear un oriden de datos de tipo “System DNS” en Panel de control->Herramientas administrativas->Origenes de datos ODBC, que conecte a su servidor PostgreSQL y nombrarlo por ejemplo “Pucallpa” (base de datos espacial con extensión PostGIS de ejemplo)


Figura 1: conexión ODBC a una base de datos PostgreSQL

3. Correr el siguiente código en el SQL Server Management Studio Express:

EXEC master.dbo.sp_addlinkedserver @server = N'Pucallpa', @srvproduct=N'Microsoft OLE DB Provider for ODBC Driver', @provider=N'MSDASQL', @datasrc='Pucallpa', @location='localhost', @catalog='pucallpa'

Este código es para añadir un servidor vinculado a SQL Server.

4. Correr el siguiente código en el SQL Server Management Studio Express: para asociar el login al servidor vinculado.


EXEC master.dbo.sp_addlinkedsrvlogin @rmtsrvname=N'Pucallpa', @useself=N'False', @locallogin=NULL, @rmtuser='postgres', @rmtpassword='xxx'

5. Ejecutar el siguiente código SQL desde SQL Server 2005:

SELECT * FROM OpenQuery(Pucallpa, 'select cod_lote from lotes')

Algo que me pidieron hacer hace un tiempo como consulta fue: saber el numero de habitantes en los lotes que están a 500 metros de un mercado de la ciudad de Pucallpa (llamado Mercado Nro 02)

SELECT --a.codlote, a.radio, u.nro_habitantes

sum(nro_habitantes)

FROM OpenQuery(Pucallpa, 'select * from mercadolimit5001000') a

left join tb_unidad_catastral u on substring(u.ucnumero,7,8) = a.codlote

where a.radio = 500


Figura 2: Lotes a 500 mts del Mercado N° 2

Para saber cuantos lotes estan a una distancia de otro lote (en este caso el mercado n° 2) hago la siguiente consulta en PostgreSQL con extensión espacial PostGIS:

Figura 3: Consulta espacial en la base de datos “pucallpa” de PostgreSQL

select l.* from lotes l, lotes a where( st_distance(l.geometria, a.geometria)<=1000 and a.cod_lote in ('01040001', '01040002', '01040003', '01040004', '01040005'))

  1. La tabla mercadolimit5001000 a sido creada con la finalidad de almacenar los datos de la consulta anterior, se ejecuto el sigueinte SQL en postgres:

insert into mercadolimit5001000 select l.cod_lote, 500 from lotes l, lotes a where( st_distance(l.geometria, a.geometria)<=500 and a.cod_lote in ('01040001','01040002','01040003','01040004','01040005'

Si desean ver un poco mas a modo de consulta y capas sobre la base de datos espacial que se utilizo en este post esta alojada en el Servidor de Mapas de la Municipalidad Provincial de Coronel Portillo en la que eh sido colaborador directo, ubicado en la siguiente direccion: http://201.230.96.134/pucallpa/mapa.phtml

Proximos Articulos:

- retomando PHP Zend Framework demo

- Google Maps con PHP aplicado a un Sistema de Posicionamiento Global



martes, 11 de agosto de 2009

Libro de Redes Neuronales

viernes, 31 de julio de 2009

Ciiptografia con Curvas Elipticas

Criptografía con Curvas Elipticas

lunes, 27 de julio de 2009

RSA y Firmas Digitales

work1_rsa

viernes, 3 de julio de 2009

Libro de Matematica discreta

Saludos, quisiera compartir con ustedes un libro estupendo sobre estructuras discretas, materia muy difundida en las ciencias de la computación.

miércoles, 13 de mayo de 2009

¿Python?

domingo, 3 de mayo de 2009

Alberto Mendelzon Workshop on Foundations of Data Management

Alberto Mendelzon Workshop on Foundations of Data Management (May 12--May14 of 2009, Arequipa-Peru)
Tutorials

* Claudio Gutierrez (Universidad de Chile);
RDF Databases
* Leonid Libkin (University of Edinburgh);
Schema mappings and data exchange for XML
* Laks Lakshmanan (U. British Columbia);
Social Networks: Is there more in them for us Database Types than just Poking?
* Peter Wood (University of London, Birkbeck);
Query languages for graph databases

Session1

* Andrea Cali, and Riccardo Torlone;
Checking Containment of Schema Mappings (Preliminary Report).
* Michael Meier, Michael Schmidt and Georg Lausen;
Stop the Chase.
* Ali Kiani and Nematollaah Shiri;
Using Patterns for Faster and Scalable Rewriting of Conjunctive Queries.
* Renzo Angles;
A Nested Graph Model for Visualizing RDF Data

Session2

* Tao Yang and Dongwon Lee;
T^3: On Mapping Text to Time Series.
* Leticia Gomez, Bart Kuijpers and Alejandro Vaisman;
Temporal Support in Sequential Pattern Mining.
* Monica R P Ferreira, Agma Traina, Ires Dias, Richard Chbeir and Caetano Traina;
Identifying Algebraic Properties to Support Optimization of Unary Similarity Queries.

Session3

* Anish Das Sarma, Jeffrey Ullman and Jennifer Widom;
Schema Design for Uncertain Databases.
* Leopoldo Bertossi;
From Database Repair Programs to Consistent Query Answering in Classical Logic (extended abstract).
* Leopoldo Bertossi, Loreto Bravo and Monica Caniupan;
Consistent Query Answering in Data Warehouses.

Session4

* David Toman;
Data Expiration and Aggregate Queries.
* Loreto Bravo and M. Andrea Rodriguez;
Semantic Integrity Constraints for Spatial Databases
* Md. Anisur Rahman, Mehedi Masud, Iluju Kiringa and Abdul Motaleb El Saddik;
Bi-Level Mapping: Combining Schema and Data Level Heterogeneity in Peer Data Sharing Systems

Graduate Student Workshop (May 15)
Tutorial:

* Alberto Laender; Web Data Extraction: Methods and Tools

Session 5

* Alejandro Mallea;
Understanding the structure of RDF data: a practical study (PDF)
* Juan Reutter;
Extending Query Languages for Data Exchange (PDF)
* Jorge Perez;
Metadata Management in Data Exchange Systems (PDF)

sábado, 2 de mayo de 2009

Que es lo que opino de documento Lectura01?

Opinion Sobre El Articulo El to Computacional

viernes, 1 de mayo de 2009

Lectura 2: Mas allá del pensamiento computacional

Beyond Computational Thinking

Lectura 1: El pensamiento Computacional

Computational Thinking

martes, 21 de abril de 2009

Buenas practicas de utilizacion de casos de uso

Algo que al inicio no tenemos claro cuando estudiamos UML y RUP es ¿como escribir correctamente un caso de uso?, bien personalmente tenía ciertas dudas al comienzo, pero leyendo y encontrando el siguiente artículo, creo que nos hace notar los errores que pudimos incurrir en algunas ocaciones. :(

Buenas Malas Practicas CU

Material audio-visual lenguaje c

Hola a todos ;) , a los interesados en ver un curso de lenguaje c, dejo una url en z0neb1t, solo tenemos que registrarnos, dejo esto pensando en una forma de tener una ayuda audio-visual para un lenguaje muy usado en la enseñanza de algoritmos.

Saludos cordiales.

sábado, 18 de abril de 2009

Comienzo de la Maestria en Ciencias de la Compu

Hola, de tiempo estoy escribiendo algo, quisiera comenzar diciendo que se va a dar inicio de la maestria en ciencias de la computacion en la Universidad Nacional de Ucayali, el cual cursare y pienso publicar algunos articulos sobre el tema, me pidieron un tema para desarrollar y creo que ya tengo uno ;) se los contare en el transcurso.

Saludos cordiales.
Enlace: maestria ciencias computacion unu

sábado, 14 de febrero de 2009

Introduccion a UML

UML

jueves, 12 de febrero de 2009

Desarrollo en Capas

viernes, 16 de enero de 2009

Funciones en PostgreSQL

Funciones en PostgreSQL

miércoles, 14 de enero de 2009

AjaxTags






Ajax Tags

Autor: Hugo Flores
hpfloresj@gmail.com
http://hpfloresj.blogspot.com
Fecha: 14-12-2008


Introduccion


Ajax Tags es una biblioteca de etiquetas JSP que nos simplifican el uso de AJAX.

Esta biblioteca no necesita forzar al desarrollador J2EE a escribir codigo javascript para implementar una capacidad Ajax en un formulario web.

Esta libreria proporciona soporte para los siguientes casos:

  • Autocomplete
  • Callout
  • HTML Content replace
  • Select/Dropdown
  • Tab Panel
  • Update field
  • Area y Anchor
  • Ajax DisplayTag
  • Editor
  • Tree

Pros
  • Fácil de usar.
  • Puede extender funcionalidades de manera facil con funciones post y pre condiciones
Contras
  • Moderadamento dificultoso extender core tags
  • Soporte y actualizaciones inciertos.
Para este articulo veremos la aplicación de Ajax con AjaxTags(Select/Dropdown), en un articulo anterior Introduccion a Ajax vimos algunes funciones javascript ahora haremos algo mas rapido y sencillo.

Recordaremos utilizar bibliotecas de etiquetas que ya vimos también.

Integrando AjaxTags en su aplicación caso: Select/Dropdown

Requerimientos
  • JDK 1.5+
  • Servlet container running Servlets 2.4+ and JSP 2.0+
  • AjaxTags dependencies
  • Maven 2 (Si usted intenta construir desde el codigo)
Download
Configuración
  • Para la configuracion seguiremos los pasos vistos en item "Usando una biblioteca de etiquetas en su aplicación" del artículo Tag Libreries
Copiar el fichero ajaxtags-1.3-beta-rc7.jar al directorio WEB-INF/lib
  • Copiar el fichero ajaxtags.tld al directorio WEB-INF/

  • Agregar al descriptor de despliegue /WEB-INF/web.xml la siguiente entrada:
<taglib>
<uri>http://ajaxtags.org/tags/ajax</uri>
<location>/WEB-INF/ajaxtags.tld</location>
</taglib>

Esto ya no es necesario para contenedores de Servlets 2.4


Librerias jar dependientes que hay que tener en cuenta para poder hacer correr bien nuestros programas que utilicen AjaxTags:

* Librerias comunes(obligatorias)

ajaxtags-1.3-beta-rc7.jar
commons-beanutils-1.7.0.jar
commons-lang-2.3.jar
commons-logging-1.1.1.jar
// servelts
jsp-api-2.0.jar
servlet-api-2.4.jar
//taglibs
standard.jar
jstl.jar

* Librerias comunes(opcionales segun requerimeinto)

commons-collections-3.2.jar
jericho-html-2.4.jar
displaytag-1.1.jar
displaytag-export-poi-1.1.jar
displaytag-portlet-1.1.jar
itext-2.0.4.jar
poi-scratchpad-3.0-rc4-20070503.jar
poi-3.0-rc4-20070503.jar
poi-contrib-3.0-rc4-20070503.jar

Lo mejor para no tener problemas es copiar los ficheros jar que vienen en ajaxtags-1.3-beta-rc7-bin.zip dentro de lib.
  • Es necesario tener en nuestro proyecto otros frameworks javascript que se encuentran en ajaxtags-1.3-beta-rc7-bin.zip, copiar dichos ficheros desde ajaxtags-1.3-beta-rc7\web\js a {app_name}/public/js

  • Copiar desde ajaxtags-1.3-beta-rc7-bin.zip el directorio web\css a {app_name}/public/css
Con todo esto tenemos configurado los ficheros que necesita AjaxTags, sigamos ;)

Creando el Servlet que devuelve una respuesta XML

AjaxTags recibe XML que tenga el siguiente formato:

<?xml version="1.0" encoding="UTF-8"?>
<ajax-response>
<response>
<item>
<name>Registro 1</name>
<value>1</value>
</item>
<item>
<name>Registro 2</name>
<value>2</value>
</item>
<item>
<name>Registro 3</name>
<value>3</value>
</item>
</response>
</ajax-response>
Esta es la respuesta del Servidor a la peticion Ajax, AjaxTags tiene la capacidad de leer este XML, además AjaxTags tambien soporta contenido HTML.

Pero de donde obtenemos estos datos XML? Creando las clases y metodos necesarios desde una base de datos. Usaremos la base Recursos Humanos de PostgreSQL.



  • Crearemos primero el método listEmployeesBySearchDepartment(int departmentID) de la clase Employees, metodo que lista todos los empleados segun el codigo de departamento que se le pasa. Hay que indicar que se tiene que añadir un atributo mas a esta clase del tipo Departments department, agregar los getters y setters a los constructores y al metodo find() quedando de la siguiente forma:

public Employees find( int employeeId ){
Employees objEmployees = null;

Connection con = null;
PreparedStatement ps = null;
ResultSet rs = null;

try{
con = cf.getConnection();
ps = con.prepareStatement("SELECT employee_id,first_name,last_name,email,phone_number, cast(to_char(hire_date,'DD-MM-YYYY') as character varying),job_id,salary,commission_pct,manager_id,department_id FROM employees WHERE employee_id = ?" );
ps.setInt( 1, employeeId );
rs = ps.executeQuery();
if( rs.next() ){
objEmployees = new Employees( rs.getInt(1),
rs.getString(2),
rs.getString(3),
rs.getString(4),
rs.getString(5),
rs.getString(6),
rs.getString(7),
rs.getInt(8),
rs.getDouble(9),
rs.getInt(10),
new Departments( rs.getInt(11), "" )
);
}

}catch( SQLException sqle ){
sqle.printStackTrace();
}finally{
ConnectionFactory.closeAllConnections(con, ps, rs);
}
return objEmployees;
}



  • Veamos como se implementa el metodo listEmployeesBySearchDepartment().

public List<Employees> listEmployeesBySearchDepartment( int departmentId ){
List<Employees> listEmployees = null;

Connection con = null;
PreparedStatement ps = null;
ResultSet rs = null;

try{
con = cf.getConnection();
ps = con.prepareStatement("select employee_id, first_name, last_name from employees where department_id = ? ");
ps.setInt( 1, departmentId );
rs = ps.executeQuery();
if( rs != null ) listEmployees = new ArrayList<Employees>();
while( rs.next() ){
listEmployees.add( new Employees( rs.getInt(1),
rs.getString(2),
rs.getString(3),
"",
"",
"",
"",
0,
0.0,
0,
null )
);
}

}catch( SQLException sqle ){
sqle.printStackTrace();
}finally{
ConnectionFactory.closeAllConnections(con, ps, rs);
}

return listEmployees;
}

  • Ahora implementaremos la clase Departments, con su metodo listDepartments(),que lista todos los departamentos de la empresa.
package dominio;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Types;

import com.hpfloresj.util.Keyboard;
import com.hpfloresj.persistencia.ConnectionFactory;
import com.hpfloresj.persistencia.DAOFactory;
import com.hpfloresj.persistencia.ConfigDatabase;
import com.hpfloresj.persistencia.TypeDB;
import java.util.ArrayList;
import java.util.List;

/**
*
* @author Hugo
*/
public class Departments {
private int departmentId;
private String name;
private ConnectionFactory cf;

public Departments( ConfigDatabase conf ){
cf = DAOFactory.create( conf );
}


public Departments( int departmentId, String name ){
setDepartmentId(departmentId);
setName(name);
}

public List<Departments> listDepartments(){
List<Departments> listDepartments = null;

Connection con = null;
PreparedStatement ps = null;
ResultSet rs = null;

try{
con = cf.getConnection();
ps = con.prepareStatement("select department_id, department_name from departments");
rs = ps.executeQuery();
if( rs != null ) listDepartments = new ArrayList<Departments>();
while( rs.next() ){
listDepartments.add( new Departments( rs.getInt(1),
rs.getString(2) )
);
}

}catch( SQLException sqle ){
sqle.printStackTrace();
}finally{
ConnectionFactory.closeAllConnections(con, ps, rs);
}

return listDepartments;
}




/**
* @return the departmentId
*/
public int getDepartmentId() {
return departmentId;
}

/**
* @param departmentId the departmentId to set
*/
public void setDepartmentId(int departmentId) {
this.departmentId = departmentId;
}

/**
* @return the name
*/
public String getName() {
return name;
}

/**
* @param name the name to set
*/
public void setName(String name) {
this.name = name;
}
}



Bien ahora que tenemos los métodos veamos como podemos contruir nuestro Servlet, pero con AjaxTags:


package servlets;

import com.hpfloresj.persistencia.ConfigDatabase;
import com.hpfloresj.persistencia.TypeDB;
import dominio.Employees;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.ajaxtags.servlets.BaseAjaxServlet;
import org.ajaxtags.xml.AjaxXmlBuilder;
/**
*
* @author Hugo
*/
public class DropSelectAjax extends BaseAjaxServlet {


public String getXmlContent( HttpServletRequest request, HttpServletResponse response )
throws Exception
{

int departmentId = 0;
ConfigDatabase conf = new ConfigDatabase("127.0.0.1", "hr",5432,
TypeDB.POSTGRE,
"postgres",
"admin");
try{
departmentId = Integer.parseInt( request.getParameter("id") );
}catch( NumberFormatException nfe ){
System.out.println( nfe.getMessage() );
}
Employees objEmployees = new Employees( conf );

List<Employees> lista = objEmployees.listEmployeesBySearchDepartment( departmentId );

AjaxXmlBuilder xml = new AjaxXmlBuilder();

for( Employees item : lista ){
xml.addItem( item.getFirstName()+ " " + item.getLastName(),String.valueOf( item.getEmployeeId() ) );
}
//xml.addItems(lista,"producto", "id");
System.out.println(xml.toString() + " -- ");
return xml.toString();
}

}

Añadimos el Servlet al descriptor de despliegue:


<servlet>
<servlet-name>DropSelectAjax</servlet-name>
<servlet-class>servlets.DropSelectAjax</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>DropSelectAjax</servlet-name>
<url-pattern>/DropSelectAjax</url-pattern>
</servlet-mapping>

Si compilamos y ejecutamos el Servlet: http://localhost:8084/ajaxTags/DropSelectAjax?id=80





Vista accediendo a nuestro XML mediante AjaxTags
En este ultimo paso diseñaremos la vista y los describiremos los metodos necesarios para llamar al Servlet mediante AjaxTags.



1. Importamos las clases que utilizaremos


<%@page import="dominio.*" %>
<%@page import="com.hpfloresj.persistencia.*" %>
<%@page import="java.util.List" %>

2. creamos un fichero selectAjax.jsp y declaramos la biblioteca de etiquetas Ajax Tags

<%@ taglib uri="http://ajaxtags.org/tags/ajax" prefix="ajax"%>


3. Declaramos el TLD de la biblioteca de etiquetas JSP(JavaServer Page Stantard Tag Library)
JSTL encapsula etiquetas simples que proporcionan funcionalidad comunes a muchas aplicaciones Web. JSTL trabaja con estructura de tareas,
iteraciones y condiciones, etiquetas para manipular documentos XML, internacionalizacion de etiquetas y etiquetas SQL.

Tambien proporciona un framework para integrar etiquetas personalizadas existentes con etiquetas JSTL.
JSTL 1.2 es parte de la plataforma Java EE 5.

Referencias:


<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>

<c:set var="contextPath"><%=request.getContextPath() %></c:set>


En esta ultima linea estamos declarando una variable etiqueta JSP que almacenara el contexto de nuestra aplicacion en "contextPath"



4. Importar los CSS y Javascripts



<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>JSP Page</title>
<%-- IMPORTAR LIBRERIAS JAVASCRIPT --%>
<script type="text/javascript" src="${contextPath}/public/js/prototype.js"></script>
<script type="text/javascript" src="${contextPath}/public/js/scriptaculous/scriptaculous.js"></script>
<script type="text/javascript" src="${contextPath}/public/js/ajaxtags/ajaxtags.js"></script>
<script type="text/javascript" src="${contextPath}/public/js/ajaxtags/ajaxtags_parser.js"></script>
<script type="text/javascript" src="${contextPath}/public/js/ajaxtags/ajaxtags_controls.js"></script>



<%-- IMPORTAR HOJAS DE ESTILOS(OPCIONAL PARA AUTO-COMPLETES) --%>
<!--<link type="text/css" rel="stylesheet" href="{contextPath}/public/css/ajaxtags.css" />-->
<link type="text/css" rel="stylesheet" href="${contextPath}/public/css/site.css" />

</head>



5. El resto de nuestro JSP creamos nuestra etiqueta HTML Select y las etiquetas Ajax


<body>
<form action="." class="basicForm">
<fieldset>
<legend>Escoger Departamento</legend>
<label for="id">Departamento:</label>
<select id="id">
<option value="">Selecionar</option>
<%
ConfigDatabase conf = new ConfigDatabase("127.0.0.1", "hr",5432,
TypeDB.POSTGRE,
"postgres",
"admin");
Departments dep = new Departments(conf);
List<Departments> lista = dep.listDepartments();
for( Departments item : lista){
%>
<option value="<%= item.getDepartmentId() %>"><%= item.getName() %></option>
<%
}
%>
</select>
<span id="progressMsg" style="display:none;"><img alt="Indicator" src="<%=request.getContextPath()%>/public/images/indicator.gif" /> Cargando...</span>

<label for="empleados">Empleados:</label>
<select id="listaEmpleados" disabled="disabled">
<option value="">Seleccionar Empleado</option>
</select>
</fieldset>
</form>
<div id="errorMsg" style="display:none;border:1px solid #e00;background-color:#fee;padding:2px;margin-top:8px;width:300px;font:normal 12px Arial;color:#900"></div>
<script type="text/javascript">
/*
* USER DEFINED FUNCTIONS
*/
function initProgress() {
Element.show('progressMsg');
}

function resetProgress() {
// show marker emblem
//var index = $('tipo').selectedIndex;
//var automaker = $('tipo').options[index].text;
Effect.Fade('progressMsg');
}

function reportError() {
if ($('listaEmpleados').options.length == 0) {
$('errorMsg').innerHTML = "Dropdown busted!";
}
Element.show('errorMsg');
setTimeout("Effect.DropOut('errorMsg')", 2500);
}
</script>
<ajax:select
baseUrl="${contextPath}/DropSelectAjax"
source="id"
target="listaEmpleados"
parameters="id={id}"
preFunction="initProgress"
postFunction="resetProgress"
emptyOptionName="Selecionar empleado"
errorFunction="reportError"
parser="new ResponseXmlParser()"/>
</body>
</html>

Funcionamiento



En primer lugar cargamos el select que contendra un listado de todos los departamentos que existe en nuestra "empresa"

La etiqueta más importante aqui es <ajax:select />, etiqueta hace referencia al evento de seleccionar datos que estan relacionados si.


baseURL: contiene el Servlet que procesara la petición Ajax y que devuelve una respuesta en formato XML.
source: Campo Select inicial que manda la peticion Ajax
target: Campo Select donde el valor retornado mediante Ajax se mostrara.
parameters: Lista de parametos separados por coma que se pasan al Servlet.
Notar que tiene corchetes parameters = "id={id}"
Esta sintaxis tiene la siguiente forma si no utilizariamos Ajax:
http://localhost:8084/ajaxTags/DropSelectAjax?id=80
donde {id} es el identificador HTML de la etiqueta Select
preFunction: Funcion que se ejecuta antes de usar Ajax.(Mostramos un inidicar "Cargando...")
postFunction: Funcion que se ejecuta después de finalizado Ajax.(Ocultamos el mensaje indicador)
emtyOptionName: Si no existe datos mostramos un mensaje en el segundo Select
errorFunction: Funcion que nos muestra un error si en caso el Server no puede devolvernos una respuesta.
parser : Tipo de respuesta a nuestra peticion (Por defecto: ResponseHtmlParser)


Ejecutemos nuestro ejemplo:













Bien, hemos llegado al final del articulo, espero que les sea de utilidad.

Un saludo ;).


A continuacion anexo el código fuente.

Download source code

Download database example

JAR Connection Library

martes, 13 de enero de 2009

Algo de buen diseño para quienes les gusta

The Woork Papers N1 | Structured process you must know to develop a web application

Triggers en PostgreSQL

Triggers en PostgreSQL

lunes, 5 de enero de 2009

SEO3


SEO usando PHP: Expresiones regulares. Video 3 from Deyby Vasquez on Vimeo.

SEO2


SEO usando PHP video 2 http://loquenecesita.com from Deyby Vasquez on Vimeo.

SEO1


SEO usando PHP video 1 http://loquenecesita.com from Deyby Vasquez on Vimeo.

viernes, 2 de enero de 2009

Entorno de Desarrollo Java y Gis Parte1



Download script tomcat

En la segunda, parte instalaremos PostgreSQL, PostGIS, MapServer y sus librerias dependientes, PMapper framework MapScript escrito para trabajar con MapServer.

jueves, 1 de enero de 2009

Intro a Ajax