Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5/6. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Разное

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Обратные кавычки на форуме
 
 автор: cheops   (16.08.2006 в 23:41)   письмо автору
 
 

На форуме теперь допускается использование обратных кавчек
`ls -l`

   
 
 автор: Loki   (16.08.2006 в 23:59)   письмо автору
 
   для: cheops   (16.08.2006 в 23:41)
 

А прямых?:)

'ls -l'

Афигеть! Дайте две!!:)

   
 
 автор: cheops   (17.08.2006 в 01:25)   письмо автору
 
   для: Loki   (16.08.2006 в 23:59)
 

Всё оказалось не так болезненно как я думал :))) Замена всех кавычек в 100 Мб базе занимает не больше 20 секунд на хорошем сервере - лишнее подтверждение тезиса, что человек является лимитирующей стадией :))) Причём записей оказалось всего около 20000 (из 120000).

   
 
 автор: Trianon   (17.08.2006 в 09:37)   письмо автору
 
   для: cheops   (17.08.2006 в 01:25)
 

Что не может не радовать! :)))

хих.... дожали cheops'a таки совместными усилиями...:))))

   
 
 автор: Trianon   (17.08.2006 в 15:39)   письмо автору
 
   для: Trianon   (17.08.2006 в 09:37)
 

так-с.... вот и баги...

function click_link()
  {
    this.form.message.value = this.form.message.value + '<?php echo ">".wordwrap($str,60,"\\n>"); ?>';
  }

Здесь явно напрашивается для результата wordwrap($str) экранирование апострофа и обратного слэша перед выводом. Хотя бы с помощью addslashes(). Иначе формируется кривая строка и цитирование не работает.

С wordwrap , правда, не всё просто. Здесь он режет строку по-живому... Вероятно, нужно будет сделать вместо него replace.

Дырку нужно закрывать достаточно оперативно. Возможны XSS.

   
 
 автор: Loki   (17.08.2006 в 15:53)   письмо автору
 
   для: Trianon   (17.08.2006 в 15:39)
 

Я думаю что надо проще:
сначала применяем wordwrap, а уж потом - addslashes().

   
 
 автор: Trianon   (17.08.2006 в 15:59)   письмо автору
 
   для: Loki   (17.08.2006 в 15:53)
 

тогда не выйдет перевод строки. Заэкранирован окажется.

   
 
 автор: Loki   (17.08.2006 в 16:06)   письмо автору
 
   для: Trianon   (17.08.2006 в 15:59)
 

а если в wordwrap использовать не "\\n>", а просто "\n>" то как раз будет добавлен необходимый слеш:)

   
 
 автор: Trianon   (17.08.2006 в 16:08)   письмо автору
 
   для: Loki   (17.08.2006 в 16:06)
 

Не будет. Он будет преобразован в LF интерпретатором PHP
Получится ошибка синтаксиса.
Готовить правильное разбиение нужно до замены CRLF на \r\n

Вот какая получается пакость, когда переход от языка к языку выполняется несогласованно... :(

   
 
 автор: cheops   (17.08.2006 в 16:51)   письмо автору
 
   для: Trianon   (17.08.2006 в 15:39)
 

>так-с.... вот и баги...
>

>function click_link()
>  {
>    this.form.message.value = this.form.message.value + '<?php echo ">".wordwrap($str,60,"\n>"); ?>';
>  }
>

>Здесь явно напрашивается для результата wordwrap($str) экранирование апострофа и обратного слэша перед выводом. Хотя бы с помощью addslashes(). Иначе формируется кривая строка и цитирование не работает.
>
>С wordwrap , правда, не всё просто. Здесь он режет строку по-живому... Вероятно, нужно будет сделать вместо него replace.
>
>Дырку нужно закрывать достаточно оперативно. Возможны XSS.

Да, какие-то старые файлы просочились... вообще там имеется экранирование, только одинарная кавычка почему-то не экранировалась - исправил.

   
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования