Comprender la importancia de las APIs y su utilidad en el mundo actual.
Leer los siguientes artículos y posteriormente contestar el cuestionario adjunto.
Crear un aplicación tipo Uber o hacer cobros por Internet. ¿Te imaginas cómo podrías hacerlo desde cero? Demandaría muchísimo trabajo y dinero, por eso es mejor utilizar un servicio que ya exista como lo es Google Maps o conectarse a PayPal.
Si tu aplicación utiliza recursos de otra aplicación hace que sea más potente a diferencia de una aplicación que se maneja por sí sola, ese es el concepto de una API.
Las APIs son interfaces que permiten la comunicación entre dos aplicaciones de software siguiendo cierto conjunto de reglas.
La arquitectura más usada es REST y el formato de envío de datos más usado es JSON.
Permite que tú puedas consumir los servicios del sistema sin saber qué hay tras bambalinas.
Ejemplo:
- Un formulario de Login, en el cual sólo te interesa ingresar mas no saber qué pasa detrás.
Entonces una API (Application Programming Interface) es una interfaz que permite que aplicaciones de software puedan intercambiar datos entre ellos.
Es la metodología mediante la cual está diseñado un sistema, cómo están organizados, cómo es la comunicación y qué roles cumplen los componentes.
Sistema que permite que equipos en una red se puedan comunicar siguiendo el protocolo HTTP (conjunto de reglas entre cliente-servidor para intercambiar información), esta es la base para que las APIs remotas permitan la comunicación entre aplicaciones de distintas locaciones.
REST (Representational State Transfer) es una Arquitectura de Software.
Las API REST involucran:
- Guardar los datos en caché.
- El estado no se envía en las peticiones.
- Define permisos para que otra aplicación pueda acceder, revisar o manipular datos de tu aplicación.
-
Locales: Cuando la aplicación se comunica con la API que se encuentran en el mismo ambiente o dispositivo.
-
Remotas: Cuando la aplicación necesita consumir una API en un punto diferente.
Las Apis remotas pueden utilizar servicios web:
-
Soap: Es un protocolo que ya dejó de ser usado. Aunque muchos sistemas aún funcionan con él.
-
Rest: Es la arquitectura más usada, los sistemas Restful se basan en éste.
-
Consultar recursos (URI- Uniform Resource Identifier) Cada consulta tiene un identificador único llamado URI, éste se consulta por medio de endpoints (la URL completa), y que permite consultar directamente un recurso.
-
Códigos de Estado: Cuando solicitamos información, el servidor responde con códigos con los que podemos saber el estado de nuestra petición.
Permiten interacción con la información de la API, es equivalente al CRUD de las bases de datos.
-
HATEOAS:(Hypermedia as the Engine of Application State) La API se autodescribe, podemos ser capaces de descubrir sus recursos basándonos únicamente en las respuestas del servidor.
-
Seguridad: Si tu API es privada necesitas seguridad para evitar el acceso o la manipulación de tu información.
-
Testear: Asegurar que la API funcione correctamente y que cumpla la función para la que fue diseñada.
-
Documentar: Una documentación bien estructurada facilita el consumo de nuestra API.
Título: Amazon, Apple, Facebook, Google: How "The Four" Are Using APIs
Esta publicación en inglés es un artículo que aborda de una manera no técnica y más abierta el concepto de API y su importancia en los negocios, en especial habla sobre cómo cuatro de las empresas tecnológicas más importantes han utilizado este concepto para crecer y convertirse en lo que son ahora.
⚠️ NotaSi tienes problemas leyendo inglés se recomienda traducir la página automáticamente o instalar la extensión oficial de google translate.
Título: API REST, qué es y cuáles son sus ventajas en el desarrollo de proyectos
Este artículo explica de manera técnica las características y ventajas de una API REST. Servirá como introducción a los conceptos técnicos que nos conciernen para esta sesión.