Lógica de negocio, ¿va en el cliente o en el servidor?

Поделиться
HTML-код
  • Опубликовано: 14 дек 2024

Комментарии • 56

  • @ManuelZapata
    @ManuelZapata  Год назад

    Conoce mi curso de Arquitecturas Limpias
    👉platzi.com/arquitecturaslimpias
    Si no te tienes suscripción en Platzi, usa mi enlace de afiliado: platzi.com/l/manuelzapata/

  • @Magistrado1914
    @Magistrado1914 3 года назад

    Excelente vídeo
    Visto en 03/03/2021

  • @TheLurleenGamespro
    @TheLurleenGamespro 3 года назад +4

    11:45. Es cierto que es buen hábito realizar la validación de datos. Pero a mi parecer también debería estar del lado del servidor (por las dudas)

  • @andrespineros4374
    @andrespineros4374 3 года назад

    El vídeo más claro que encontré, muchas gracias

  • @ing.marcelozenzano3436
    @ing.marcelozenzano3436 Год назад

    Excelente video Manuel! Eternamente agradecido!!

  • @carlossalinas4254
    @carlossalinas4254 2 года назад

    que video mas estupendo, muy bien explicado jjaja muy muy bueno👍🏽

  • @abadie7
    @abadie7 2 года назад

    Muy deacuerdo con tus consejos en tu video gracias por haberlo expuesto aqui.

  • @sebac0des
    @sebac0des 2 года назад

    Excelente Manuel ! Creo que este vídeo le acaba de cambiar la vida a mi yo del futuro, gracias !!

  • @RuslanGonzalez
    @RuslanGonzalez 4 года назад +1

    Increíble vídeo, gracias por compartir tus conocimientos. Estoy aprendiendo mucho contigo!

  • @julioperaza07
    @julioperaza07 4 года назад +1

    Manuel muchas gracias por los vídeos es uno de los mejores canales en español de desarrollo de software. Gracias x El esfuerzo.

    • @ManuelZapata
      @ManuelZapata  4 года назад +2

      Gracias por esas palabras, Julio. Se hace lo mejor que se puede.

    • @julioperaza07
      @julioperaza07 4 года назад

      @@ManuelZapata pura vida. Ojalá un día te hagas un live para conversar

  • @GerentedeSistemas
    @GerentedeSistemas 3 года назад

    Excelente explicación

  • @sergiogimenez3751
    @sergiogimenez3751 4 года назад +1

    Hola Manuel! Te conocí por los NullPonters. Sos la información que estaba buscando hace mucho, por lo general te hablan de lenguajes, frameworsk, librerías y demás cosas del estilo pero lo tuyo es la base. Felicitaciones!

    • @ManuelZapata
      @ManuelZapata  4 года назад +2

      Genial Sergio! Esa era un poco la idea del canal. Salirnos un poco de los tutoriales y profundizar en aspectos que poco se tocan.

  • @OmarzLiszt
    @OmarzLiszt 3 года назад

    ¡Muchas gracias! Buen contenido

  • @mongose911
    @mongose911 3 года назад

    Como se implementaría una aplicación ejemplo con windows form utilizando la lógica de negocio desde el servidor? Es decir si tengo le proyecto en 3 capas con sus dll se puede implementar igual o se tiene que hacer desde 0? se necesita un programa adicional?

  • @elmirador7097
    @elmirador7097 3 года назад

    Me acabo de suscribir a tu canal me parecio increiblemente nutritivo el contenido te consulto libros y recomendaciones para aprender sobre este modelado respecto a la logica de negocios ... desde ya un suscriptor mas atento a tu contenido !!

  • @felixinit
    @felixinit 4 года назад

    Gracias Manuel. Has respondido muchas de mis dudas 👍😁

  • @gamalielaq
    @gamalielaq 2 года назад

    Acabo de descubrir tu canal es una mina que me encontre. Estoy iniciando con la programación soy autidacta y quiero aclarar estos temas o alguien de la comunidad que lo hiciera. Pasa que siempre he desarrollado aplicaciones CRUD y nunca he visto esto de "logica de negocios", "regla de negocios", "core" en la practica, y ahora mas que mencionas logica de "negocio en lado del cliente" ya me perdí. Entonces ¿que es realmente la logica de negocios?, ¿En que parte de nuestra aplicación se integra?. Gracias.

  • @trex3612
    @trex3612 4 года назад

    Excelente explicación..! Excelente... Felicitaciones

  • @rickertluisgonzalesramirez1839
    @rickertluisgonzalesramirez1839 2 года назад

    Hola, me gustó mucho el video, pero aun tengo dudas sobre la logia de negocio y como estructurar todo de manera correcta ¿Tienes algún libro, blog o video que me ayude? te lo agradecería muchísimo 😊

    • @ManuelZapata
      @ManuelZapata  2 года назад

      Revistate un libro de Martin Fowler que se llama "Patterns of Enterprise Application Architecture". Tiene varios capitulos dedicados a lógica de negocio.

  • @CAGUANET121
    @CAGUANET121 4 года назад +3

    Gracias Manuel es un tema que disipa muchas dudas, por ejemplo en algunos casos se maneja la misma lógica de negocio en el cliente se repite a partir del concepto de ahorrarnos una petición al servidor pero esto está realizando dos validaciones, que piensas de ese contexto?

    • @ManuelZapata
      @ManuelZapata  4 года назад +4

      Si la lógica de negocio en el cliente, está limitada solo a validaciones, yo creo que está bien. Eso mejora la usabilidad de la aplicación.
      Sin embargo, lo ideal es validar también en el servidor (así el cliente ya haya validado). La razón principal es seguridad. Los browsers dan mucha flexibilidad a usuarios malintencionados. Basta con llamar directamente el servicio o deshabilitar el JavaScript en el navegador para que las validaciones no se apliquen.

  • @KaliSurfYoMero
    @KaliSurfYoMero 4 года назад

    Hola, buen día! Por ejemplo en casos como Angular (y apps) donde el mismo framework te permite construir la aplicación junto con -casi- toda la lógica de negocios y -a veces- solo delegar al servidor el resguardo de los datos ¿vale la pena retirar esta responsabilidad al cliente para enviarla al servidor? se entiende que en caso de tener app y web se tendría que replicar esta funcionalidad, pero considero que se gana en performance y en consumos al servidor. ¿Que opinan? no soy experto y podría no estar viendo algo y me gustaría que me ayuden a ampliar mi perspectiva del escenario.

  • @edgarorlandocalderonsanche8259
    @edgarorlandocalderonsanche8259 4 года назад +1

    Gracias Manuel, excelente vídeo. Tengo un dilema con respecto a que tan insegura podría ser una aplicación si su lógica de negocio esta en el cliente. Digamos en una aplicación desarrollada por ejemplo en Angular.

    • @ManuelZapata
      @ManuelZapata  4 года назад +2

      Depende mucho del despliegue y como manejes ciertas cosas a nivel de aplicación.
      Por ejemplo, si por error subes los archivos .map a producción, dejas tu código expuesto. Si usas el session o el local storage, y todo lo pones en texto plano, también queda expuesto.

  • @josecarloz1627
    @josecarloz1627 4 года назад +1

    Hola manuel, estoy desarrollando una aplicación en Laravel y utilizó su motor de plantillas Blade
    Eso quiere decir que toda mi lógica de negocio está en el cliente?

    • @ManuelZapata
      @ManuelZapata  4 года назад +1

      Está en el servidor porque PHP se ejecuta del lado del servidor. Si pusieras lógica en JavaScript, ahí si la tendrías del lado del cliente.

  • @diegoalzate5473
    @diegoalzate5473 4 года назад

    Gracias Manuel! Estuvo súper. Por ahí sigo con la duda si las validaciones de datos serían necesarias hacerlas también en el servidor? Que piensas tú?

    • @ManuelZapata
      @ManuelZapata  4 года назад +1

      Yo creo que sí Diego. Especialmente en el ámbito web. Los browsers son herramientas muy potentes que facilmente dejan expuesta tu aplicación. Por ejemplo, se deshabilita el JavaScript y cualquier validación que tengas con este lenguaje, ya no funciona.

    • @diegoalzate5473
      @diegoalzate5473 4 года назад

      @@ManuelZapata Gracias Manuel!! Ya con mucha mas confianza argumento lo tengo claro. Gracias por responder! 🖒

  • @walterleme1263
    @walterleme1263 3 года назад

    Excelente video Manuel, gracias por compartir tus conocimientos. Una pregunta: para una aplicación de escritorio utilizando C# y windows forms, cómo me aconsejas hacer la conexión entre mi capa de presentación y la lógica que está en otra pc que brinda servicios de servidor? Gracias.

    • @ManuelZapata
      @ManuelZapata  3 года назад

      Con aplicaciones de escritorio, las opciones son mayores. Pero creo que me iría con un API REST clásico. Facilita la interoperabilidad si algún día una aplicación web se conecta a ese servicio.

  • @RuslanGonzalez
    @RuslanGonzalez 4 года назад

    Creo que existe un escenario posible para utilizar un poco de lógica en ambos lados y sería aplicada en backends que son dinámicos. En otro sentido una lógica abstracta de negocio. En el que varios clientes pueden consumir esa lógica aplicando diferentes conceptos de negocio de forma personalizada e independiente, pero basándote en el mismo sistema de acceso de datos. Véase en un sistema de blog dinámico, etc. ¿Tú qué opinas?

  • @joseangelramirezhernandez3269
    @joseangelramirezhernandez3269 4 года назад

    Manuel una pregunta que recomendarías en este caso tengo una solución con n proyectos uno es para la APIREST, otro con las clases dto etc, otro con los Repositorios, otro para una aplicación de escritorio para la aplicación de escritorio recomiendas consumir la api o los repositorios, cabe decir que la api utiliza el proyecto de repositorio. No se si me expliqué bien

    • @ManuelZapata
      @ManuelZapata  4 года назад +1

      Sin tener full contexto de tu problema, yo te recomendaría consumir el API. Así tienes todas las validaciones de seguridad. Además, centralizas todos los llamados. Eso te va a facilitar mucho los cambios. Saludos Jose!

    • @joseangelramirezhernandez3269
      @joseangelramirezhernandez3269 4 года назад

      @@ManuelZapata excelente muchas gracias

    • @RexGanesAdventures
      @RexGanesAdventures 4 года назад

      Las validaciones de seguridad se hacen el la capa API o en la de logica de negocio? O se reparten las validaciones segun el tipo? por ejemplo el api hago que valide mal formato o datos incompletos, los numeros no cumplen un rango, ect

  • @AtrapadosEnElCodigo
    @AtrapadosEnElCodigo 4 года назад

    Hola Manuel, buen video. ahorita prácticamente todos los desarrollos se hacen bajo la arquitectura cliente - servidor, entonces lo recomendable es que la lógica de negocio siempre este en el servidor?

  • @lvbernal
    @lvbernal 4 года назад

    Muy buen video! Muchas gracias. Tengo una pregunta: cuando el API expone los recursos hacia el cliente, es normal tener unos "transfer objects" repetidos en cada lado para facilitar la comunicación. En C#, por ejemplo, el cliente mapea esos objetos a ViewModels y luego los pasa a la vista. Es recomendable devolver el ViewModel desde el servidor para evitar ese último paso? Al principio podríamos pensar que un servicio puede servir para varias vistas, pero eso sucede en muy pocos casos. En otras palabras: el API devuelve justo lo que necesita la vista o los recursos para que se construya del lado del cliente?

    • @ManuelZapata
      @ManuelZapata  4 года назад +1

      En mi experiencia Leo, yo prefiero devolver transfer objects con la información precisa que necesita la vista, y ya que la vista se encargue de convertir a view-models.
      No devolvería el view model directamente desde el servidor porque es muy fácil cruzar la línea de meter la lógica de presentación en el servidor. Por ejemplo, colores o estilos (lo he visto).
      Otra alternativa que tenés es tomar la decisión consciente de acoplar un controlador a una vista. Lo que Fowler llama un Page Controller: martinfowler.com/eaaCatalog/pageController.html
      Allí ya tendrías los controladores organizados por página o vista, y no por dominio u otro concepto.

  • @itmarck
    @itmarck 4 года назад

    Hola Manuel, tú diferencias entre lógica de negocio y dominio? Me surge una duda respecto a eso. Si la aplicación (Android, por ejemplo) recibe datos de una Api, las entidades y los modelos forman parte del dominio? Se debe hacer robusta esa parte o mantenerla lo más simple posible (tal vez una clase que haga las peticiones y ya)? Gracias por compartir tus conocimientos 😁

    • @ManuelZapata
      @ManuelZapata  4 года назад

      Hola Marcelo. Normalmente las entidades y modelos hacen parte del dominio del problema. Qué tan robusta sea depende de qué tanta responsabilidad le quieras dar al cliente. Por ejemplo, hay personas que mandan toda la lógica de negocio al backend y dejan la app recibiendo y enviando DTOs. Saludos!

  • @melchiah6603
    @melchiah6603 4 года назад

    Cuando se derrolla una app movil en dónde hay que tener en cuenta que el usuario piede no estar conectado a un Internet, sería conveniente que la app contemple ese escenario y poder utilizar la app aun sin conexión a Internet. En todo caso yo casi siempre utilizo el peor escenario.

  • @abrahamhernandes5400
    @abrahamhernandes5400 3 года назад

    que es Lógica de negocio ?

    • @ManuelZapata
      @ManuelZapata  3 года назад

      Por aquí te cuento qué es: ruclips.net/video/fdnqf0qZUbw/видео.html

    • @abrahamhernandes5400
      @abrahamhernandes5400 3 года назад

      ​@@ManuelZapata Gracias, si justo ese me lo recomendó youtube. Muy buena info de tu canal, gracias Manuel !

  • @alanfabianherrera5874
    @alanfabianherrera5874 4 года назад +1

    No se por experiencia en un proyecto de un software contable la lógica de facturación que era calcular el total de una factura cuando se estaba creando el resultado era unos retardos por que cada ves que calculaba el subtotal de un producto hacía una petición servidor la experiencia de usuario era pobre entonces se recomendó que esa lógica de calcular el total estuviera en el cliente entonces se redujo mucho las peticiones de servidor y experiencia de usuario mejoro no sense ai esta logica es una parts De logica De negocio

    • @ManuelZapata
      @ManuelZapata  4 года назад

      Sí, eso haría parte de la lógica de negocio. Obviamente cada caso tiene sus particularidades, pero en las condiciones apropiadas lo ideal sería no duplicar la lógica de negocio en múltiples clientes.

  • @lordjavier_
    @lordjavier_ 2 года назад

    La logica de formato de datos, ejemplo escritura de precios con decimal o miles, estructura de fechas, etc deberia estar en el cliente o servidor ?, Excelente video, muchas gracias.