Diferencia entre revisiones de «Usuario:ManuelRomero/Laravel/practica crud/producto»

De WikiEducator
Saltar a: navegación, buscar
Línea 56: Línea 56:
 
  Solicitud '''put''' a un método '''update''' que almacenará los datos del formulario en la base de datos
 
  Solicitud '''put''' a un método '''update''' que almacenará los datos del formulario en la base de datos
 
<source lang=php>
 
<source lang=php>
  Route::post("producto/store","ProductoController@store")->name("producto.update");
+
  Route::put("producto/store","ProductoController@store")->name("producto.update");
 
</source>
 
</source>
 
 
 
;Delete
 
;Delete
 +
En este caso tenemos una única acción que será la de borrar el registro seleccionado
 +
<source lang=php>
 +
Route::delete("producto/{producto}","ProductoController@delete($producto)")->name("producto.delete");
 +
</source>
 +
;Automatizar estas entradas
 +
Como hemos comentado '''''Laravel'''''nos provee de un método para crear todas estas 7 entradas con sus diferentes vebos http y sus rutas parametrizadas según proceda respetando la especificación REST
 +
*Para ello agregamos en el fichero '''''routes/web.app''''' las siguientes líneas (una por cada tabla:
 +
<source lang=php>
 +
Route::resource("producto", "ProductoController");
 +
Route::resource("tienda", "TiendaController");
 +
Route::resource("stock", "StockController");
 +
Route::resource("familia", "FamiliaController");
 +
<source>
 +
;Vemos las rutas creadas escribiendo en la consola que nos las muestre con artisan
 +
<source lang=php>
 +
php artisan route:list
 +
</source>
 +
*Las rutas de '''''producto'''''
 +
[[Archivo:rutas_producto.png]]
 +
*Las rutas de '''''familia'''''
 +
[[Archivo:rutas_familia.png]]
 +
*Las rutas de '''''stock'''''
 +
[[Archivo:rutas_stock.png]]
 +
*Las rutas de '''''tienda'''''
 +
[[Archivo:rutas_tienda.png]]

Revisión de 05:15 5 mar 2020

Configuración de conexión a base de datos

  • En este caso la base de datos la tenemos en un docker
  • Modificamos el fichero ./.env
 DB_CONNECTION=mysql
 DB_HOST=172.17.0.2
 DB_PORT=3306
 DB_DATABASE=dwes
 DB_USERNAME=root
 DB_PASSWORD=root
  • Estos parámetros se han de adaptar a la configuración que tengas sobre tu base de datos
 Ver configuración de bases de datos

Creación de la base de datos

  • Las tablas producto, tienda, stock, familia y existe, por lo que no crearemos migración para crear las tablas de la base de datos. Sí lo haremos en la tabla de usuarios

Añadir las solicitudes en web.php

  • A continuación vamos a analizar cada caso. No hay que realizar estas entradas, esto es para entenderlo, todas quedarán creadas agregando en el fichero la ruta
 Route::resource("producto", "ProductoController");

Queremos hacer un CRUD. vamos a ver qué solicitudes necesitamos

Create
esta acción va a implicar dos acciones

1.- El usuario presiona un botón de crear un regsitro

Solicitud get a un método create que entrega un formulario
 Route::get("producto/create","ProductoController@create")->name("producto.create");
  • LA ruta creada la vamos a poner un nombre para referenciarla más cómodamente

2.- El usuario rellena los datos y presiona el submit del formulario

Solicitud post a un método store que almacenará los datos del formulario en la base de datos
 Route::post("producto/store","ProductoController@store")->name("producto.store");
Read
  • Esta acción puede ser visualizar un registro (show), o visualizar (index) todos
  • En el primer caso será una solicitud get que atenderá el método index
 Route::get("producto","ProductoController@index")->name("producto.index");
  • En el segundo caso será una solicitud get pasándo el código de producto que quiero ver al método show
  • Estamos creando rutas parametrizadas
 Route::get("producto/{producto}","ProductoController@show($producto)")->name("producto.index");
Update
  • En el caso de actualización igualmente necesitamos dos acciones, una es editar el registro que queemos modificar con sus datos, y la otra es almacenar los valores actualizados

1.- El usuario presiona un botón editar un determinado registro

Solicitud get a un método edidt que entrega un formulario con los datos 
 Route::get("producto/{producto}/edit","ProductoController@edit($producto)")->name("producto.edit");

2.-El usuario ve en un formulario los datos de un registro para modificar

Solicitud put a un método update que almacenará los datos del formulario en la base de datos
 Route::put("producto/store","ProductoController@store")->name("producto.update");
Delete

En este caso tenemos una única acción que será la de borrar el registro seleccionado

 Route::delete("producto/{producto}","ProductoController@delete($producto)")->name("producto.delete");
Automatizar estas entradas

Como hemos comentado Laravelnos provee de un método para crear todas estas 7 entradas con sus diferentes vebos http y sus rutas parametrizadas según proceda respetando la especificación REST

  • Para ello agregamos en el fichero routes/web.app las siguientes líneas (una por cada tabla:
Route::resource("producto", "ProductoController");
Route::resource("tienda", "TiendaController");
Route::resource("stock", "StockController");
Route::resource("familia", "FamiliaController");
<source>
;Vemos las rutas creadas escribiendo en la consola que nos las muestre con artisan
<source lang=php>
php artisan route:list
  • Las rutas de producto

Rutas producto.png

  • Las rutas de familia

Rutas familia.png

  • Las rutas de stock

Rutas stock.png

  • Las rutas de tienda

Rutas tienda.png