viernes, 1 de enero de 2010

actions en struts2

Bueno en este pequeño articulo vamos hablar de
las acciones en struts, una accion es una una clase
de java normal, en las cuales podemos tener metodos,
atributos, etc., pero
tenemos que respetar las
normas de los javaBean.

como primera observacion podemo decir que si
tenemos una sobrecarga de contructor es necesario
escribir el contructor implicito, puesto que si no
tendremos problema de ejecucion , una accion puede
ser llamada por multiples acciones y como otro
detalle podemos decir que struts2 por defecto
no crea un objeto HttpSession, pero añadiendo

en la pagina jsp el siguiente tag


<%@page session="false"%>

lo tenemos resuelto

nuestra clase accion debe heredar de La Clase
ActionSupport
, esta clase nos proporciona unos
campos estaticos que son utilizados constatementes
en nuestra configuracion struts.xml , estos campos
son importantes porque al principio podemos verlos
en el archivo de configuracion y no saber a que se
referencia.

SUCCESS: el proceso es un exito y se accede a

la peticion del usuario.

NONE : Indica que la ejecución de la acción fue un éxito,

pero el resultado no es mostrado al usuario.

ERROR: Indica que la ejecución de la acción fracasó.


INPUT: la validacion no corresponde y la entrada

del usuario se debe tomar denuevo.


LOGIN: Indica que la acción no se pudo ejecutar

porque el usuario no ha iniciado la sesión.


estos parametros son utilizados en el archivo de configuracion

struts.xml



miércoles, 30 de diciembre de 2009

interceptors en struts2



Los interceptores en struts2 son procedimientos que se ejecutan
antes o despues que se invoque una accion, existen algunos
definidos que podemos utilizar directamente o crear nuevas e
implementarlas, estos dos esquemas que tenemos nos sirve
para entender mejor los famosos interceptor de struts2.

Pero que mejor que un ejemplo para entender mejor este
concepto.

vamos a desarrollar un programa que pasa una palabra de una
pagina a otra y que el momento de hacer la solicitud de cambio
de pagina nos muestre un mensaje que se ejecuta
automaticamente mediante un interceptor.

1.- primiero vamos a crear nuestra pagina inicio, como siempre
la pagina index.jsp


<%@page contentType="text/html"%>
<%@page pageEncoding="UTF-8"%>

<%@ taglib uri="/struts-tags" prefix="s" %>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>struts2</title>

</head>

<body>

<h1>traspasar la siguiente palabra</h1>

<s:form action="proceso">

<s:textfield name="palabra" label="palabra"/>

<s:submit/>

</s:form>

</body>

</html>


2.- creamos las siguientes clases

import com.opensymphony.xwork2.ActionSupport;

public class parametro extends ActionSupport {

private String palabra;

// @Override
public String execute() {
System.out.println("entro a axecute");
return SUCCESS;
}

public String getPalabra() {
return palabra;
}

public void setPalabra(String palabra) {
this.palabra = palabra;
}
}

-------------------------------------------
esta clase es el interceptor, como cosas claves
podemos decir que implementa de la interfaz
Interceptor y el metodo invoke() es el que nos
delimita los procesos antes o despues de la accion.

import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.Interceptor;

public class PruebaInterceptor implements Interceptor{

public String intercept(ActionInvocation next) throws Exception {


String s= next.invoke();
System.out.println("intercept");

return s;
}

public void init() {
}
public void destroy() {
}
}

si colocamos el System.out.println("intercept"); antes de
String s= next.invoke(); se mostrara el mensaje antes de
System.out.println("entro a axecute"); encontrado en la
clase parametro

3.- creamos la pagina respuesta, que es la asociada a la accion
parametro.


<%@page contentType="text/html"%>
<%@page pageEncoding="UTF-8"%>

<%@ taglib uri="/struts-tags" prefix="s" %>
<html>
<body>

parametro <s:property value="palabra"/>

</body>
</html>

4.- ahora vamos a lo mas importante que seria
nuestro archivo strust.xml, el que tiene toda nuestra
configuracion.


<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>

<!-- Configuration for the default package. -->
<package name="default" extends="struts-default">

<interceptors>
<interceptor name="tiempo_servidor" class="PruebaInterceptor"/>

</interceptors>

<action name="proceso" class="parametro">

<interceptor-ref name="tiempo_servidor"/>
<interceptor-ref name="defaultStack" />

<result name="success" >/resultado.jsp</result>
</action>

</package>
</struts>

de este codigo podemos decir que es importante que este
interceptor-ref name="defaultStack" en nuestra accion, puesto
que si no esta el parametro palabra no llega a nuestra pagina
respuesta.jsp

ahora al momento de ejecutar nuestro codigo, podemos
apreciar que a simple vista podemos ver que se pasa
el parametro desde una pagina a la otra, pero si vemos
nuestra consola podemos ver que se muestra lo siguiente.

entro a axecute
intercept

bueno trate de hacer un ejemplo lo mas sencillo, para
entender e iniciar los conocimientos de este framework,
creo que lo mas recomendable es leer mucho y tratar
de entender como funciona para evitar estar pegado en
problemas de configuracion, principalmente en el
archivo struts.xml

martes, 29 de diciembre de 2009

struts.xml

Struts2 utiliza un archivo de configuración llamado
struts.xml, este archivo xml es utilizado para iniciar
los recursos del proyecto. Que pueden ser interceptors,
actions, results y otros , también se pueden definir
variables globales, validaciones ósea en pocas palabras
es como el corazon de nuestro proyecto.

se puede trabajar con mas archivos xml, pero todos
tienen que estar incluidos en el archivo struts.xml
de la siguiente forma include file (de forma de tag),
separar este archivo en mas pequeño creo que es
recomendable cuando estamos presentes de un
proyecto muy grande, porque así nos quedaría mas
ordenado y mas fácil de trabajar, se podria de decir
que realizamos un modularizacion de nuestro archivo.

en la practica el archivo yo siempre lo guardo en src
no es necesario tenerlo guardado en la carpeta web-inf
tenemos que tener en cuenta que la estructura de nuestro
struts.xml tiene que respetar las reglas de formato de un
xml, puesto que será trasformado a DTD (archivo xml
bien formado, es como un validador de nuestro archivo xml
y sirve para recorrerlo )para poder leer, en mi copa
experiencia me he percatado que muchos errores son
generados al formar mal o definir mal este famoso archivo,
tenemos que en cuenta que la lectura de este archivo
es secuencial.

además existe el archivo strustdefault.xml y
struts-plugin.xml, estos dos archivos se incluyen
implicitamente (un parecido a la clase Object ) y
tienen la configuracion por defecto y son cargados
en el inicio, en la practica puedo decir que no se ven
en nuestro proyecto, yo trabajo con netbeans, y a
veces con eclipce, pero muy poco

viendo la estructura de este archivo podemos
ver que su principal tag es , ósea su
raíz y dentro de ella encontramos otras como:

package este define el grupo de trabajo, su
tag es podemos compartir atributos
o utilizarlos de forma organizativa, una condición
obligatoria es su nombre y una de sus caracteristicas
es que se puede extender

siguiendo con algunas etiquetas importantes,
podemos encontrar la tag bean, estos son creados
por el por el framework e utilizado y por ultimo
vamos hablar de las constantes(constant), esta
son muy útiles, ya que pueden ser usadas para
definir configuraciones, puede definir que tipo de
bean se debe utilizar, etc . Como dato podemos
decir que en el archivo web.xml los parametros
de inicialización FilterDispatchir se cargan como
constantes. este famoso FilterDispatcher es el punto
de entrada de nuestro proyecto y se configura en
el archivo web.xml

para trabajar con las constantes debe estar
devMode=true, bueno esto lo pueden ver en los
miles de ejemplos que se pueden encontrar en
internet, pero ya saben a que se refiere esta
configuración.

como siempre voy a dejar su buen link, para entrar
en detalle mas sobre strust2, porque podemos encontrar
muchos ejemplos pero si no entendemos lo que hacemos
vamos a dar siempre palos de ciego

link : struts2 muy bueno este link y esta en español, explica bien
la arquitectura de este framework y con solo ver la siguiente imagen
podemos entender muchas cosas de este framework.

sábado, 26 de diciembre de 2009

Empezando con struts 2

espero dar varios ejemplos de este framework, y para comenezar
tenemos que añadir struts2 a nuestro netbeans y entender como
funciona.

el link oficial es struts2

pero no prentendo explicar este framework porque existe muchos
blog y paginas que explican, solamente en este articulo pretendo
dar el punto de inicio para comenzar a trabajar con este framework.

1.-encontre este blog que explica de forma buena como empezar
Aqui

2.- como siempre tenemos que comenzar con el famoso "hola
mundo " jejeje aqui esta el link (la idea no es escribir ya mas de lo
mismo, mejor aprobechamos lo que existe.)

3.- y por ultimo este link explicando varias etiquetas link



viernes, 25 de diciembre de 2009

segundo ejemplo de jquery con jsp


el siguiente ejemplo utilizaremos jsp con jdbc , hoja de estilo,
se trata de ir capturando un texto, guardarlo y rescatarlo, para
despues mostrarlo en secuencia hacia abajo

insert.jsp


<%@page contentType="text/html"%>

<%@page pageEncoding="UTF-8"%>

<%@ page language="java" import="java.sql.*" errorPage="" %>

<script type="text/javascript" src="js/jquery-1.3.1.js">

</script>

<link rel="stylesheet" href="code.css" type="text/css" media="all" />

<script type="text/javascript" >

$(function() {

$(".update_button").click(function() {

var boxval = $("#content").val();

var dataString = 'content='+ boxval;

if(boxval=='')
{
alert("introduzca texto");

}else

{
$.ajax({

type: "POST",
url: "demo.jsp",
data: dataString,
cache: false,
success: function(html){

$("ol#update").prepend(html);
$("ol#update li:first").slideDown("slow");
$("#content").value('');
$("#content").focus(); $("#flash").hide();
}
});

} return false;
});
});

</script>
<div>
<form method="post" name="form" action="">
<h3>ingrese Comuna</h3>
<textarea cols="30" rows="2" name="content" id="content" maxlength="145" >
</textarea><br />
<input type="submit" value="Ingresar" name="submit" class="update_button"/>
</form>
</div>
<div id="flash"></div>
<ol id="update" class="timeline">
</ol>

demo.jsp


<%@page contentType="text/html"%>
<%@page pageEncoding="UTF-8"%>
<%@ page language="java" import="java.sql.*" errorPage="" %>
<%

String content=request.getParameter("content");
try{
Class.forName("org.postgresql.Driver");
Connection con =
DriverManager.getConnection
("jdbc:postgresql://localhost/ejemplo","postgres","1234");
Statement st = con.createStatement();
int i=st.executeUpdate
("insert into comuna(nombre) values('"+content+"')");

ResultSet rs=st.executeQuery
("select * from comuna order by nombre desc");

if(rs.next())
{
while(rs.next())
{
String msg=rs.getString("nombre");
%>
<li>
<div align="left">
<span ><%= msg %> </span>
</div>
</li>
<%
}
}else{

out.println("error");}
}
catch(Exception e){

Exception ex = e;
out.println("error de conexion con postgres:"+ex);
}
%>

la base de dato es una tabla sencilla llamada comuna,
con un campo llamado nombre y nada mas.

ahora creamos la hoja de estilo en
netbeans lo podemos crear en nuevo, web ,
cascading style sheet.

root {
display: block;
}

*{margin:0;padding:0;}
ol.timeline{
list-style:none;font-size:0.8em;
}

ol.timeline li{
display:none;position:relative;
padding:.7em 0 .6em 0;
border-bottom:1px dashed #000;
line-height:0.8em;
background-color:#D3E7F5;
height:25px}

ol.timeline li:first-child{
border-top:1px dashed #000;}


encontre estos ejemplos muy intersantes tambien como son:

auto llenado de un text con java link
para entrar mas en detalle tenemos este otro link,
ademas este ejemplo el cual es un combo dependiente con jsp y
ajax link y por ultimo para entrar mas endetalle de jquery link



org.apache.commons

esta es una libreria super interesante y nos puede ayudar
mucho en nuestro desarrollo, para utilizar esta libreria
debemos bajar el jar correspondiente, el cual lo
podemos encontrar aqui

esta libreria nos brinda ayuda en manejo de String,
numeros, fecha, etc.

despues de bajar el jar lo agregamos a nuestro
proyecto y estamos listos para utilizarlo.

en el siguiente link podemos encontrar mas detalle sobre esta libreria

transmision de datos mediante ajax con jquery

vamos a desarrollar el siguiente ejemplo
a diferencia del ejemplo anterior es que ahora vamos a trabajar
con un archivo estructurado , ademas vamos a trabajar con
un controlador para nuestro ejemplo. pero vamos al ejemplo.

1.- primero vamos a crear nuestra clase libro, encapsulada
como dios manda, solomante los get de los atributos de la
clase, puesto que vamos a setiar mediante un contructor.

public class libro {
private String titulo;
private String tipo;
private int qty;
private String comentario;

libro(){
}

libro(String titulo,String tipo, int qty, String comentario){

this.titulo=titulo;
this.tipo=tipo;
this.qty=qty;
this.comentario=comentario;

}

public String getTitulo() {
return titulo;
}

public String getTipo() {
return tipo;
}

public int getQty() {
return qty;
}

public String getComentario() {
return comentario;
}

}


2.- como segundo paso creamos la clase libros, el cual
nos gestionara los objetos de la clase libro.

import java.util.*;


public class libros {

Map books = new LinkedHashMap();

public libros() {

books.put(11, new libro(
"Java Swing", "java", 1 ," para aplicaciones de escritorio"));
books.put(27, new libro(
"php","daniel",1," libro para iniciar php"

)
);

}
public libro fetch(int id) { return books.get(id); }
public Set fetchIds() { return books.keySet(); }

}

3.- despues vamos a crear nuestro archivo getbook_as_table.js de
tipo javascript y añadimos lo siguiente.

$(function() {
$("#button").click(function() {
$.ajax({
type: "GET",
url: "book_table.jsp",
data: { id: $("#sel").val() },
success: function(data) {
$("#out").html( data )
}
})
})
})

4.- ahora vamos a crear las paginas jsp, la primera sera
getbook_as_table.jsp


<%@page contentType="text/html"%>

<%@page pageEncoding="UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"

"http://www.w3.org/TR/html4/loose.dtd">

<%@ page import="java.util.*" %>

<%@ page import="modelo.*" %>

<jsp:useBean id="books" scope="session" class="modelo.libros"/>

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>Seleccion de libro </title>

<script type="text/javascript" src="js/jquery-1.3.1.js"></script>

<script type="text/javascript" src="js/errors.js"></script>

<script type="text/javascript" src="js/getbook_as_table.js"></script>

</head>

<body>

<h3>Buscar libro</h3>

<select id="sel">

<% for( Integer i: books.fetchIds() ) { %>

<option value="<%=i%>"><%=i%></option>

<% } %>

</select>

<button id="button">Buscar libro</button>

<br /><br />

Seleccion de libro:

<div id="out"></div>

</body>

</html>

y por ultimo la pagina book_table.jsp


<%@page contentType="text/html"%>

<%@page pageEncoding="UTF-8"%>

<%@ page import="modelo.*" %>

<jsp:useBean id="libros" scope="session" class="modelo.libros"/>

<%

String id = request.getParameter("id");

int num_id = Integer.parseInt(id);


libro book = libros.fetch(num_id);

String comentario = book.getComentario();

String titulo = book.getTitulo();

String tipo = book.getTipo();

int qty=book.getQty();

%>

<table border="1" cellpadding="5">

<tr>

<td>Titulo:</td> <td><%=titulo%></td>

</tr>

<tr>

<td>tipo:</td> <td><%=tipo%></td>

</tr>

<tr>

<td>qty:</td> <td><%=qty%></td>

</tr>

<tr>

<td>comentario:</td> <td><%=comentario%></td>

</tr>

</table>

sobre el codigo, si no entienden como trabaja useBean pueden buscar
en este blok como se trabaja. Aqui

jueves, 24 de diciembre de 2009

Ejemplo de jquery seleccion en base a un combobox

en el articulo anterior solamente explique una introduccion,
pero realmente lo que importa es la implementacion es por
ello que vamos a dar unos ejemplos que encontre muy
interesante para empezar a entender mejor lo que es jquery
y como trabajar con ella.

primero tenemos que tener nuestro proyecto con la
carpeta js en la cual encontramos jquery-1.3.1.js, esto lo
podemos ver en el articulo anterior.

en la misma carpeta creamos un archivo para trabajar
con javascript esto lo hacemos asi:



creamos el archivo client_getperson y dentro de ella introducimos
el siguiente codigo:

$(function() {
$("#button").click(function() {
$("#out").html( $("#sel").val() )
})
})



luego en souce parckage creamos el paquete modelo,
en donde creamos la clase People

package modelo;

public class People {

private String people[]
= new String[] { "jorge", "felipe", "hector", "enzo", "sergio", };
public int getNumPeople() { return people.length; }
public String getPerson(int num) { return people[num]; }
}

ahora en nuestra pagina jsp


<%@page contentType="text/html"%>

<%@page pageEncoding="UTF-8"%>



<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"

"http://www.w3.org/TR/html4/loose.dtd">

<%@ page import="java.util.*" %>

<%@ page import="modelo.People" %>

<jsp:useBean id="people" scope="request" class="modelo.People"/>

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>Seleccion con javascript</title>

<script type="text/javascript" src="js/jquery-1.3.1.js"></script>

<script type="text/javascript" src="js/client_getperson.js"></script>

</head>

<body>

<h3>Seleccion de Persona</h3>

<select id="sel">

<% for( int i = 0; i < people.getNumPeople(); ++i ) { %>

<option value="<%=people.getPerson(i)%>"><%=i%></option>

<% } %>

</select>

<button id="button">Ver persona</button>

<br /><br />

Persona Seleccionada: <span id="out"></span>

</body>

</html>

y la salida nos queda asi:

bueno este es el ejemplo mas simple, pero el mismo de otra forma
mas completa es asi.


<%@ page import="java.util.*" %>

<%@ page import="modelo.People" %>

<jsp:useBean id="people" scope="request" class="modelo.People"/>



<html>

  <head>

    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

    <title>Selection con ajax</title>

    <script type="text/javascript" src="js/jquery-1.3.1.js"></script>

    <script type="text/javascript" src="js/server_getperson.js"></script>

  </head>

  <body>

    <h3>AJAX " Obtener Persona "</h3>



    <select id="sel">

      <% for( int i = 0; i < people.getNumPeople(); ++i ) { %>

      <option value="<%=i%>"><%=i%></option>

      <% } %>

    </select>

    <button id="button">buscar persona</button>

    <br /><br />

    persona Seleccionada: <span id="out"></span>

  </body>

</html>


en el archivo server_getperson.js temos que escribir :

$(function() {
$("#button").click(function() {
$.ajax( {
type: "GET", // the default
url: "GetPerson",
data: { id: $("#sel").val() },
success: function(data) {
$("#out").html( data )
}
} )

luego tenemos un servlet llamado GetPerson

import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import modelo.People;

public class GetPerson extends HttpServlet {

private People people = new People();


protected void processRequest(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
try {

String id = request.getParameter("id");
out.print(people.getPerson(Integer.parseInt(id)));

} finally {
out.close();
}
//.....
}

miércoles, 23 de diciembre de 2009

jquery con jsp


jquery es una libreria javascript que se esta utilizando mucho,
una de las caracteristicas de esta libreria es su version bien
comprimida y comparte muchas de caracteristicas de prototype
(una de las diferencias son la llamada de metodos).

en un link anterior explico un poco de ajax y si existe alguna duda
seria bueno ver este tema, ademas tengo unos link para profundizar
mas el tema.

http://ungranoparajava.blogspot.com/2009/05/empezando-con-ajax.html

si ya tenemos entendemos ajax o queremos ir directo a lo practico
podemos ver este manual de jquery muy bueno( en la pagina oficial
existe mucha documentacion e incluso en español)

http://www.librosweb.es/ajax/capitulo10/la_libreria_jquery.html

en el link anterior podemos encontrar tambien un manual de
prototype y de ajax, es muy bueno este link.

ahora vamos a los que nos reune jajajaja, a lo entretenido a lo
que es codigo.

como siempre vamos a utilizar nuestro netbeans y lo primero
que vamos hacer es un proyecto web, el cual no incluimos
ningun framework ( como hibernate, jsf, struts, etc aunque
se puede utilizar con jsf , struts , spring etc).

como podemos apreciar nuestro proyecto tiene una carpeta js, esta
la creamos en nuevo->otro->carperta. Para trabajar con esta libreria
tenemos que bajar el archivo jquery-1.3.1.js , esta es la version
pero podemos trabajar con la anterior que es la 1.2.1 bueno existen
muchas. este archivo lo guardamos en la carpeta js que creamos en
nuestro proyecto , asi de simple es.

y ahora trabajamos como uno lo hace con javascript , pero tenemos
que definir nuestro jquery en el codigo.


<%@page contentType="text/html"%>

<%@page pageEncoding="UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"

"http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<script src="js/jquery-1.3.1.js"></script>

<script type="text/javascript">

$(document).ready(function() {

alert("CARGADO");

});

</script>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>JSP Page</title>

</head>

<body>

<h1>JSP Page</h1>


podemos ver en el codigo anterior un pequeño ejemplo
de como implementar la libreria jquery en netbeans

En el siguiente link podemos ver que podemos
lograr con esta libreria , ejemplos buenos


Ahora vamos a dar un link de este ejemplo que esta muy bueno, la idea
es comunicar jsp y jquery. solamente date este link porque encontre
muy bueno el ejemplo para empezar y la idea no es copiar, sino reutilizar
codigo jejejej la idea es dar una manito a la comudidad java.

http://rekkeb.wordpress.com/2009/03/15/comunicar-jsp-y-jquery/

como el tema es interesante creo que vamos a crear otra entrada sobre el tema, con unos ejemplos mas interesantes.




martes, 24 de noviembre de 2009

llamar un ejb desde un jsp

bueno llamar un ejb desde un servlet es sumamente facil y es una
de las facilidades que nos proporciona la version ejb 3 , pero desde
un jsp no es lo mismo puesto que hay que llamarlo mediante JNDI
(igual no es complicado)

primero vamos a crear nuestro ejb.


package ejb;

import javax.ejb.Remote;

@Remote
public interface saludoRemote {

public String saludo();
}

------------------------------------

package ejb;

import javax.ejb.Stateless;

@Stateless(name="saludoRemote")
public class saludoBean implements saludoRemote {

public String saludo() {

return "hola desde ejb";
}
}

asi nos queda el proyecto

ahora vamos a nuestro proyecto web



bueno desde un servlet solamente tenemos que llamarlo mediante
la opcion del boton derecho insert code->call enterprise bean
y seleccionamos nuestro ejb y nos genera el siguiente codigo

@EJB
private saludoRemote saludoBean;

el @EJB nos ahorra utilizar jndi, ademas este llamado tiene
que ser afuera de cualquier metodo de la clase servlet.

otra observacion que encontre en la red es la implementacion
distinta en el servidor glassfish y JBoss en el momento de ocupar
lookup en distintos servidores.

ejemplo: para jboss

Context context = new InitialContext();
HelloWorld helloWorld = (HelloWorld) context.lookup("HelloWorldBean/remote");

ejemplo: para glassfish

Context context = new InitialContext();
HelloWorld helloWorld = (HelloWorld) context.lookup(HelloWorld.class.getName());

jueves, 19 de noviembre de 2009

Struts 1.x y Struts 2.x

los cambios que podemos encontrar entre estas dos
versiones son muy importantes, como primera impresion
puede decir que no es la misma. Las principales diferencias
son :


Dependencia del Servlet :

Las acciones en Struts1 tienen dependencias con el servlet
( HttpServletRequest y HttpServletResponse) estos objetos
se pasan al método de ejecución, en Struts 2, "Acciones no son
dependientes de contenedores porque están hechos POJOs simple.
En Struts 2, los contextos de servlets son representados como
mapas sencillos, tambien
las acciones se puede acceder a la
solicitud original
.

Acction class

Se soluciono el problema de las clases abstractas en Struts 2, en
Struts1 la clase de accion necesita ampliar el marco puesto que
depende de la clase base abstracta.
Pero en el caso de Struts 2,
la clase de acción puede implementar interfaces
En el caso de Struts 2, "Acciones no son dependientes de contenedores
porque están hechos POJOs simple.
Struts 2 proporciona una
clase ActionSupport base para implementar interfaces de uso común.
Si bien, la interfaz de acción no es necesario. Cualquier objeto POJO
con una ejecución de la firma puede ser utilizado como un
objeto de 2 Struts Acción.

Validación

En las dos versiones podemos hacer validaciones manuales, en
Struts1 se utiliza el método de la ActionForm, o valida a través
de una ampliación de la Validator Commons.
Sin embargo, Struts 2,
Se utuliza el marco de validación XWork.
El marco de validación Xwork
apoya el encadenamiento de validación.


Modelo de subprocesos

En Struts1, los recursos de acción deben ser flujos seguros o sincronizada.
Lo que las acciones son únicos y multi-hilo,
El patron de diseño Singleton se
impone,
en caso de Struts 2, los objetos se crean instancias de acción para
cada solicitud, así que no hay hilo( esto genera menos impacto)


Comprobabilidad

Prueba de aplicaciones Struts1 son un poco complejo, pero Struts 2
Las acciones pueden ser probados.

recolección de entrada

Struts1 utiliza un objeto ActionForm para captar de entrada.
Y todos ActionForms necesita extender un marco de base
dependientes de clase.
JavaBeans no puede ser utilizado como
ActionForms, por lo que los desarrolladores tienen que crear
clases redundantes para captar de entrada.
Sin embargo Struts 2 utiliza las propiedades de acción (como las
propiedades de entrada independiente de la estructura subyacente)
que elimina la necesidad de un objeto, por lo tanto reduce la
redundancia.

Además, en struts2, las propiedades de acción se puede acceder desde
la página web a través de la taglibs.
Struts 2 también soporta el patrón
ActionForm, así como objetos de formulario POJO y Acciones POJO.



bueno existen mas diferencias pero considero que estas son las mas
importantes , despues cuando me maneje mas y encuentre que falta otro
modificare estos puntos.

Proyecto Strust en Netbeans

Para empezar a desarrollar en Struts, primero tenemos que
empezar con los conceptos basicos.

1.- primero vamos a crear nuestro proyecto en netbeans

En esta ultima ventana encontramos lo siguiente:

Action Servlet name : Aqui encontramos el descriptor de
despliegue web.xml, contiene una entrada para el servlet de
acción y especifica el Struts y sus parámetros específicos,
como la ruta de acceso a la clase servlet dentro de la biblioteca
Struts y el struts-config.xml de configuración.

Action Url Pattern :
Especifica los patrones de las solicitudes
de entrada que se asignan a la controladora de acciones de Struts


Aplication Resource:
Especifica los paquetes que seran utilizados
por struts-config.xml

Add struts TLDs: Le permite generar descriptores de
biblioteca de etiquetas,
Un descriptor de biblioteca de etiquetas es
un documento XML que contiene información adicional.


bueno ahora generado el proyecto encontramos lo siguiente:


aqui podemos ver que tenemos el archivo config-struts.xml , este
archivo es donde vamos a guardar nuestras configuraciones, con un
un formato xml, aqui podemos confgurar el action-mappings, form-beans
y muchas cosas mas.

Este archivo de configuracion es el cordinador de nuestro proyecto.

tambien podemos ver el archivo : ApplicationResource.propierties,
este archivo vamos a guardar propiedades que seran llamadas
mediente la implementacion de nuestro proyecto, ej:

errors.usuario= La variable usuario ingresada no corresponde.

bueno existen mas archivos y los podemos apreciar, pero solamente
estamos empezando.

Otro proceso muy importante en el desarrollo de nuestro proyecto
es crear los ActionFormbeans y los Action estos lo podemos encontrar
aqui:


Para finalizar y entender mejor este framework, podemos apreciar
en la siguiente figura como es el comportamiento de nuestro
futuro proyecto.

lunes, 5 de octubre de 2009

manejo de table en jsf con hibernate

bueno este ejemplo es muy sencillo, vamos a llenar
una tabla de visual web de netbeans con los datos
de una tabla de base de datos.

primero tenemos que generar a configuracion de hibernate
con jsf(el cual se puede ver en http://ungranoparajava.blogspot.com/2009/10/jsp-con-framework-hibernate.html) y ademas tenemos que agregar
como framework el visual web.


aqui tenemos que tener en cuenta que ocuparemos Query y no
SQLquery, porque tenemos que ocuapar hql que corresponde al
primero que mencionamos, porque estamos trabajando con objetos.


despues en el metodo init añadimos la llamada
al metodo mostrarEmpresa()

@Override
public void init() {

super.init();

try {
_init();
} catch (Exception e) {
log("SessionBean1 Initialization Failure", e);
throw e instanceof FacesException ? (FacesException) e: new FacesException(e);
}

mostrarEmpresa();
}

la clase Empresa la encontramos aqui, que es la representacion


luego en la tabla buscamos la propiedad table layout

viernes, 2 de octubre de 2009

hibernate parte 2

En el ejemplo anterior vimos como se configura un proyecto jsp
y el framewor Hibernate, pero nos falto ver como guardar( insert)
en la base de datos, este proceso es muy sencillo y lo vamos a realizar
de la siguiente manera:

en la clase: consulta_empresa creamos un metodo guardar empresa

public String guardar_empresa(Empresa em){


try {
org.hibernate.Transaction tx = session.beginTransaction();
session.save(em);

tx.commit();
return "Empresa guardada";

} catch (Exception e) {
e.printStackTrace();
}


return "Error";
}
}

el tipo que retorna el metodo lo podemos dejar como nos mas
nos acomode, pero lo importate es que pasamos un objeto tipo
empresa que esta setiados sus parametros con los set que posee
este objeto que ya lo creamos y que es la representacion de la
de la tabla de la base de datos.

la clase consulta_empresa posee lo siguiente.

Session session = null;

public consulta_empresa() {
this.session = NewHibernateUtil.getSessionFactory().getCurrentSession();
}

y el newHibernateUtil es la clase que creamos anteriormente
(para entender bien es necesario ver el articulo anterior)

este es el codigo que tengo en una pagina jsp para poder llamar
el metodo guardar_empresa.
<% if(request.getParameter("guardar")!=null){ out.println("nombre: "+request.getParameter("nombre")); Empresa e=new Empresa(); e.setNombre(""+request.getParameter("nombre")); e.setDireccion(""+request.getParameter("direccion")); e.setRut(""+request.getParameter("rut")); consulta_empresa co=new consulta_empresa(); String respuesta; respuesta=co.guardar_empresa(e); out.println("br "); out.println("center "+respuesta+" /center"); } %>

Como paso siguiente es entrar a entender mejor el lenguaje que tiene
Hibernate HQL.

http://www.java2s.com/Code/Java/Hibernate/CatalogHibernate.htm

http://www.acsinet-solutions.com/es/tutoriales/hibernate/01-mapeo_sencillo.html

Mapeo Sencillo con Configuración Básica de Spring Framework:

http://www.acsinet-solutions.com/es/tutoriales/hibernate/02-mapeo_sencillo.html

jueves, 1 de octubre de 2009

JSP con Framework Hibernate

Hibernate es una herramienta que realiza el mapping entre el mundo
orientado a objetos de las aplicaciones y el mundo entidad-relación de
las bases de datos en entornos Java. El término utilizado es ORM
(object/relational mapping) y consiste en la técnica de realizar la
transición de una representación de los datos de un modelo relacional
a un modelo orientado a objetos y viceversa.

Hibernate no solo realiza esta esta transformación sino que nos proporciona capacidades para la obtención y almacenamiento de datos de la base de datos que nos reducen el tiempo de desarrollo.

la estructura de este framework la podemos ver en un articulo de mi blog :

http://ungranoparajava.blogspot.com/2009/06/arquitectura-de-la-persistencia.html

vamos a ver un pequeño ejemplo de este framework con jsp y como siempre con el IDE Netbeans

1.- creamos nuestro proyecto web

2.- asignamos el nombre , next y seleccionamos el framework hibernate y ademas la base de dato que vamos a trabajar

2.1- la base de dato tiene que estar registrada, como lo podemos ver en la figura

3.- añadimos estas dos configuraciones que se ven en la figura en el archivo hibernate.cfg.xml

la configuracion se puede ver en el formato de xml, es aqui donde se guardan
las configuraciones del framework.

4.- vamos a crear los objetos relacionados a la base de dato que seleccionamos

5.- ahora los generamos los hbm.xml de cada tabla que se encuentra relacionado con un objeto de tipo beans

5.1 asi nos queda el proyecto

6.- generamos la clase newhibernateUtil

7.- generamos una clase: consulta_empresa, la cual consta de un contructor y metodo que entrega una Query (obs: hibernate ocupa HQL para realizar consultas)

8.- ahora vamos a nuestro index e insertamos este codigo bien sencillo

para mayor informacion https://www.hibernate.org/

jueves, 24 de septiembre de 2009

JPA hibernate en netbeans

quiero dar una introduccion y ejemplo simple de como
implementar esta tecnologia, simpre recomiendo leer
un poco, porque si no vamos a dar puro jugo al intentar
de implementar estas tecnologias.

http://ubuntulife.wordpress.com/2008/10/20/introduccion-a-jpa-java-persistence-api/
http://www.slideshare.net/jamslug/introduccin-a-java-persistence-api
http://www.softwarelibre.net/ibatis_hibernate_y_jpa_%C2%BFcu%C3%A1l_es_el_que_tu_necesitas
http://www.roseindia.net/software-tutorials/detail/24071
http://www.roseindia.net/tutorialsearch/?t=jpa&image.x=0&image.y=0

bueno en el siguiente link tenemos un ejemplo
muy bueno pero con ejb
http://nachxs.wordpress.com/2009/04/28/tutorial-ejb-persistencia-y-postgresql-en-netbeans-65/

pero yo lo voy hacer sin un ejb

1: en nuestro proyecto web

2:
3:
Luego next, next

4: en nuestro nuevo servlet

ahora tenemos este codigo medular

en este codigo vamos ingresar datos a nuestra base de datos

-> dentro de nuestro servlet ingresamos el siguiente codigo

Empresa e=new Empresa();

e.setNombre("el mejor");
e.setDireccion("santiago");
e.setRut("1111");
persist(e); // llamamos a nuestro codigo anterior

recordar que las entidades son las representaciones de tipo beans de
nuestras tablas de nuestra base de dato

y por ultimo para recuperar informacion tenemos que ocupar
el objeto Query q = em.createNativeQuery....
todo este proceso es muy parecido al codigo mostrado en
la foto y para recorrerlo ocuparemos la coleccion List


martes, 22 de septiembre de 2009

datasource en jsp

bueno este ejemplo es muy similar a uno hecho con un servlet,
pero no tiene unas diferencias, los pasos son los siguientes




como siempre unos link que nos ayudara a entender mejor datasource

http://java.sun.com/j2se/1.4.2/docs/guide/jdbc/getstart/datasource.html
http://doc.postgresintl.com/jdbc/ch11.html
http://tomcat.apache.org/tomcat-4.1-doc/jndi-datasource-examples-howto.html
http://java.sun.com/j2se/1.4.2/docs/api/javax/sql/DataSource.html

conexion BD en jsp y Datadriver

bueno esta es la conexion que corresponde a la plataforma J2SE y es la
mas sencilla, pero no es la mas recomendada para j2ee, puesto que
para muchas conexiones simultaneas tiene un comportamiento muy
lento y aunque se podria mejorar con un patron de diseño como un
singleton, que en general lo implemento en una aplicacion de
escritorio de java, la idea seria ocupar las propierdades que nos
proporciona el contenedor web, el cual nos puede proporcionar una
conexion de tipo pool. ( como funciona un pool de conexion lo explico
en un articulo anterior)

para una aplicacion de pocas conexiones unas 3 , 5 o 7
el siguiente ejemplo considero que puede ser bueno, y lo mas importante
que no tiene un gran impacto de pasar de j2se a j2ee.

<%@ page import="java.sql.*" %>
<%@ page import="java.io.*" %>

html
head

/head
body
h1 conexion postgres /h1
<%
try {

String connectionURL = "jdbc:postgresql://localhost/ejemplo";

Connection connection = null;
Class.forName("org.postgresql.Driver").newInstance();
connection = DriverManager.getConnection(connectionURL, "postgres", "1234");

Statement stat = connection.createStatement();
String unsql="select * from empresa ";
ResultSet respuesta= stat.executeQuery(unsql);

while(respuesta.next()){

out.println(""+respuesta.getString("nombre"));
}
respuesta.close();
stat.close();
connection.close();
}catch(Exception e){

out.println("error conexion base de dato");}

%>
/body /html

ojo no tengo las etiquetas con <> para que no me de problema
el blog

se puede apreciar que la conexion es la misma que ocupamos en
j2se, pero no se preocupen, porque en una articulo anterior explico
como generar un pool en un servlet, pero ahora en el siguiente articulo
explicare como hacerlo en un jsp ( me parece que tengo un ejemplo con
jstl, pero la tecnologia jstl no es de mis favoritas, perfiero jSF, Struts y spring)

martes, 7 de julio de 2009

IDE eclipse

bueno no quiero dar detalles pero si encontre muy interesante
que este link que esta en la pagina de eclipse, donde se
puede apreciar varios videos para interiorizarse

http://live.eclipse.org/node/572

todo los video estan relacionados a la plataforma
J2EE