freeCodeCamp/guide/spanish/rest-api/index.md

106 lines
5.3 KiB
Markdown

---
title: Rest API Design
localeTitle: Diseño API de descanso
---
### Historia
RESTO significa **Re** protocolo **T** ransferencia **S** tate de presentación. Roy Fielding definió a REST en su tesis doctoral en el año 2000.
### ¿Qué es?
REST fue desarrollado para proporcionar una interfaz uniforme para
* Identificando recursos
* Manipulación de recursos.
* Mensajes auto descriptivos
* Uso de Hypermedia como el motor del estado de la aplicación (HATEOS)
### Mejores prácticas
* \#### Fundamentos
| Método | http://api.co/v2/cars | http://api.co/v2/cars/1234 |
| --- | --- | --- | | GET | Listar todos los coches | Recuperar un coche individual | | POST | Crear un coche nuevo | Error | | PUT | Reemplazar colecciones de autos con una nueva | Reemplazar el coche con id 1234 | | BORRAR | Borrar todos los coches | Eliminar coche con id 1234 |
_Tenga en cuenta que mientras que las operaciones PUT, el cliente o el servidor pueden generar ID_
* #### Los sustantivos son buenos Los verbos son malos
* Usa sustantivos para referir recursos como `cars` , `fruits` , etc.
* Use verbos para declaraciones de acciones `convertMilesToKms` , `getNutritionalValues`
* #### ¿Singular o plural?
Usa la gramática correcta para la declaración.
**Evitar** `/person/145`
**Prefiero** `/people/154` Supongamos que se devuelve 154a persona de la lista de personas
* #### Usar carcasa
¡Usa cualquiera de los siguientes patrones y sé **consistente!**
| Estilos de caja | Ejemplo | | ------------- | ------------- | | **UpperCamelCase** | `http://api.fintech.cp/DailyTransactions/Today` | | **lowerCamelCase** | `http://api.fintech.cp/dailyTransactions/today` |
| **snake\_case** | `http://api.fintech.cp/daily_transactions/today` |
* #### **Relaciones y recursos**
* Los recursos pueden tener relaciones de `one-to-many` , de `many-to-many` , de `many-to-one` , etc. El mapearlos correctamente es crucial.
* Mapeo **uno a muchos**
Por ejemplo, `Tickets/145/messages/4` sugiere una relación de uno a varios entre `tickets` y `messages` . Significado de `1` ticket tiene `N` mensajes. El mensaje no es un recurso independiente. No puedes tener `/messages/4` .
* **Muchos a muchos** mapeos
Por ejemplo, `/usergroups/345/users/56` sugiere seleccionar 345o grupo de usuarios y obtener usuario con id 56. Sin embargo, un usuario puede estar en varios `usergroups` es decir, `/usergroups/209/users/56` también es válido. En tal caso, para separar a los `users` recursos dependientes en un punto final separado como `/users/56` y proporcionar enlaces de recursos en `/usergroups/209/users/56`
* #### **Parámetros API**
* **RUTA** : _requerida_ para acceder al recurso Ej. `/cars` , `/fruits`
* **Parámetros de consulta** : _opcional_ filtrar la lista Ej. `/cars?type=SUV&year=2010`
* **Cuerpo** : Lógica específica del recurso. Consulta de búsqueda avanzada. A veces puede tener tanto consulta como cuerpo.
* **Encabezado** : Debe contener datos globales o de plataforma amplia. Por ejemplo, parámetros de clave API, claves encriptadas para autenticación, información de tipo de dispositivo, por ejemplo, dispositivo móvil o de escritorio o punto final, tipo de datos del dispositivo, por ejemplo, xml o json. Utilice el encabezado para comunicar estos parámetros.
* #### Códigos de estado HTTP
Usa códigos de estado correctos
| Codigos Significado | | ------------- |: -------------: | | 1xx | Solicitud recibida y entendida. | | 2xx | Acción solicitada por el cliente fue recibida, entendida y solicitada. | | 3xx | El cliente debe tomar medidas adicionales para completar la solicitud. La mayoría de estos códigos de estado se utilizan en la redirección de URL. | | 4xx | Destinado a situaciones donde parece que el error fue causado por el cliente. | | 5xx | El servidor no pudo completar una solicitud. |
¡Poco más en **2xx** !
* **201 Recurso creado.** POST `/cars` debe devolver HTTP 201 creado con el encabezado de `location` indica cómo acceder al recurso Por ejemplo, `location` : `api.com/cars/124` en el encabezado
* **202 - Aceptado**
Use esto si la tarea es enorme para ejecutar. Dígale al cliente, ha aceptado la solicitud y será / es proceso / procesamiento No se devuelve ninguna carga
* **204 - Sin contenido**
Se usa cuando se eliminan los `DELETE cars/124` No devuelve contenido. Pero también puede devolver `200 OK` si la API intenta enviar el recurso eliminado para su posterior procesamiento.
¡Los peligrosos recursos **5xx** !
* Error interno del servidor **500**
* **504** Tiempo de espera de puerta de enlace. El servidor no recibió una respuesta oportuna
Menos conocido **4xx** sugiere que está pasando un parámetro incorrecto. También puede pasar información que es incorrecta. P.ej
`DELETE /cars/MH09234`
devuelve `4xx` o mensaje `Expecting int car id /car/id got string car/MH09234`
### **Otras lecturas**
[Cómo diseñar excelentes APIs - Parse Developer Day 2013](https://www.youtube.com/watch?v=qCdpTji8nxo)
[El interminable debate sobre el diseño de la API REST por Guillaume Laforge](https://www.youtube.com/watch?v=48azd2VqtP0)
[Códigos de estado HTTP](https://httpstatuses.com/)