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;
}