|
|
|
| Я делаю скрипт сбора статистики, подключаемый к каждой 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("Система отключена");
|
| |
|
|
|
|
|
|
|
для: Владимир55
(18.02.2009 в 17:13)
| | return - это возврат из функции или включаемого файла, не выполняются лишь дальнейшие инструкции функции или файла. А так да, лучше и надежнее использовать die() или exit() - вы движитесь в совершенно верном направлении, затачивая логику скрипта под свои нужды. | |
|
|
|