PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
db9vol
Отправлено: 03 Января, 2021 - 22:54:34
Post Id


Новичок


Покинул форум
Сообщений всего: 1
Дата рег-ции: Янв. 2021  


Помог: 0 раз(а)




Здравствуйте!Не могу понять в чем проблема. Вообщем при авторизации вот такое:

CODE (text):
скопировать код в буфер обмена
  1. Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[3D000]: Invalid catalog name: 1046 No database selected' in Z:\home\test1.ru\www\engine\controllers\Accounts.class.php:36 Stack trace: #0 Z:\home\test1.ru\www\engine\controllers\Accounts.class.php(36): PDOStatement->execute() #1 Z:\home\test1.ru\www\engine\core\Router.php(76): Accounts->auth() #2 Z:\home\test1.ru\www\index.php(95): Router::dispatch() #3 {main} thrown in Z:\home\test1.ru\www\engine\controllers\Accounts.class.php on line 36


Соединение с базой:
data.json
CODE (text):
скопировать код в буфер обмена
  1.  {
  2.   "db_name": "123"
  3.   "db_host": "localhost"
  4.   "db_user": "123"
  5.   "db_pass": "zxczxc"
  6. }


CODE (text):
скопировать код в буфер обмена
  1. <?php
  2. class Database
  3. {
  4.     public $dbh;
  5.     public static function initialize()
  6.     {
  7.                 try
  8.                 {
  9.         $json = json_decode(file_get_contents('engine/models/data.json'), true);
  10.         return new PDO(
  11.             "mysql:dbname={$json['db_name']};host={$json['db_host']}",
  12.             $json['db_user'],
  13.             $json['db_pass'],
  14.             array (PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES 'utf8'")
  15.         );
  16.                 }
  17.                 catch(PDOException $e) {  
  18.         echo 'Возникли проблемы с подключением базы данных сервера. Сайт временно недоступен.';
  19.                 die();
  20.                 }
  21.     }
  22. }


В чем проблема? Заранее благодарю.
 
 Top
Vladimir Kheifets
Отправлено: 04 Января, 2021 - 07:55:24
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 596
Дата рег-ции: Март 2017  
Откуда: Германия, Бавария


Помог: 28 раз(а)




db9vol пишет:
Здравствуйте!Не могу понять в чем проблема. Вообщем при авторизации вот такое:

CODE (text):
скопировать код в буфер обмена
  1. Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[3D000]: Invalid catalog name: 1046 No database selected' ......


Соединение с базой:
data.json
CODE (text):
скопировать код в буфер обмена
  1.  {
  2.   "db_name": "123"
  3.   "db_host": "localhost"
  4.   "db_user": "123"
  5.   "db_pass": "zxczxc"
  6. }


CODE (text):
скопировать код в буфер обмена
  1. <?php
  2. class Database
  3. {
  4.     public $dbh;
  5.     public static function initialize()
  6.     {
  7.                 try
  8.                 {
  9.         $json = json_decode(file_get_contents('engine/models/data.json'), true);
  10.         ......
  11.        


В чем проблема? Заранее благодарю.

Добрый день!
У Вас ошибка в структуре JSON. $json = null. В data.json потеряли запятые. Д.б так
CODE (javascript):
скопировать код в буфер обмена
  1. {
  2.   "db_name": "123",
  3.   "db_host": "localhost",
  4.   "db_user": "123",
  5.   "db_pass": "zxczxc"
  6. }
Удачи!
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 1 (гостей: 1, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB