С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
 Аватар для Nebiros
41 / 40 / 16
Регистрация: 23.03.2010
Сообщений: 3,122

безопасность получения сообщения

30.10.2010, 12:14. Показов 961. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вот приходит POSTом с <textarea> содержимое и помещяется в $message , что дальше делать , как фильтровать что бы никакой вредоносный текст введенный в поле не нарушил работу?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.10.2010, 12:14
Ответы с готовыми решениями:

Метод для получения последнего полученного сообщения
Искал этот метод в messages ничего не нашел нужного,в notifications,тоже пусто,а мне нужно вытащить последнее полученное письмо,вернее даже...

Баг в системе отправки=>получения сообщения с сайта
Не работает $from='message@sportassist.pro' = вместо етого используется основной мейл ( почему? ) ; а так же при вводе текста в форму на...

Разное время получения сообщения на двух компьютерах в оутлук 2010 с одного адреса
В двух разных кабинетах настроен оутлук 2010 на одинаковый адрес электронной почты. Письма на оба приходят одинаково, но вот время...

9
 Аватар для Vovan-VE
13210 / 6599 / 1041
Регистрация: 10.01.2008
Сообщений: 15,069
30.10.2010, 12:51
Минимум: Когда будете сохранять текст в БД, не забудьте заэкранировать все, что нужно. Когда будете его отображать обратно, не забудьте сделать htmlspecialchars() и опционально nl2br().

По вкусу дополнительная фильтрация: порезать длинные_слова_без_пробелов, убрать ненужные повторяющиеся пробельные символы (сначала надо подумать, а какие когда будут лишними, и когда не будут), и т.п.
1
 Аватар для Nebiros
41 / 40 / 16
Регистрация: 23.03.2010
Сообщений: 3,122
30.10.2010, 13:41  [ТС]
Цитата Сообщение от Vovan-VE Посмотреть сообщение
не забудьте сделать htmlspecialchars() и опционально nl2br().
чтото у меня с этим проблемки. залез сюда http://php.su/functions/?htmlspecialchars , делаю все по примеру но у них результат (&lt;a href='test'&gt;Test&lt;/a&gt, а у меня (<a href='test'>Test</a><a href='test'>Test</a>) , я даж не переписывал а тупо скопировал и ноль.
В чем моя ошибка , или то описание устарело?

Добавлено через 6 минут
Да кстати тут же по теме , если например в сообщении написать <script> alert('alert'); </script> то он выполнится на серверной стороне (проверял работает) но естественно за месть alert там можно что угодно за код написать. Как этого избежать?
0
 Аватар для Vovan-VE
13210 / 6599 / 1041
Регистрация: 10.01.2008
Сообщений: 15,069
30.10.2010, 14:09
Цитата Сообщение от Nebiros Посмотреть сообщение
но у них результат (&lt;a href=..., а у меня (<a href=
PHP
1
echo '<p>' . htmlspecialchars('<p></p>') . '</p>';
Цитата Сообщение от Nebiros Посмотреть сообщение
написать <script> alert('alert'); </script> то он выполнится на серверной стороне (проверял работает)
Во-первых, на сервере ничего не выполнится, а, во-вторых, если сделаете htmlspecialchars() по-человечески, то и у клиента будет порядок.
1
 Аватар для Nebiros
41 / 40 / 16
Регистрация: 23.03.2010
Сообщений: 3,122
30.10.2010, 14:23  [ТС]
Цитата Сообщение от Vovan-VE Посмотреть сообщение
echo '<p>' . htmlspecialchars('<p></p>') . </p>;
если так написать то будет ошибка , так как последнее </p> не в кавычках , но эт такое. Я так и непонял к чему его применить. вот у меня есть переменная $message коорую я получил постом , как все знаки перевести, просто $message=htmlspecialchars($message); не катит , хотя в описании читал должно преобразовать. А echo '<p>' . htmlspecialchars('<p></p>') . </p> что с этим делать непойму , не дошло еще обьясните?
0
 Аватар для Vovan-VE
13210 / 6599 / 1041
Регистрация: 10.01.2008
Сообщений: 15,069
30.10.2010, 14:26
Nebiros, Все правильно преобразуется. Было "<p>test</p>" и в браузер оно выводилось, как тег <p>. После htmlspecialchars() оно стало "&lt;p&gt;test&lt;/p&gt;" и в браузер оно стало выводиться, как текст "<p>test</p>", а не как тег. Вам это и надо.
1
 Аватар для Nebiros
41 / 40 / 16
Регистрация: 23.03.2010
Сообщений: 3,122
30.10.2010, 14:35  [ТС]
Цитата Сообщение от Vovan-VE Посмотреть сообщение
Nebiros, Все правильно преобразуется. Было "<p>test</p>" и в браузер оно выводилось, как тег <p>. После htmlspecialchars() оно стало "&lt;p&gt;test&lt;/p&gt;" и в браузер оно стало выводиться, как текст "<p>test</p>", а не как тег. Вам это и надо.
так проверил по подставлял и все получается кроме кавычек . Вот сдесь я так понял нужно правильно заэкранировать , текст с кавычками также не записывается в БД , короче у меня почемуто htmlspecialchars() - переводит все знаки кроме кавычек , что и как правильно сделать?
0
 Аватар для Vovan-VE
13210 / 6599 / 1041
Регистрация: 10.01.2008
Сообщений: 15,069
30.10.2010, 14:37
PHP
1
echo htmlspecialchars("test \" test ' test ", ENT_QUOTES); // test &quote; test &#0З9; test
1
 Аватар для Nebiros
41 / 40 / 16
Регистрация: 23.03.2010
Сообщений: 3,122
30.10.2010, 15:53  [ТС]
вот накопал решение

PHP
1
2
3
$message=$_POST['message'];
$message=addslashes($message);
$message=htmlspecialchars($message,ENT_QUOTES);
работает вроде нормально и записывает в базу и читает , безопасно но ли использовать такую конструкцию?
0
 Аватар для __PION__
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
31.10.2010, 03:12
Nebiros, чтобы было безопасно, надо все эти сра.. волшебные кавычки отключить с помощью файла .haccess и гемора с кавычками не будет, типа так
PHP
1
2
php_flag magic_quotes_gpc 0
php_flag magic_quotes_runtime 0
и сделать sql-инъекцию, т.е. заменить строковые данные из БД на %s, целоцисленные на %d, дроб. на %f ... и т.д.
если конечно я правильно понял твой вопрос
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
31.10.2010, 03:12
Помогаю со студенческими работами здесь

дата и время получения/отправки сообщения в БД "Почта"
Как сделать, что бы при отправке/получении сообщения отображались дата и время ?

Рассчитать, какое количество лет в среднем необходимо ожидать получения квартиры, и вывести на экран весь список с указанием ожидаемого года получения
Имеется список учета нуждающихся в улучшении жилищных условий. Каждая запись этого списка содержит фамилию, имя, отчество и дату постановки...

В файле mail.tpl не выводится заголовок сообщения {$subject} и текст сообщения {$message}
ребят помогите разобраться, изначально у меня все выводилось через функцию popupWindow вот сама функция JS function...

Пронумеровать очерёдность каждого сообщения так, чтобы нумерация очерёдности печаталась напротив сообщения
Покажите мне пожалуйста как можно пронумеровать очерёдность каждого сообщения так чтоб нумерация очерёдности печаталась напротив сообщения....

При быстрой победе в игре крестики_нолики не выводилось после сообщения победителя, другие сообщения
Как сделать что при быстрой победе в игре крестики_нолики не выводилось после сообщения победителя, ходит Х или 0. Может использовать...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru