Модераторы: skyboy, MoLeX, Aliance, ksnk

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> функционал LIKE при сохранении безопасности 
V
    Опции темы
Pitlord
Дата 27.11.2009, 18:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 246
Регистрация: 31.10.2009

Репутация: нет
Всего: 7



mysql_real_escape_string() всегда должен быть для корректного формирования строки в SQL-запросе, с безопасностью это никак не связано.

Сам паттерн LIKE'а тоже содержит спец. символы: "%", "_", "\"  Но не имеет смысла их экранировать в данной ситуации, поскольку тогда пропадает смысл LIKE. Или используй просто "=".

Добавлено через 2 минуты и 52 секунды
Хотя иногда делают так:
Код

<?php

function like_pattern_escape($s)
{
    return addCslashes($s, '\\_%');
}

$es = mysql_real_escape_string(like_pattern_escape($s));
$query = "SELECT ... `s` LIKE '%{$es}%';";

?>


Это сообщение отредактировал(а) Pitlord - 27.11.2009, 18:27
PM MAIL   Вверх
bars80080
Дата 27.11.2009, 18:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


прапор творюет
****
Награды: 1



Профиль
Группа: Завсегдатай
Сообщений: 12022
Регистрация: 5.12.2007
Где: Königsberg

Репутация: 9
Всего: 315



Цитата(Pitlord @  27.11.2009,  17:26 Найти цитируемый пост)
 "%", "_", "\"

да, такие символы нужны


Цитата(Pitlord @  27.11.2009,  17:26 Найти цитируемый пост)
Хотя иногда делают так

честно говоря, это "иногда" убивает. 

вопрос же простой, если приходящую строку, которую впоследствии подставлю после LIKE, буду обрабатывать только mysql_real_escape_string(), этого хватит, чтобы пользователь не набедокурил?
/подставляться будет только в запросе select/

в смысле, чтобы он не вырвался за пределы запроса и не добавил какое-нибудь drop ... и т.п.

в документации что-то написано про енту замену слэшей. касательно моего вопроса я могу сделать вывод только, что всё будет в порядке.
из ваших постов после Скайбоя не понятно. то ли делай двойной mysql_real_escape_string, то ли не делай

истина где-то рядом, но к какой подошве она у меня прилипла?
PM MAIL WWW   Вверх
Pitlord
Дата 27.11.2009, 18:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 246
Регистрация: 31.10.2009

Репутация: нет
Всего: 7



Цитата(bars80080 @  27.11.2009,  18:39 Найти цитируемый пост)
вопрос же простой, если приходящую строку, которую впоследствии подставлю после LIKE, буду обрабатывать только mysql_real_escape_string(), этого хватит, чтобы пользователь не набедокурил?

Слабо в мануал по MySQL глянуть, а не PHP (хотя и туда ты тоже не особо захаживаешь похоже)? 

Цитата(bars80080 @  27.11.2009,  18:39 Найти цитируемый пост)
в смысле, чтобы он не вырвался за пределы запроса и не добавил какое-нибудь drop ... и т.п.

Налицо отсутствие понимания того, что ты делаешь такими функциями, как mysql_real_escape_string, htmlspecialchars, urlencode и пр.

Цитата(bars80080 @  27.11.2009,  18:39 Найти цитируемый пост)
в документации что-то написано про енту замену слэшей. касательно моего вопроса я могу сделать вывод только, что всё будет в порядке.
из ваших постов после Скайбоя не понятно. то ли делай двойной mysql_real_escape_string, то ли не делай

Если кратко, то если бекслеш не экранировать, то это позволит пользователю искать символы "%" и "_". Если экранировать — они будут фигурировать только в качестве спец. символов LIKE и не более.

Это сообщение отредактировал(а) Pitlord - 27.11.2009, 18:55
PM MAIL   Вверх
Ипатьев
Дата 27.11.2009, 18:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2232
Регистрация: 5.7.2009

Репутация: 3
Всего: 37



Цитата(Pitlord @  27.11.2009,  18:54 Найти цитируемый пост)
Если кратко, то если бекслеш не экранировать, то это позволит пользователю искать символы "%" и "_". Если экранировать — они будут фигурировать только в качестве спец. символов LIKE и не более.

мне кажется, это заблуждение.
PM MAIL   Вверх
Pitlord
Дата 27.11.2009, 19:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 246
Регистрация: 31.10.2009

Репутация: нет
Всего: 7



Цитата(Ипатьев @  27.11.2009,  18:59 Найти цитируемый пост)
мне кажется, это заблуждение. 

Тебе что-то кажется, а я просто знаю.

Добавлено через 1 минуту и 3 секунды
Хотите разговаривать по сути — приводите примеры. У вас же просто танцы с бубном вокруг темы экранирования символов. "Надо или не надо экранировать?"
PM MAIL   Вверх
Ипатьев
Дата 27.11.2009, 19:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2232
Регистрация: 5.7.2009

Репутация: 3
Всего: 37



Насколько я вижу в документации, там ничего не написано про символы "%" и "_" в связи с рекомендацией экранировать слеш
PM MAIL   Вверх
bars80080
Дата 27.11.2009, 19:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


прапор творюет
****
Награды: 1



Профиль
Группа: Завсегдатай
Сообщений: 12022
Регистрация: 5.12.2007
Где: Königsberg

Репутация: 9
Всего: 315



Цитата(Pitlord @  27.11.2009,  17:54 Найти цитируемый пост)
Слабо в мануал по MySQL глянуть, а не PHP (хотя и туда ты тоже не особо захаживаешь похоже)? 
по этому поводу уже говорил выше

Цитата(Pitlord @  27.11.2009,  17:54 Найти цитируемый пост)
Налицо отсутствие понимания того, что ты делаешь такими функциями, как mysql_real_escape_string, htmlspecialchars, urlencode и пр.

спасибо, за замечание


Цитата(Pitlord @  27.11.2009,  17:54 Найти цитируемый пост)
Если кратко, то если бекслеш не экранировать, то это позволит пользователю искать символы "%" и "_". Если экранировать — они будут фигурировать только в качестве спец. символов LIKE и не более.

ну, и страшно, что они будут искать эти самые символы?


Цитата(Pitlord @  27.11.2009,  18:06 Найти цитируемый пост)
Хотите разговаривать по сути — приводите примеры. У вас же просто танцы с бубном вокруг темы экранирования символов. "Надо или не надо экранировать?"

пример? что угодно. я не знаю, на какую комбинацию пробьёт пользователя
PM MAIL WWW   Вверх
Pitlord
Дата 27.11.2009, 19:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 246
Регистрация: 31.10.2009

Репутация: нет
Всего: 7



Цитата(Ипатьев @  27.11.2009,  19:38 Найти цитируемый пост)
Насколько я вижу в документации, там ничего не написано про символы "%" и "_" в связи с рекомендацией экранировать слеш 

В какой документации? Экранировать для чего — интерпретации строки в SQL-запросе, интерпретации паттерна LIKE?

Цитата(bars80080 @  27.11.2009,  19:52 Найти цитируемый пост)
ну, и страшно, что они будут искать эти самые символы?

Это ты себе вопрос задай, я тебе просто сказал что будет если экранировать и что — если нет.

Цитата(bars80080 @  27.11.2009,  19:52 Найти цитируемый пост)
пример?

Я не тебе в данном случае говорил. Тебе просто курить мануал:
http://dev.mysql.com/doc/refman/5.0/en/str...l#operator_like
http://dev.mysql.com/doc/refman/5.0/en/string-syntax.html
PM MAIL   Вверх
Ипатьев
Дата 27.11.2009, 20:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2232
Регистрация: 5.7.2009

Репутация: 3
Всего: 37



По ссылке написано про экранирование "%" и "_"
А я говорил про экранирование "\".
Которое никак с первым не связано
PM MAIL   Вверх
Pitlord
Дата 27.11.2009, 20:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 246
Регистрация: 31.10.2009

Репутация: нет
Всего: 7



Цитата(Ипатьев @  27.11.2009,  20:07 Найти цитируемый пост)
По ссылке написано про экранирование "%" и "_" А я говорил про экранирование "\".


Цитата

To test for literal instances of a wildcard character, precede it by the escape character. If you do not specify the ESCAPE character, “\” is assumed. 


Код

CREATE TABLE `testtable` (
`s` VARCHAR( 100 ) NOT NULL
);

INSERT INTO `testtable` ( `s` )
VALUES (
'\\%'
);

Попробуй с помощью LIKE, без использования "%" и "_" в качестве спец. символов, найти строку с записью "\%".
PM MAIL   Вверх
Ипатьев
Дата 27.11.2009, 20:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2232
Регистрация: 5.7.2009

Репутация: 3
Всего: 37



и то и другое надо экранировать, но слеш - дважды.

PM MAIL   Вверх
bars80080
Дата 27.11.2009, 20:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


прапор творюет
****
Награды: 1



Профиль
Группа: Завсегдатай
Сообщений: 12022
Регистрация: 5.12.2007
Где: Königsberg

Репутация: 9
Всего: 315



Цитата(Pitlord @  27.11.2009,  18:59 Найти цитируемый пост)
Это ты себе вопрос задай, я тебе просто сказал что будет если экранировать и что — если нет.

зачем просто говорить, если можно просто ответить?


Цитата(Pitlord @  27.11.2009,  18:59 Найти цитируемый пост)
Я не тебе в данном случае говорил. Тебе просто курить мануал:
http://dev.mysql.com/doc/refman/5.0/en/str...l#operator_like
http://dev.mysql.com/doc/refman/5.0/en/string-syntax.html 

не курю. мануалы я читаю. 
прочитал, ничего нового не узнал. и всё равно, совершенно не догоняю, что после поста Скайбоя вы мне пытаетесь втолковать. по ссылкам написано, что никакая последовательность символов не может выйти за пределы строки, если она была преобразована с помощью mysql_real_escape_string().
PM MAIL WWW   Вверх
Pitlord
Дата 27.11.2009, 20:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 246
Регистрация: 31.10.2009

Репутация: нет
Всего: 7



Цитата(Ипатьев @  27.11.2009,  20:35 Найти цитируемый пост)
и то и другое надо экранировать, но слеш - дважды.

Ну вот, теперь правильно.

По-хорошему, должно быть так:
Код

SELECT @a := '\\%', @b := '\\\\\\%', @a LIKE @b -- Вернёт "1"


Но будет работать и так:
Код

SELECT @a := '\\%', @b := '\\\\\%', @a LIKE @b -- Вернёт "1"

...., но это запутывает.

Проверить, что мы не соврали можно, заменив "%" на "_":
Код

SELECT @a := '\\%', @b := '\\\\\\_', @a LIKE @b -- Вернёт "0"


Добавлено через 1 минуту и 55 секунд
bars80080, короче, с безопасностью это никак не связано. Применил mysql_real_escape_string() — будет синтаксически корректная строка, ошибок не будет. "Вылезти" куда-то там нельзя.
PM MAIL   Вверх
Ипатьев
Дата 27.11.2009, 20:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2232
Регистрация: 5.7.2009

Репутация: 3
Всего: 37



Цитата(Pitlord @  27.11.2009,  20:41 Найти цитируемый пост)
Ну вот, теперь правильно.

а я ничего другого и не говорил.
но слеш надо экранировать дважды не поэтому. если мы ищем его одного, без %, то все равно дважды smile

Это сообщение отредактировал(а) Ипатьев - 27.11.2009, 20:48
PM MAIL   Вверх
Pitlord
Дата 27.11.2009, 20:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 246
Регистрация: 31.10.2009

Репутация: нет
Всего: 7



Цитата(Ипатьев @  27.11.2009,  20:44 Найти цитируемый пост)
если мы ищем его одного, без %, то все равно дважды

Я что, говорю что-то противоположное?
PM MAIL   Вверх
Страницы: (3) Все 1 [2] 3 
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | PHP: Базы Данных | Следующая тема »


 




[ Время генерации скрипта: 0.0967 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.