Spring 2.5.5 and 2.5.6: What happened since the previous release

Spring 1 de March del 2010

1 Star2 Stars3 Stars4 Stars5 Stars (No Ratings Yet)
Loading ... Loading ...

Me encontré esta página que se llama xdepend y que realiza un reporte del análisis del los cambios que tiene Spring desde una versión anterior hasta la nueva versión que haya salido.

This page is a code analysis report about Spring auto-generated by XDepend.
In this report, you will find useful project metrics about the 2.5.6 release of Spring such as the most used types.
This report detailled also what has changed since the previous release 2.5.5 and also the evolution between abstractness and instability.

Ahora  ha echo el análisis entre la versión 2.5.5. con la versión 2.5.6 y que en su informe podemos encontrar:

  • Jars Metrics
  • Abstractness Versus Instability
  • What happened since the previous release
  • Types Metrics
  • etc.

Así que no estaría mal echarle un ojo, pera ver que les puede interesar.

Un Ejemplo de un proxi con AOP(Aspect) y Spring Framework

Java, Programación, Spring 14 de February del 2010

1 Star2 Stars3 Stars4 Stars5 Stars (1 votes, average: 5.00 out of 5)
Loading ... Loading ...

Jajajaja la verdad es que me doy cuenta que no se programar mucho, y hay veces que pongo ejemplos de este tipo, donde las bases se supone que las tengo bien claras… jajajajaj en fin, leyendo un poco de varias cosas y con las ideas de nuevos temas que me dejan de tarea… púes me hice un ejemplo de Aspect (Programación Orientada a Aspectos) con Spring Framework, y bueno además me ayudo mucho en que es verdad que debemos de tomar muy en cuenta la forma de estructurar el proyecto, las clases, los patrones que vamos a utilizar, etc. etc. y muchas cosas que a estas alturas me falta mucho por aprender,  pero sin más rollos aburridos… aquí les dejo un ejemplo:

Este ejemplo también lo hice con JAVA 1.4, pero la verdad es que mejor les voy a poder un ejemplo utilizando Java 5:
1.- Estamos utilizando en este caso las clases que hicimos en otro ejemplo con Hessian.
2.- Aquí vamos a hacer que el Aspecto se comporte como un proxi (esto quiere decir que cada vez que se llama a un recurso que le digamos se ejecutara nuestro interceptor)
3.- Así que sólo hay que agregar las cabeceras en el application-configuration.xml de nuestra aplicación.

1
2
3
4
5
6
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
       http://www.springframework.org/schema/aop

4.- y además declaramos nuestros dos beans,
1) userServices: que es nuestra interfaz
2) requestInjector: que es la clase que vamos a utilizar como nuestro interceptor( proxi)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
       http://www.springframework.org/schema/aop
       http://www.springframework.org/schema/aop/spring-aop-2.5.xsd">
   <!--
    To use @AspectJ aspects in a Spring configuration you need to enable Spring support for configuring Spring AOP based on @AspectJ aspects, and autoproxying beans based on whether or not they are advised by those aspects. By autoproxying we mean that if Spring determines that a bean is advised by one or more aspects, it will automatically generate a proxy for that bean to intercept method invocations and ensure that advice is executed as needed.  
    -->
    <aop:aspectj-autoproxy />
    <bean id="requestInjector" class="com.aspect.interceptor.ResquetInterceptor" />
    <bean id="userServices" class="com.serunix.services.impl.UserServicesImpl" />
</beans>

5.- y por último creamos nuestro Interceptor.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
package com.aspect.interceptor;
 
import org.apache.log4j.Logger;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
 
/**
 *
 * @author sergio
 */
@Aspect
public class ResquetInterceptor {
 
    private static final Logger log = Logger.getLogger(ResquetInterceptor.class);
 
   /** Es quí donde le decimos que se ejecute, que casa vez que se ejecute una clase que se encuentra en este paquete
   *   las diferente formas en que se puede ejecutar  las pueden consultar en la documentación. :)
   /
    @Before("execution(* com.serunix..*.*(..))")
    public void before(JoinPoint thisJoinPoint) {
        log.info("Before [" + thisJoinPoint.toShortString() + "]");
    }
}

6.- Y bueno eso es todo, creamos nuestro Test con JUnit o haciendo una clase main o como quieran, y les tiene que imprimir el info que tenemos dentro del método de before()

Pero para que nos puede servir esto:
1.- Para saber cuantas veces se ejecuta un recurso(estadísticas)
2.- Insertar en la DB
3.- Cambiar rutas, configuraciones, etc. etc.

lo importante es saber que debemos implementarlo si y sólo sí, es necesario ya que nos pega en el rendimiento de la aplicación.

4 Parte Hessian: Crear un Test con Spring Framewoks utilizano @ContextConfiguration

Java, Programación, Spring 3 de February del 2010

1 Star2 Stars3 Stars4 Stars5 Stars (1 votes, average: 5.00 out of 5)
Loading ... Loading ...

Para los que no sabemos hacer un test como yo, púes tenemos que estar leyendo un buen de cosas y sobre todo como hacerlo lo más fácil posible, con la versión 5 de java ayuda mucho a escribir menos código, pero esa es harina de otro costal… la verdad es que gracias a un compañero de trabajo, me entere de como poder cargar el contexto de spring en test unitario con Junit sin tener que hacer un:

1
  ApplicationContext context = new ClassPathXmlApplicationContext(....)

dentro de la aplicación, así que me dijo que existía una clase que se llamaba:

1
  AbstractDependencyInjectionSpringContextTests...

esta clase le inyecta todas las dependencias que quieras cargar en el contexto, es muy fácil implementarla en los Test aparte que necesitas el jar:

1
2
3
4
5
  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-test</artifactId>
    <version>2.5.6</version>
</dependency>

ya que me puse a leer el api, me di cuenta que estaba Deprecated en la versión 3.x.x de Spring Framework, así que leyendo un poco más la documentación de spring , púes la otra forma de inyectas las dependencias es por medio de anotaciones:

1
2
3
4
5
6
7
8
9
  /**
 *
 * @author serunix.com
 */
@RunWith(SpringJUnit4ClassRunner.class)
 
@ContextConfiguration(locations={"classpath:test/serunix/remoting-servlet-test.xml"})
public class UserServicesImplSpringTest {
...

hacemos que se ejecute primero la clase de SpringJUnit4ClassRunner y después le decimos que cargue el contexto que nosotros queramos, en otras palabras, es una forma de inyectas las dependencias y utilizarlas durante todo el Test.

3 Parte – Hessian: Crear un test con Junit para probar la respuesta del Web Services…

Java, Programación, Spring, Web Services 31 de January del 2010

1 Star2 Stars3 Stars4 Stars5 Stars (1 votes, average: 5.00 out of 5)
Loading ... Loading ...

La verdad es que es un mundo hacer un test para realizar pruebas unitarias de nuestras aplicaciones web, hay veces que no los hacemos por que no sabemos, no queremos, consumen más tiempo, etc. mil pretextos, pero la verdad es que son muy importantes, mejor dicho deberían ser indispensables pero eso es otro tema que debe resolver cada uno.

Continuando con el pequeño ejemplo de “1 Parte – Hessian: Un ejemplo de creación de un Web Services con Hessian en Java ejecutándolo con GlassFish” púes habíamos creado un test usando un main, pero ahora les dejo un ejemplo de test utilizando Junit, la verdad es que no es difícil y sólo hay que:

1.- Creamos nuestra clase de prueba
2.- Importamos el jar de Junit en caso de que no lo tengamos. (como estoy utilizando Netbeans al crear el proyecto me crea todo lo necesario para poder desarrollar los test además que me importa el jar de junit).

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
package test.serunix;
 
import com.serunix.bean.User;
import com.serunix.services.UserServices;
import java.util.Iterator;
import java.util.List;
import org.apache.log4j.Logger;
import org.junit.Before;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
 
/**
 *
 * @author serunix.com
 */
public class UserServicesImplTest {
 
    private static final Logger log = Logger.getLogger(UserServicesImplTest.class);
    /**
     *
     */
    protected UserServices userservices;
 
    /**
     * Se ejecuta antes de probar los test, para que pueda cargar el contexto y hacer
     * la llamada al Web Services.
     *
     * @throws Exception
     */
    @Before
    public void init() throws Exception {
        ApplicationContext context = new ClassPathXmlApplicationContext("classpath:test/serunix/remoting-servlet-client.xml");
        userservices = (UserServices) context.getBean("userService");
    }
 
    /**
     * Es para probar que podemos obetenr un lista de los usarios
     *
     * @throws Exception
     */
    @Test
    public void ObtainListUsers() throws Exception {
        List users = userservices.ObtainListUsers();
 
        Iterator ite = users.iterator();
        while (ite.hasNext()) {
            User user = (User) ite.next();
            user.getName();
            user.getLasName();
            user.getEmail();
        }
 
    }
}

3.- Después los ejecutamos, en mi caso solo tengo que seleccionar la clase del test y dar click derecho ->Test File
4.- Nos muestra los resultados del test ya sea que hayan fallado o que hay ido todo Ok.

Test - Junit

Test - Junit

Podríamos seguir haciendo diferentes tipos de prueba, pero eso depende del nivel y detalle que queramos, este test es muy sencillo y ojala les sirva de ejemplo.

2 Parte – Hessian: Integración de Hessian con Spring Framework…

Java, Programación, Spring, Web Services 26 de January del 2010

1 Star2 Stars3 Stars4 Stars5 Stars (No Ratings Yet)
Loading ... Loading ...

Bueno, como he dicho antes con un poco de práctica y sobre todo, con mucho interés se pueden saber las cosas que uno quiere… después de mucha lectura sobre como crear un Web Services con Hessian integrándolo con Spring púes he conseguido levantar el cliente y el servidor, pero me encontré con muchos problemas que principalmente fueron de versiones, y como he leído en muchos foros, no se puede obtener una respuesta correcta por parte del servidor en spring 2.5.xx así que tuve que download la versión 3.0.0 release:

Tomamos como ejemplo el proyecto que creamos en el post “1 Parte – Hessian… ” y sólo hay que crear:

1.- remoting-servlet.xml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
       http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd">
 
 
    <bean id="userServices"   class="com.serunix.services.impl.UserServicesImpl" />
 
   <bean name="/userService"   class="org.springframework.remoting.caucho.HessianServiceExporter">
        <property name="service"  ref="userServices"/>
        <property name="serviceInterface" value="com.serunix.services.UserServices"/>
    </bean>
 
</beans>

2.- Modificamos nuestro web.xml y agregamos esto.

1
2
3
4
5
6
7
8
9
10
11
12
...
    <servlet>
        <servlet-name>remoting</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <load-on-startup>1</load-on-startup>
    </servlet>
 
    <servlet-mapping>
        <servlet-name>remoting</servlet-name>
        <url-pattern>/remoting/*</url-pattern>
    </servlet-mapping>
   ...

3.- Y quitar que la clase UserServicesImp ya no extienda de HessianServlet

1
       ... extends HessianServlet ...

4.- Esto tendría que ser suficiente para el servidor y por parte del cliente, sólo hay que agregar:

5.- remoting-servlet-client.xml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
 <?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
       http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd">
 
 
    <bean id="userService" class="org.springframework.remoting.caucho.HessianProxyFactoryBean">
        <property name="serviceUrl" value="http://localhost:8080/EJEMPLOHESSIAN/remoting/userService"/>
        <property name="serviceInterface" value="com.serunix.services.UserServices"/>
    </bean>
 
</beans>

6.- Y para obtener la llamada sólo hay que hacer la petición a la Url que configuramos en el servidor /userService

1
2
3
        ApplicationContext context = new ClassPathXmlApplicationContext("classpath:test/serunix/remoting-servlet-client.xml");
        UserServices userservices = (UserServices) context.getBean("userService");
        List users = userservices.ObtainListUsers();

7.- Así que esto sería todo, aquí les dejo un screenshot de como quedo mi proyecto incluyendo los jars…

Web services con Hessian y Spring

Web services con Hessian y Spring

Una forma de recargar/reload/refreshing un archivo properties con Spring

Java, Programación, Spring 8 de November del 2009

1 Star2 Stars3 Stars4 Stars5 Stars (No Ratings Yet)
Loading ... Loading ...

Hay muchisisisisimas formas de hacer esto, y una de ellas es hacerlo con spring y sólo hay que definir los siguientes beans en el spring-context de la aplicación y este se encargara de hacer el reload en el tiempo que se le defina. Aquí les dejo su API.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<bean id="baseMessageSource"
            class="org.springframework.context.support.ResourceBundleMessageSource">
            <property name="basename">
                  <value>classpath:Application</value>
            </property>
      </bean>
<!-- messageSource,  spring lo tiene definido para los archivos properties, así que no hay que cambiarlo -->
      <bean id="messageSource"
            class="org.springframework.context.support.ReloadableResourceBundleMessageSource">
            <property name="basenames">
                  <value>classpath:Application</value>
            </property>
            <property name="parentMessageSource">
                  <ref bean="baseMessageSource" />
            </property>
            <property name="cacheSeconds">
       <!-- En este caso cada 60 segundos -->
                  <value>60</value>
            </property>
      </bean>
http://www.wikio.es BlogESfera - Directorio de Blogs Hispanos blogarama - the blog directory Mi Ping en TotalPing.com
Internet blogs Programming Blogs - Blog Catalog Blog Directory Internet blogs Buzzear (ES) Publicidad por tu blog con Boosterblog directorio de blogs
Agregar Web - Directorio de webs Directorio webs Directorio Web