Новости Joomla

Перевод и публикация интервью на греческом портале Joomla Утро, просматриваешь входящие письма и...

Перевод и публикация интервью на греческом портале Joomla 🇬🇷Утро, просматриваешь входящие письма и изучаешь новости и внезапно обнаруживаешь, что инициатива, которую ты начал, подхватывается другими людьми. 🎉Недавно я взял интервью у Билла (Василиса) Коциаса - руководителя студии, читающего лекции в университете и популяризатора Joomla в Греции.Это интервью из журнала NorrNext, в оригинале на английском, теперь доступно на греческом языке и опубликовано на портале joomla.gr. 🎉До чего же приятно… 😇😊 Работа замечена и с ней посчитали необходимым ознакомить аудиторию страны, в которой Билл читает лекции. И это солнечная Греция - страна, страна, с которой Россию многое связывает. 🇬🇷🇷🇺🕊Смотрю на греческий алфавит и тут же рисуются картины белоснежных зданий в окружении винограда и амфор, красивых женщин в сандалиях и мужественных воинов, охраняющих покой полисов, в которых ученые мужи работают над трудами, позже вошедшими в века. Красиво! 😇Но вернемся к интервью. Из него вы узнаете, что в Греции доля Joomla среди CMS занимает порядка 30-40%. По моему мнению это - самый высокий показатель во всем мире. Также чтение лекций о Joomla в университетах позволит привести новых пользователей и к тому же молодое поколение. Ну и огромное кол-во сертификтатов Билла на стене (смотрим фото в статье) свидетельствует о том, что Joomla может применяться как профессиональный инструмент. 🇬🇷 Интервью на греческом портале (joomla.gr)🌐 Оригинальное интервью (на английском)Что насчет перевода на русский? Увы, времени всего 24 часа в сутках. Я продолжаю готовить новые интервью. Возможно, после завершения выпуска журнала, рассмотрю перевод некоторых интервью на русский. Но я об этом не говорил. 😊 В блоге @eugenius_blog публикую анонсы интересных событий из мира Joomla, интервью, уроки и полезные советы, а также делюсь мыслями:, связанными с разработкой и веб-дизайном.

Обработка HTTP ответа в Joomla 6+. Изменения по сравнению с Joomla 3 - Joomla 5

👩‍💻 Обработка HTTP ответа в Joomla 6+. Изменения по сравнению с Joomla 3 - Joomla 5.В Joomla для выполнения внешних запросов из PHP к сторонним API используется класс Joomla\Http\Http напрямую или же Joomla\Http\HttpFactory, который возвращает для работы преднастроенный по умолчанию класс Http. О работе с HTTP-запросами подробно рассказывалось в статье 2021 года Создание внешних запросов с использованием HttpFactory (Joomla). Некоторые изменения касаются работы с ответами на запросы. Например, наш запрос:
use Joomla\Http\HttpFactory;$http = (new HttpFactory)->getHttp($options, ['curl', 'stream']);$response = $http->get('https://any-url.ru/api/any/endpoint');
Раньше можно было получить код ответа или тело ответа как свойство $response - $response->code или $response->body. Однако, Joomla, начиная с Joomla 4 во многом переходит на стандарты PSR. В частности для работы с HTTP-ответами - на PSR-7. Также хорошая статья на Хабре о PSR-7: PSR-7 в примерах.
Прямое обращение к свойствам code, headers, body объявлено устаревшим в Joomla 6.0.0 и обещают удалить в Joomla 7.0.0.
Вместо этого нужно работать с HTTP-ответом по стандартам PSR-7. Код ответа.Было $response->code. Стало $response->getStatusCode().Заголовки ответа.Было $response->headers. Стало $response->getHeaders().Тело ответа.Было $response->body. Стало (string)$response->getContents().В тело ответа теперь приходит не строка, а поток - объект класса Laminas\Diactoros\Stream. Поэтому его нужно привести к строке (если это json, к примеру): (string)$response->getContents(). Чаще всего в коде Joomla встречается именно такой вариант. Однако, есть и вариант с перемещением указателя чтения на начало потока:
// Получили ответ в виде потока$stream = $response->getBody();// "перемотали" на начало$stream->rewind();// Получили строковый ответ$json = $stream->getContents();
В итоге результат одинаковый.@joomlafeed#joomla #разработка #php

Quantum Manager нужен сообществу, а автору нужна ваша поддержка!

Quantum Manager нужен сообществу, а автору нужна ваша поддержка!Файловый менеджер Quantum — одно...

Файловый менеджер Quantum — одно из самых популярных решений для Joomla, созданное разработчиком из сообщества Joomla, Дмитрием Цымбалом (@tsymbalmitia). Он делает Quantum удобным, безопасным и современным, обновляет его, исправляет уязвимости и отвечает пользователям — всё это в свободное от основной работы время.

Теперь настал момент для следующего шага: развитие проекта требует больше времени и ресурсов.

0 Пользователей и 1 Гость просматривают эту тему.
  • 12 Ответов
  • 1212 Просмотров
*

IceBlade

  • Новичок
  • 8
  • 0 / 0
Доброго времени.

Решил прогнать сайт через OWASP, в итоге увидел достаточно уязвимостей. Поэтому нужен совет, как от них закрыться.

1. XSS
1.1 Тут показывается везде, в основном - это материалы Joomla. Пример: http://xxx/en/novosti-2?amp%3Bformat=feed&amp%3Btype=atom&amp%3Btype=javascript%3Aalert%281%29%3B
javascript%3Aalert%281%29%3B - это и есть уязвимость. Если вместо нее написать "><script>alert("cookie: "+document.cookie)</script> - то вылетает 403 ошибка. Вопрос: при таком раскладе стоит обращать на нее внимание? Так как если вбивать строку изначальную, то алерт не всплывает.

1.2 А вот эта уязвимость отрабатывает, если в поле поиска (компонент joomshopping) вставить " onMouseOver="alert(1);. Это уже рабочая уязвимость. Как ее закрыть, где что фильтровать? Так как походу фильтров в строке поиска товара нет, от слова "совсем".

2. Buffer Overflow
Показывает в "блоге категорий", где размещается материал. Отключен стандартный редактор, поэтому текст в новостях (материалах) пишется с использованием тегов (картинки, текст и т.д.)
УРЛ: http://ххх/en/novosti-2?format=feed&type=atom
Параметр : GET http://ххх/en/novosti-2?format=feed&type=TIp(очень много букв)
При использовании длинного адреса вылезает 500 ошибка. Критично или нет ? Если да, как исправить? Ибо решение, как Я понял, "Rewrite the background program using proper return length checking.", а это уже движок.

3. Format String Error
Показывает в "блоге категорий", где размещается материал.
УРЛ : http://ххх/en/novosti-2?format=feed&type=ZAP%25n%25s%25n%25s%25(и так далее в таком же виде). Выбивает 500 ошибку. Критично или нет ? Если да, как исправить? Ибо решение, опять же,  "Rewrite the background program using proper deletion of bad character strings." - движок.

Больше всего интересуют уязвимости XSS. Заранее благодарен.

P.S. Версия PHP - 5.6. Версия joomla - 3.8.2. Все компоненты последней версии.
Тест проходил на локальном сервере (OSPanel).
« Последнее редактирование: 25.11.2017, 02:31:46 от IceBlade »
*

voland

  • Легенда
  • 11026
  • 588 / 112
  • Эта строка съедает место на вашем мониторе
*

IceBlade

  • Новичок
  • 8
  • 0 / 0
Re: OWASP ZAP показал наличие уязвимостей
« Ответ #2 : 25.11.2017, 02:20:27 »
Версия PHP - 5.6. Версия Joomla - 3.8.2. Компоненты соответствует последней версии.
*

ProtectYourSite

  • Живу я здесь
  • 2368
  • 139 / 4
  • Безопасность вебсайтов
Re: OWASP ZAP показал наличие уязвимостей
« Ответ #3 : 25.11.2017, 03:00:02 »
Фильтровать кавычки
*

IceBlade

  • Новичок
  • 8
  • 0 / 0
Re: OWASP ZAP показал наличие уязвимостей
« Ответ #4 : 25.11.2017, 03:18:10 »
ProtectYourSite, это понятно, что фильтровать... А где фильтр находится, который за это отвечает? Он есть в самом движке или его допиливать надо? Или можно реализовать через, допустим .htaccess (так как блокиратор <script> там настроен)? Как этот фильтр подключить к form.php поиска джумшоппинга, чтобы "onmoseover" не срабатывал, если там и намека нет, что он подключает какой-то фильтр?
Спасибо за совет, но больше интересует как реализовать и куда рыть.
*

draff

  • Гуру
  • 5801
  • 434 / 7
  • ищу работу
Re: OWASP ZAP показал наличие уязвимостей
« Ответ #5 : 25.11.2017, 09:17:28 »
Отдавать 404 на запрос с ?format=feed
Так яваскрипт в браузере выполняется, не влияет на безопасность .
*

ProtectYourSite

  • Живу я здесь
  • 2368
  • 139 / 4
  • Безопасность вебсайтов
Re: OWASP ZAP показал наличие уязвимостей
« Ответ #6 : 25.11.2017, 10:16:33 »
ProtectYourSite, это понятно, что фильтровать... А где фильтр находится, который за это отвечает? Он есть в самом движке или его допиливать надо? Или можно реализовать через, допустим .htaccess (так как блокиратор <script> там настроен)? Как этот фильтр подключить к form.php поиска джумшоппинга, чтобы "onmoseover" не срабатывал, если там и намека нет, что он подключает какой-то фильтр?
Спасибо за совет, но больше интересует как реализовать и куда рыть.
Надо смотреть воспроизводится ли проблема в самом компоненте магазина, и если да, то надо проинформировать разработчиков, чтобы исправили.
Пока не могу проверить, только после выходных.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: OWASP ZAP показал наличие уязвимостей
« Ответ #7 : 25.11.2017, 11:00:28 »
не смог повторить с поиском JoomShopping http://prntscr.com/hf03fg . какие именно действия нужно сделать?

P.S. по сути вот этот скрин более важен http://prntscr.com/hf058v
« Последнее редактирование: 25.11.2017, 11:06:07 от dmitry_stas »
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: OWASP ZAP показал наличие уязвимостей
« Ответ #8 : 25.11.2017, 11:44:45 »
Нашел модуль, в котором есть это. Нужно в его шаблоне заменить
Цитировать
<input type = "text" class = "inputbox" style = "width: 110px" name = "search" id = "jshop_search" value = "<?php print $search ?>" />
на
Цитировать
<input type = "text" class = "inputbox" style = "width: 110px" name = "search" id = "jshop_search" value = "<?php print htmlspecialchars($search)?>" />
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

IceBlade

  • Новичок
  • 8
  • 0 / 0
Re: OWASP ZAP показал наличие уязвимостей
« Ответ #9 : 25.11.2017, 13:48:55 »
dmitry_stas, большая человеческая благодарность! Вот так он отрабатывал : https://prnt.sc/hf1995 При чем вроде IE и хромой еще как-то его блокировали, а вот новый Лис исполняет на ура...
В строке поиска вводил просто - " onMouseOver="alert(1);. Теперь не отрабатывает. Надо будет написать разрабам магазина.

Drafа, в принципе, так и думал сделать. Пойду ковырять хтаксесс. Надеюсь, смогу додуматься =)

Благодарю всех за помощь!
« Последнее редактирование: 25.11.2017, 13:53:15 от IceBlade »
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: OWASP ZAP показал наличие уязвимостей
« Ответ #10 : 25.11.2017, 14:04:19 »
Надо будет написать разрабам магазина.
уже
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

IceBlade

  • Новичок
  • 8
  • 0 / 0
Re: OWASP ZAP показал наличие уязвимостей
« Ответ #11 : 26.11.2017, 12:36:30 »
Попробовал выдавать 404 на ?format=
Цитировать
RewriteCond %{QUERY_STRING} format=(.*)
RewriteRule ^ - [R=404,L]
Работает. Хотя тестовые письма из админки после этого не отправляются, но все остальные письма: заказ, авторизация, восстановления доходят. Видимо сработало.
Благодарю за подсказку!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как проверить наличие у материала конкретной метки?

Автор joy smile

Ответов: 2
Просмотров: 779
Последний ответ 07.02.2017, 00:51:03
от joy smile
Проверить наличие компонента из модуля

Автор ksalab

Ответов: 2
Просмотров: 873
Последний ответ 07.08.2016, 20:26:44
от ksalab
[Решено] Проверка блока для контента на наличие содержимого в нем

Автор veterok

Ответов: 12
Просмотров: 1647
Последний ответ 14.02.2014, 18:20:49
от veterok