Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В. PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В. Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум (новые сообщения вниз) Структурный форум

тема: Учет невозможности соединения с базой

Сообщения:  [1-2] 

 
 автор: cheops   (19.02.2009 в 00:24)   письмо автору
 
   для: Владимир55   (18.02.2009 в 17:13)
 

return - это возврат из функции или включаемого файла, не выполняются лишь дальнейшие инструкции функции или файла. А так да, лучше и надежнее использовать die() или exit() - вы движитесь в совершенно верном направлении, затачивая логику скрипта под свои нужды.

  Ответить  
 
 автор: Владимир55   (18.02.2009 в 17:13)   письмо автору
 
 

Я делаю скрипт сбора статистики, подключаемый к каждой html странице сайта.
Для соединения с базой я использую такую типовую конструкцию, позаимстванную из счетчика softtime:
      // Соединяемся с сервером базы данных
      $dbcnx = @mysql_connect($dblocation, $dbuser, $dbpasswd);
      if(!$dbcnx) return;

      // Выбираем базу данных
      if(!@mysql_select_db($dbname,$dbcnx)) exit();


Функцию return я досконально не знаю, но понимаю её так, что в случае неудачного соединения происходит выход из скрипта, обращающегося к базе. (Не знаю, в чем отличие от exit).

Это так?

Соотвественно, после выхода из скрипта продолжается открытие html страницы, так что от отказа базы посетитель совершенно не страдает.

Однако ситуация в корне меняется, когда этот же фрагмет кода я использую на странице контроля пароля. В этом случае при отказе бызы посетитель "проскакивает" контроль насквозь и даже не ощущает его существования.

Как изменить подключение базы таким образом, чтобы при отказе (независимо от причин) останавливалось открытие страницы?

Может быть, так:
      // Соединяемся с сервером базы данных
      $dbcnx = @mysql_connect($dblocation, $dbuser, $dbpasswd);
      if(!$dbcnx) die ("Система отключена");

      // Выбираем базу данных
      if(!@mysql_select_db($dbname,$dbcnx)) die("Система отключена");

  Ответить  

Сообщения:  [1-2] 

Форум разработан IT-студией SoftTime
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования