Un servidor REST es una aplicación que nos permite crear, actualizar, eliminar y recuperar datos de forma remota siguiendo el estandar de diseño REST. Lo habitual cuando programamos, por ejemplo peticiones ajax, es nombrar las urls como “/obtenerProducto”, “/crearProducto”, etc. En REST los verbos “obtener” o “crear” no se usan, ya que se utiliza una única url para todas las acciones, en nuestro ejemplo “/producto”. Además, REST nombra a estas urls como recursos.

Para poder diferenciar la acción que se está realizando sobre un recurso concreto se utiliza un método u otro en la petición: GET, POST, PUT o DELETE.

Podemos detectar el método que se usa e indicarle a la aplicación las acciones que debe realizar en cada caso. Cada método tiene un uso:

  • GET: Obtener datos de un recurso.
  • POST: Crear un nuevo elemento (un producto, un usuario).
  • PUT: Actualizar los datos de un recurso.
  • DELETE: Eliminar los datos de un recurso.

Os dejo un código muy, muy sencillo para la creación de un servidor REST. He intentado que sea lo más básico y sencillo posible. Además he añadido un pequeño detalle que no se suele ver en estos ejemplos por internet, que es cómo obtener los datos que llegan al servidor en un archivo xml. En realidad se usa el buffer de entrada de PHP (php://input) para recuperar los datos.

El ejemplo muestra como obtener los datos que nos llegan en la petición y devolverlos como resultado de la petición. A partir de ahí es todo vuestro.

  1. <?php
  2.  
  3. $method = $_SERVER['REQUEST_METHOD'];
  4. $resource = $_SERVER['REQUEST_URI'];
  5. $request = $_SERVER['HTTP_REQUEST'];
  6.  
  7. switch($method) {
  8. case 'GET':
  9. $string_xml_get = $_GET;
  10. break;
  11. case 'POST':
  12. $string_xml_post['POST'] = $_POST;
  13.  
  14. // Si los datos se envían como un xml lo habitual será que se guarden en el
  15. // buffer de entrada de php
  16. // Tendrás que cambiar esta línea por la anterior, dependiendo de por donde provengan los datos
  17. $string_xml_post['INPUT'] = file_get_contents('php://input');
  18. break;
  19. case 'PUT':
  20. parse_str(file_get_contents('php://input'), $string_xml_put);
  21. break;
  22. case 'DELETE':
  23. $string_xml_delete = $_REQUEST;
  24. break;
  25. }
  26.  
  27. if (!empty($string_xml_get)) {
  28. print 'Resultado por GET: ' . print_r($string_xml_get, true) . "\n\r";
  29. }
  30. elseif (!empty($string_xml_post)) {
  31. print 'Resultado por POST: ' . print_r($string_xml_post, true) . "\n\r";
  32. }
  33. elseif (!empty($string_xml_put)) {
  34. print 'Resultado por PUT: ' . $string_xml_put . "\n\r";
  35. }
  36. elseif (!empty($string_xml_delete)) {
  37. print 'Resultado por DELETE: ' . print_r($string_xml_delete, true) . "\n\r";
  38. }