Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Почему не работает addslashes и mysql_real_escape_string?

 PHP.SU

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


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

> Без описания
Rooner
Отправлено: 11 Декабря, 2012 - 17:53:27
Post Id


Посетитель


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


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




В php.ini магические ковычки отключены, также на странице стоит ini_set('magic_quotes_gpc', 0);
Добавляю в БД: Категория "A"
Перед добавлением применяю к данной строке mysql_real_escape_string или addslashes, но когда смотрю в БД, то вижу что данная строка не экранирована, у нее нет слэшей
Если применить к строке htmlspecialchars, то в БД строка экранируется
Почему не работает addslashes и mysql_real_escape_string?
 
 Top
Мелкий Супермодератор
Отправлено: 11 Декабря, 2012 - 18:11:08
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


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




Rooner пишет:
когда смотрю в БД

Там их и не должно быть.
Экранирование нужно, чтобы парсер SQL понял, где данные, а где - команды.


-----
PostgreSQL DBA
 
 Top
Rooner
Отправлено: 12 Декабря, 2012 - 09:25:51
Post Id


Посетитель


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


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




Мелкий, понятно, а можно ли потом, при вытаскивании из БД, в mysql запросе убрать экранирование?
 
 Top
EuGen Администратор
Отправлено: 12 Декабря, 2012 - 09:27:28
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


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






-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
Мелкий Супермодератор
Отправлено: 12 Декабря, 2012 - 09:34:19
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


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




Rooner пишет:
при вытаскивании из БД, в mysql запросе убрать экранирование?

В запросе - ни в коем случае. SQL-инъекция будет.
В ответе на запрос - экранирования не будет. А если вы дважды или более раз зачем-то экранировали (например, упомянутые магические кавычки были по ошибке включены + mysql_real_escape_string применили) - то stripslashes, да.


-----
PostgreSQL DBA
 
 Top
Rooner
Отправлено: 12 Декабря, 2012 - 09:45:50
Post Id


Посетитель


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


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




EuGen, с этим ясно, возвращаюсь к вопросу. Объясните пожалуйста почему в инпуте не выводятся ковычки и все что после них?
Вот пример:
PHP:
скопировать код в буфер обмена
  1. $text = addslashes('Категория "Б" и "В"');
  2. echo $text;
  3. $query = "INSERT test SET text='".$text."'";
  4. $data = mysql_query($query) or die;
  5.  
  6. $query = "SELECT * FROM test";
  7. $data = mysql_query($query) or die;
  8. $row = mysql_fetch_assoc($data);
  9. echo '<br />'.$row['text'];
  10. echo '<br /><input type="text" name="text" value="'.$row['text'].'"/>';


Результат:
CODE (html):
скопировать код в буфер обмена
  1. Категория \"Б\" и \"В\"
  2. Категория "Б" и "В"
  3. в инпуте: Категория
 
 Top
EuGen Администратор
Отправлено: 12 Декабря, 2012 - 09:50:59
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


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




Потому что при подстановке в
Rooner пишет:
value="'.$row['text'].'"

- подставятся и кавычки. И первая кавычка закроет атрибут value у Вашего input-поля.
Например, htmlentities решит эту проблему.


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
Rooner
Отправлено: 12 Декабря, 2012 - 10:06:27
Post Id


Посетитель


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


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




EuGen, не пойму к чему Вы предлагаете применить htmlentities?
 
 Top
EuGen Администратор
Отправлено: 12 Декабря, 2012 - 10:07:35
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


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




PHP:
скопировать код в буфер обмена
  1. echo '<br /><input type="text" name="text" value="'.htmlentities($row['text']).'"/>';


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
Rooner
Отправлено: 12 Декабря, 2012 - 10:13:36
Post Id


Посетитель


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


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




EuGen, сначала я так и сделал, но скрипт мне в инпуте вывел
CODE (html):
скопировать код в буфер обмена
  1. Р&#65533;Р°С&#65533;егоС&#65533;РёС

Что-то не то Однако
(Добавление)
А кодировка не та, вот так работает:
PHP:
скопировать код в буфер обмена
  1. echo '<br /><input type="text" name="text" value="'.htmlentities($row['text'], ENT_QUOTES, "UTF-8").'"/>';

EuGen, спасибо
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB