Skip to main content

Microservicios con JAX-RS Parametros Date

 JAX-RS Parametros Date

JAX-RS   es fundamental para la creación de servicios REST dentro del ecosistema Java. tiene notables mejorias con cada versión.

Contamos con varios mecanimos para pasar parametros mediante simples anotaciones. En algunos casos deseamos realizar consultas por fechas por ejemplo para filtras los documentos de una colección en MongoDB mediante un campo fecha.

Hacemos una consulta desde consola a la colección fruit




Ahora creamos un Proyecto para Microservicios que usamos con PayaraMicro , MongoDB, jmoordb , jmoordbutils.
Creamos el entity
public class Fruit {
    private String name;
    private String description;
    private String id;
    private Date date1;

    public Fruit() {
    }
//set/get
}



Acontinuación creamos el Resources observe que el parametro fecha es de tipo String, y MongoDB almacena el contenido de las fechas en formato ISODATE
Mediante la clase DateUtil.stringToISODate --> Convertimos la fecha en formato String a ISODate que maneja MongoDB.

Creamos el Resources
  @GET
    @Path("/filterbyqueryparamdate")
    @Produces({MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON})
    public List<Fruit> filterbyqueryparamdate(@QueryParam("name") String name, @QueryParam("id") String id, @QueryParam("date1") String date1) {
        List<Fruit> fruitList = new ArrayList<>();
        try {

            Date dateConverter = DateUtil.stringToISODate(date1);//dateString is query param.
          fruitList = fruitRepository.findByDate(dateConverter);

        } catch (Exception e) {
            System.out.println("filterbyqueryparam() " + e.getLocalizedMessage());

        }

        return fruitList;
    }

En el cliente creamos un Services
   public List<Fruit> filterbyqueryparamdate(String name, String id, String date1) {
        List<Fruit> suggestions = new ArrayList<>();
        try {

            Client client = ClientBuilder.newClient();
            suggestions = client
                    .target("http://localhost:8080"+ "/jmoordbcoreweb/resources/fruit/filterbyqueryparamdate/")
                     .queryParam("name",name )
                     .queryParam("id", id)
                     .queryParam("date1", date1)
                    
                    .request(MediaType.APPLICATION_JSON)
                    .get(new GenericType<List<Fruit>>() {});

        } catch (Exception e) {

            JsfUtil.errorDialog(" filterbyqueryparam()", e.getLocalizedMessage());
        }

        return suggestions;
    }

En el Controller del Cliente usamos un proceso inverso convertimos una fecha a String mediante DateUtil.isoDateToString(): y lo pasamos como parametro,
String date1 = DateUtil.isoDateToString(date);
List<Fruit> list = fruitServices.filterbyqueryparamdate("orange", "2", date1);


Comments

Popular posts from this blog

Cambiando el estado de un checkbox

Cambiando el Estado de un CheckBox Algunas veces deseamos controlar el estado de un checkbox o cambiarlo segùn determinadas condiciones. Pasos: 1. Creamos un proyecto Web. 2. En el diseñador agregamos un checkbox y dos botones. * Dar click derecho en el checkbox y luego seleccionar Add Binding Attribute, para agregar los atributos al checkbox, de manera que los podamos usar en nuestro código. Generando automáticamente private Checkbox checkbox1 = new Checkbox(); public Checkbox getCheckbox1() { return checkbox1; } public void setCheckbox1(Checkbox c) { this.checkbox1 = c; } 3.Damos click derecho en el botón Habilitar, y seleccionamos Edit Action Event Handler. A continuación, agregamos el código: this.checkbox1.setSelected(true);, el método setSelected con valor true, marca el checkbox como seleccionado, y un valor de false, quita la marca. public String button1_action() { // TODO: Process the action. Return value is a navigation //

Corregir el error el archivo de manifiesto en proyectos maven

Corregir el error en el archivo de manifiesto en proyectos maven Si creamos un proyecto maven con NetBeans e intentamos ejecutarlo encontraríamos el siguiente error Agregamos el plugin   <artifactId>maven-jar-plugin</artifactId>  <plugin>                 <groupId>org.apache.maven.plugins</groupId>                 <artifactId>maven-jar-plugin</artifactId>                 <version>2.4</version>                 <configuration>                     <archive>                         <manifest>                             <mainClass>org.javscaz.maven1.App</mainClass>                         </manifest>                                           </archive>                 </configuration>             </plugin> Luego al construir el proyecto con dependencias, podemos ejecutar el .jar

Tutorial básico de aplicaciones Web con NetBeans parte 1

NetBeans ofrece un excelente soporte para el desarrollo de aplicaciones Web, en esta ocasión lo haremos utilizando el Framework Java Server Faces 2.0. En el Menu Seleccionamos Nuevo->Proyecto y luego en Categorias Java Web y en tipo de Proyectos Web  Application indicamos el nombre del proyecto Seleccinamos el servidor Web, usamos GlassFish ya que este soporta EJB3.0 y JSF 2.0 Framework Java Server Faces El IDE genera el esquelto del proyecto Web Pages   almacenamos las paginas .html, xhtml, jsf, los archivos de recursos, los scripts .js, imagenes Source Packages    Son las clases Java  Test Packages    Son las clases que usamos para los Test Libraries     Tenemos las bibliotecas de Java y GlassFish necesarias para ejecutar la aplicación Web. Test Libraries     Están las bibliotecas usadas para los test  Configuration Files    Archivos de configuración de la aplicación. Ejecutamos la aplicación  Esperamos que se inicie GlassFish y se cargue la aplicación Este se