Acabamos de ver las operaciones básicas que podemos hacer con PHP y MongoDB. Ahí vimos cómo hacer un CRUD, pero no lo aplicamos. Es por eso que decidí hacer un ejemplo con una agenda que simplemente guarda contactos.
Dicho ejemplo de MongoDB y PHP está hecho con Bootstrap y puedes clonarlo o descargarlo en el repositorio de GitHub.
Requisitos y recomendaciones
Únicamente lee el post anterior, pues aquí partiré con la idea de que ya sabes cómo hacer las operaciones básicas.
¿Por qué no hay ejemplo en línea?
Intenté pero al final decidí no perder más tiempo, y por ahora la única manera de probarlo es descargarlo por ti mismo. Recuerda seguir los tutoriales del post anterior para habilitar la extensión y todas esas cosas.
El paradigma
Intenté abstraer todo en un paradigma de tipo MVC. No se usa ningún framework, es PHP puro. Para la gestión de paquetes utilizo composer, y un tema de Bootstrap.
El modelo
Es un modelo que se encarga de interactuar con la base de datos y las operaciones de la agenda. Se ve así:
<?php
class ContactosModel
{
private static function obtenerBaseDeDatos()
{
$host = "127.0.0.1";
$puerto = "27017";
$usuario = rawurlencode("parzibyte");
$pass = rawurlencode("hunter2");
$nombreBD = "agenda";
# Crea algo como mongodb://parzibyte:hunter2@127.0.0.1:27017/agenda
$cadenaConexion = sprintf("mongodb://%s:%s@%s:%s/%s", $usuario, $pass, $host, $puerto, $nombreBD);
$cliente = new MongoDB\Client($cadenaConexion);
return $cliente->selectDatabase($nombreBD);
}
/**
* @param $contacto Contacto: un objeto de la clase Contacto
* @return bool indicando si la inserción fue correcta
*/
public static function insertar($contacto)
{
$baseDeDatos = self::obtenerBaseDeDatos();
# Acceder a la colección contactos
$coleccion = $baseDeDatos->contactos;
$resultado = $coleccion->insertOne([
"nombre" => $contacto->getNombre(),
"direccion" => $contacto->getDireccion(),
"correoElectronico" => $contacto->getCorreoElectronico(),
]);
return $resultado->getInsertedCount() === 1;
}
public static function obtenerPorId($id)
{
$baseDeDatos = self::obtenerBaseDeDatos();
$coleccion = $baseDeDatos->contactos;
return $coleccion->findOne(["_id" => new MongoDB\BSON\ObjectId($id)]);
}
public static function obtenerTodos()
{
$baseDeDatos = self::obtenerBaseDeDatos();
$coleccion = $baseDeDatos->contactos;
return $coleccion->find(); // Sin criterio de búsqueda
}
public static function actualizar($id, $contacto)
{
echo "id => $id";
$baseDeDatos = self::obtenerBaseDeDatos();
$coleccion = $baseDeDatos->contactos;
$resultado = $coleccion->updateOne(
// El criterio, algo así como where
["_id" => new MongoDB\BSON\ObjectId($id)],
// Nuevos valores
[
'$set' => [
"nombre" => $contacto->getNombre(),
"direccion" => $contacto->getDireccion(),
"correoElectronico" => $contacto->getCorreoElectronico(),
],
]
);
# Recuerda que puedes ver a cuántos afectó con $resultado->getModifiedCount()
return true;
}
public static function eliminar($id)
{
$baseDeDatos = self::obtenerBaseDeDatos();
$coleccion = $baseDeDatos->contactos;
$resultado = $coleccion->deleteOne(
// El criterio, algo así como where
["_id" => new MongoDB\BSON\ObjectId($id)]
);
return $resultado->getDeletedCount() === 1;
}
}
Nota: tal vez con el paso del tiempo ya actualicé el código, pero no te preocupes, el archivo actualizado siempre estará en el repositorio de GitHub.
El controlador
Un simple pegamento. Evalúa la url y dependiendo de ello incluye las vistas. También se encarga de definir variables que son “pasadas” a las vistas, gracias al modelo.
Todo eso está en el index.
Las vistas
Simples archivos de PHP que renderizan y proveen una interfaz gráfica. Están separadas por la acción que hacen, y la mayoría de veces son incluidas con el encabezado y pie.
La seguridad
No he validado nada, es un simple ejercicio. Me parece que la seguridad es la cosa más importante en los sistemas, pero no lo he puesto por simplicidad.
Una clase
Para simplificar cosas, hice una clase que permitirá que las funciones queden más cortas (como cuando conectamos MySQL con Go).
hola amigo, muy bien pero faltarian las rutas para poder cargar las vistas
Están en el repositorio. Lea el post de nuevo y detenidamente
Hola que tal amigo, yo estoy haciendo algo parecido a lo que muestras en este tutorial, quiero ver como funciona para tratar de adaptarlo a mi proyecto. Descargue tu codigo de GitHub y al intentar ejecutarlo me muestra el siguiente error:
Fatal error: Uncaught MongoDB\Driver\Exception\AuthenticationException: Authentication failed. in C:\xampp\htdocs\ClasesMongoDB\vendor\mongodb\mongodb\src\Operation\Find.php:299 Stack trace: #0 C:\xampp\htdocs\ClasesMongoDB\vendor\mongodb\mongodb\src\Operation\Find.php(299): MongoDB\Driver\Server->executeQuery(‘agenda.contacto…’, Object(MongoDB\Driver\Query), Array) #1 C:\xampp\htdocs\ClasesMongoDB\vendor\mongodb\mongodb\src\Collection.php(624): MongoDB\Operation\Find->execute(Object(MongoDB\Driver\Server)) #2 C:\xampp\htdocs\ClasesMongoDB\ContactosModel.php(45): MongoDB\Collection->find() #3 C:\xampp\htdocs\ClasesMongoDB\index.php(16): ContactosModel::obtenerTodos() #4 {main} thrown in C:\xampp\htdocs\ClasesMongoDB\vendor\mongodb\mongodb\src\Operation\Find.php on line 299
Note que tu codigo no tiene la carpeta de vendor con las dependencias de MongoDB, asi que la instale yo mismo, pero el error aun sigue, como puedo corregirlo?
Gracias de antemano
Hola, qué tal. La excepción te está diciendo el problema: falló la autenticación. Verifica que tus credenciales sean correctas, que el host y puerto estén correctos, y que el servicio de Mongo se esté ejecutando. También intenta conectarte con Robomongo: https://parzibyte.me/blog/2018/10/29/instalar-robomongo-en-windows-10-mongodb/
Espero que se solucione tu problema 🙂 te invito a seguirme en mis redes sociales para estar al tanto de mis actualizaciones.
Gracias por responder, no me di cuenta del mensaje de autenticacion, ya he empezado a ver tu blog, estoy precisamente viendo el post de creacion de usuarios en MongoDB, y tengo instalado Robo 3T, una duda cuando termine de hacer mi usuario y habilite la autenticacion Robo 3T detectará estos cambios automaticamente? o Debo hacer algo mas?
Crea tus usuarios normalmente y cierra Robo 3T, luego de eso vuelve a abrirlo y crea una nueva conexión; coloca tus credenciales y la conexión se guardará, más tarde simplemente conecta y ya podrás administrar tu base de datos
Que tal, ya he podido probar tu ejemplo, esta genial, pero tengo unas dudas, cuando haces el guardado desde el formulario, los datos de los campos a donde se envían, veo que usas “action=?q=guardar”, pero no entiendo como es esta parte, me supongo que lo envias a Contacto.php, y posteriormene en ContactModel.php traes los datos para insertarlos a la BD con los getters.
Podrías explicar mejor esa parte porfavor?
Hola, como estamos en index.php se evalúa en el case a “guardar” y luego de eso se ejecuta lo que hay en el index en la línea 36 como se ve aquí: https://github.com/parzibyte/crud_mongodb_php/blob/master/index.php#L36