Laravel SSL соединение с MySQL не работает - PullRequest
0 голосов
/ 14 сентября 2018

Я работаю над проектом, в котором мне нужно использовать SSL для подключения к базе данных MySQL. Это работает в ванильном PHP, но не тогда, когда я пытаюсь использовать Laravel.

Рабочий PHP-код:

<?php
$host = 'xxx';
$db = 'xxx';
$user = 'xxx';
$pass = 'xxx';
$charset = 'utf8';

$dsn = "mysql:host=$host;dbname=$db;charset=$charset";
$options = [
    PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
    PDO::ATTR_EMULATE_PREPARES => false,
    PDO::MYSQL_ATTR_SSL_VERIFY_SERVER_CERT => false,
    PDO::MYSQL_ATTR_SSL_CA => "../rootCA.pem",
];

try {
    $pdo = new PDO($dsn, $user, $pass, $options);
} catch (\PDOException $e) {
    throw new \PDOException($e->getMessage(), (int)$e->getCode());
}

$data = $pdo->query('SELECT * FROM x LIMIT 100')->fetchAll(PDO::FETCH_ASSOC);
var_export($data);

Но когда я пытаюсь подключиться через Laravel, я получаю следующую ошибку:

C:\*\*\vendor\laravel\framework\src\Illuminate\Database\Connection.php on line 330
[Fri Sep 14 11:35:05 2018] ::1:54869 [500]: /data - Allowed memory size of 134217728 bytes exhausted (tried to allocate 4096 bytes) in C:\*\*\vendor\laravel\framework\src\Illuminate\Database\Connection.php on line 330

Конфигурация My Laravel (5.7) для подключения:

    'mysql' => [
        'driver' => 'mysql',
        'host' => env('DB_HOST', 'xxx'),
        'port' => env('DB_PORT', 'xxx'),
        'database' => env('DB_DATABASE', 'xxx'),
        'username' => env('DB_USERNAME', 'xxx'),
        'password' => env('DB_PASSWORD', ''),
        'unix_socket' => env('DB_SOCKET', ''),
        'charset' => 'utf8',
        'collation' => 'utf8_unicode_ci',
        'prefix' => '',
        'strict' => false,
        'engine' => null,
        'options' => array(
            PDO::MYSQL_ATTR_SSL_CA  => '../rootCA.pem',
            PDO::MYSQL_ATTR_SSL_VERIFY_SERVER_CERT => false
        ),
    ],

Есть идеи? =)

Ответы [ 2 ]

0 голосов
/ 23 сентября 2018

Проблема была не в том, что он сам подключен. Это было то, что я пытался извлечь много строк из моего SQL-запроса, который (очень странно) выдавал мне сообщения об ошибках вроде:

Не удалось выполнить операцию SSL с кодом 1. Сообщения об ошибках OpenSSL: ошибка: 1408F10B: процедуры SSL: ssl3_get_record: неправильный номер версии

и т.д.. Так что мой плохой - но я надеялся, что сообщения об ошибках могли бы быть лучше.

0 голосов
/ 14 сентября 2018

Вам необходимо указать полный путь к файлам.

'options' => [
    PDO::MYSQL_ATTR_SSL_KEY => base_path('ssl/client-key.pem'),
    PDO::MYSQL_ATTR_SSL_CERT => base_path('ssl/client-cert.pem'),
    PDO::MYSQL_ATTR_SSL_CA => base_path('ssl/ca-cert.pem')
]

См. Ссылку: Как подключиться к базе данных MySQL через SSL с помощью Laravel 5.3

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...