forked from cefireazure2505/php-docs-hello-world
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathconexion.php
More file actions
39 lines (39 loc) · 1.29 KB
/
conexion.php
File metadata and controls
39 lines (39 loc) · 1.29 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
<?php
// Recuperar variables de entorno
$dbHost = getenv('DB_HOST');
$dbName = "prueba";
$dbUser = getenv('DB_USER');
$dbPass = getenv('DB_PASSWORD');
if (!$dbHost || !$dbUser || $dbPass === false) {
throw new \RuntimeException('Faltan variables de entorno para la
conexión a la base de datos.');
}
// DSN con charset utf8mb4
$dsn = "mysql:host={$dbHost};dbname={$dbName};charset=utf8mb4";
try {
$options = [
// Excepciones en errores
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
// Fetch como array asociativo
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
// Desactivar emulación de prepares
PDO::ATTR_EMULATE_PREPARES => false,
// Asegurar la conexión TLS hacia Azure Database for MySQL
PDO::MYSQL_ATTR_SSL_CA =>
'/etc/ssl/certs/BaltimoreCyberTrustRoot.crt.pem',
// Desactivamos la validación del certificado SSL
PDO::MYSQL_ATTR_SSL_VERIFY_SERVER_CERT => false,
];
// Crear la conexión PDO
$pdo = new PDO($dsn, $dbUser, $dbPass, $options);
// Ejemplo: consulta sencilla
$stmt = $pdo->query('SELECT NOW() AS fecha_actual;');
$fila = $stmt->fetch();
echo "Conectado correctamente. Hora del servidor: " .
$fila['fecha_actual'];
} catch (PDOException $e) {
error_log('Error de conexión PDO: ' . $e->getMessage());
echo "Error al conectar con la base de datos: " .
htmlspecialchars($e->getMessage());
exit;
}