Saltar al contenido

¿Definiendo la conexión MySQL en Slim Framework?

Solución:

Lo primero es lo primero: abra el archivo src / settings.php y configure los detalles de conexión de la base de datos en la matriz de configuración como se muestra a continuación.

<?php
return [
  'settings' => [
      'displayErrorDetails' => true, // set to false in production

      // Renderer settings
      ....
      ....    

      // Monolog settings
      ....
      ....

      // Database connection settings
      "db" => [
          "host" => "localhost",
          "dbname" => "slim3",
          "user" => "root",
          "pass" => "xxxxx"
      ],
   ],
];

Hay muchas bibliotecas de bases de datos disponibles para PHP, pero este ejemplo usa PDO. Ahora abra su archivo src / dependencies.php y configure la biblioteca de la base de datos como se muestra a continuación. puede utilizar sus propias bibliotecas adaptando el ejemplo.

// DIC configuration
$container = $app->getContainer();

...
...
...

// PDO database library
$container['db'] = function ($c) {
    $settings = $c->get('settings')['db'];
    $pdo = new PDO("mysql:host=" . $settings['host'] . ";dbname=" . $settings['dbname'],
        $settings['user'], $settings['pass']);
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    $pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
    return $pdo;
};

a través de: https://arjunphp.com/configure-load-database-slim-framework-3/

Es mejor mantener estas credenciales en un archivo de configuración local. Agrego una carpeta de configuración fuera de la raíz web y agrego un archivo de configuración local.php a eso.

....
/configs
    local.php
/public
/vendor
....

Puede configurar lo que quiera, pero aquí está la base de datos:

<?php
// configs/local.php
return array(
    'db' => ['user' => 'root', 'password' => 'root']
);

Luego incluye el archivo en tu aplicación y crea la conexión:

// public/index.php
$config = include(__DIR__ . '/../configs/local.php');
$db = new PDO("mysql:host=localhost;dbname=dbname", $config['db']['user'], $config['db']['password'] );

$app->get("https://foroayuda.es/", function () use ($app, $db) {
    // do something with your db connection
});

Puede definir una función en su archivo (por ejemplo, index.php)

    function getConnection() {
    $dbhost="yourdbhost";
    $dbuser="yourdbuser";
    $dbpass="yourdbpass";
    $dbname="yourdb";
    $dbh = new PDO("mysql:host=$dbhost;dbname=$dbname", $dbuser, $dbpass);  
    $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    return $dbh;
    }
¡Haz clic para puntuar esta entrada!
(Votos: 0 Promedio: 0)


Tags : / /

Utiliza Nuestro Buscador

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *