![]() |
Ошибка при использовании mysql_real_escape_string()
Здравствуйте. У меня довольно давно есть проблема с mysql_real_escape_string(), всё никак не могу решить, в чём дело. Однажды перевели форум IPB (v1.3 Final) на PHP5 / MySQL5, начались траблы. Все остальные варнинги давно уже вычистил, а тут - никак, периодически всплывает. Мешает, в логи мусор валится, устаешь :]
Итак, PHP5 / MySQL5, ошибка такая: [error] PHP Warning: mysql_real_escape_string() [<a href='function.mysql-real-escape-string'>function.mysql-real-escape-string</a>]: Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2) Я уже несколько раз пытался переписать код, только хуже становилось :] Синтаксис mysql_real_escape_string: string mysql_real_escape_string ( string unescaped_string [, resource link_identifier] ) Происходит это в коде вида такого: PHP код:
Соединение с базой выполняется буквально перед использованием mysql_real_escape_string(): Код:
$DB->connect(); Как это починить? Есть одна мысль, в принципе, но она уж какая-то бредовая и её проверка требует времени :-/ Может, у кого-то есть уже опыт работы с этим? |
Попытайтесь определить было ли успешным соединение с базой. А то возможно, что просто вышел лимит соединений и $DB->connect(); дали отлуп.
|
Цитата:
Цитата:
hasherfrog, А только с этой функцией проблемы? а как другие mysql_* фукнции себя ведут? |
"Мега-Мысль" свою проверил, как и подозревал, бредятина :-)
>> А только с этой функцией проблемы? а как другие mysql_* фукнции себя ведут? Только с этой. Остальные, может, когда-то что-то писали по мелочи, но я в конечном итоге всё разрулил, пусть даже косвенно. >> Или посмотреть, есть ли ещё соединение. >> Попытайтесь определить было ли успешным соединение с базой Как? В этом-то и затык. Я чего-то "теоретически", видимо, не понимаю. Что такое это "соединение"? Цитата:
Переменная connection_id в классе db_driver определена как var connection_id = ""; и её значение внутри connect() инициализируется так: PHP код:
??? Как быть? Как проверить, нее потерялось ли оно, это соединение? И как (если уж на то пошло) оно вообще "теряется" (или не устанавливается, но без ошибки[!] при этом) в теории? |
hasherfrog,
Проверьте значение connection_id Если False, то соединение не успешно, если же имеет какоето значение, значит соединение произошло |
может просто mysql_escape_string? разница в них не очень большая.
|
Цитата:
|
Всё, исправил, спасибо всем.
В общем, я проверяю connection_id, потом, в зависимости от результата, пользуюсь либо mysql_escape_string, либо mysql_real_escape_string(). Ошибки вроде пропали. Немного тревожит использование mysql_escape_string(), но в контексте кода (там ещё проверка на валидность маске IP) инъекция вряд ли возможна. |
Время: 09:06. |
Время: 09:06.
© OSzone.net 2001-