Новости Joomla

Joomla 6: Автоматические обновления ядра в Joomla

Joomla 6: Автоматические обновления ядра в Joomla

👩‍💻 Joomla 6: Автоматические обновления ядра в Joomla. В октябрьском номере официального журнала Joomla - Joomla Community Magazine вышла статья David Jardin, где рассказывается о внедрении функционала автоматического обновления ядра Joomla.❓Почему сейчас? Joomla же жила как-то 20 лет без автоматических обновлений?Это оказалась самая востребованная за последнее время от пользователей Joomla функция. Но, основная причина внедрения - проблемы безопасности. Всякий раз, когда в новой версии Joomla устраняется уязвимость, злоумышленники начинают анализировать код, чтобы выяснить, какая именно уязвимость была исправлена. И как только они это выясняют - начинается разработка автоматизированных скриптов для взлома как можно большего количества сайтов. Затем доступы к автоматически взломанным сайтам продаются в профильных чатах и ресурсах "пачками" по несколько сотен тысяч или миллионов сайтов. Ваш сайт могли взломать несколько лет назад, но воспользоваться уязвимостью могут не сразу, а тогда, когда у злоумышленников возникнет необходимость. И только после этого вы может быть узнаете об этом.Анализ патча, понимание проблемы и разработка скрипта требуют времени. И если владелец сайта не обновит его до истечения этого срока, сайт может быть взломан. А хакеры действуют быстро! Для критических, легко эксплуатируемых уязвимостей речь идёт о временном окне в 10–12 часов — и этого времени явно недостаточно, чтобы все успели обновить свои сайты.Здесь выходят на первый план автоматизированные обновления: проект Joomla теперь может активно устанавливать обновления (и, следовательно, исправления безопасности) на сайты, чтобы гарантировать, что сайты действительно обновляются вовремя.🕘 От первых идей до реализации прошло 5 лет. И здесь можно вспомнить, как в Joomla 5.1 внедрили TUF - The Update Framework, позволяющий устанавливать защищённое соединение между сайтом и сервером обновлений и исключает возможность supply chain attack (атаки на цепочку поставок).Об особенностях реализации и требованиях к сайту читаем подробнее в статье на JCM.@joomlafeed#joomla #secutiry #jcm

Первый выпуск журнала NorrNext в честь 20-й годовщины Joomla™

Первый выпуск журнала NorrNext в честь 20-й годовщины Joomla™

Первый выпуск журнала NorrNext в честь 20-й годовщины Joomla™. Интервью с волонтёрами 🎈Ну что, друзья, вот и настал этот долгожданный момент. Мы выпустили первое издание собственного журнала под эгидой NorrNext, который включает в себя интервью с видными деятелями сообщества из разных стран и континентов.Общий нарратив: показать, что нас объединяет (Joomla) и узнать больше о людях, которые вносят свой вклад в развитие платформы в своих сообществах. 20 лет — это много. Давайте же узнаем о коллегах 🎁 Первый цикл включает такие страны, как Австрия, Испания, Латвия, Россия, Румыния, Тайланд, Черногория, Чехия.⚙️ С кем интервью: ✔️ Владимир Елисеев 🇷🇺✔️ Дмитрий Рекун 🇱🇻✔️ Дмитрий Цымбал 🇷🇺✔️ Евгений Сивоконь 🇷🇺 ✔️ Сергей Толкачёв 🇷🇺✔️ Dénes Székely 🇷🇴✔️ Jan Pavelka 🇨🇿✔️ Miljan Vujosevic 🇲🇪✔️ Sergio Iglesias 🇪🇸✔️ Sigrid Gramlinger 🇦🇹✔️ Pisan Chueatchatchai 🇹🇭‼️ Новые интервью будут добавляться до конца декабря 2025. Заходите по ссылке время от времени💡👉 Читать далее

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

ExJTMaster

  • Осваиваюсь на форуме
  • 11
  • 3 / 0
AJAX пагинация товара
« : 13.02.2017, 19:03:45 »
Сделал AJAX пагинацию товара по кнопке "Показать еще товары"

В файл шаблона /list_products/list_products.php
в конце перед последним </div> добавить код кнопки
Код
<div class = "more-product"><button class = "show-more btn btn-default" onclick="showmore()">Показать еще</button></div>
и в конце файла добавить скрипт
Код
<script>
function showmore(){
var lasturl = jQuery(".pagination li").last().find("a").attr("href");
if (lasturl){
var ajax_products_url = jQuery(".pagination li").eq(-2).find("a").attr("href")+"&tmpl=component";
jQuery.ajax({
url: ajax_products_url,
dataType: "html",
type: "GET",
cache: false,
success: function (result) {
var newContent = jQuery('<div/>').append(result).find(".list_product");
var newPagination = jQuery('<div/>').append(result).find("ul.pagination");
jQuery('.more-product').replaceWith(newContent.children());
jQuery('ul.pagination').replaceWith(newPagination);
lasturl = jQuery(".pagination li").last().find("a").attr("href");
if (!lasturl){
jQuery('.more-product').html("");
}
}
});
} else {
jQuery('.more-product').html("");
}
}
</script>
*

dmitry_stas

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

ExJTMaster

  • Осваиваюсь на форуме
  • 11
  • 3 / 0
Re: AJAX пагинация товара
« Ответ #2 : 13.02.2017, 19:17:56 »
AJAX пагинацию сделать несложно. сложно сделать чтобы она правильно ботами поисковыми вопринималась. и чтобы кнопка Назад в браузере нормально работала. и т.п. а саму кнопочку Показать еще сделать несложно :) но в любом случае спасибо что поделились.
Должна правильно поисковиками обрабатываться, так как фактически блок пагинации остается, его можно скрыть стилями, для поисковика все по старой схеме работает.
Назад тоже верно работает, возвращает на предыдущую страницу
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: AJAX пагинация товара
« Ответ #3 : 14.02.2017, 01:27:40 »
tmpl=component не забыть от индексации закрыть
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

intcorp

  • Захожу иногда
  • 456
  • 12 / 0
Re: ajax пагинация товара
« Ответ #4 : 08.11.2018, 17:40:29 »
Хорошее решение, но, когда достигается конец позиций, кнопку , в идеале, нужно было бы скрыть, иначе начинает подгружать уже загруженные позиции.

П.с. если сейчас есть новые решения данного вопроса, поделитесь ссылочкой)
« Последнее редактирование: 08.11.2018, 18:37:55 от intcorp »
*

kadriel

  • Новичок
  • 3
  • 0 / 0
Re: ajax пагинация товара
« Ответ #5 : 29.04.2019, 01:20:51 »

П.с. если сейчас есть новые решения данного вопроса, поделитесь ссылочкой)

+1 ^-^
*

Gringo7

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: ajax пагинация товара
« Ответ #6 : 02.10.2019, 11:52:59 »
Немного другая реализация данного метода, с сокрытием кнопки, когда показывать нечего.

В самый конец list_products.php (после дива list_product) добавляем кнопку.
Код
<div id = "more-products" class = "hidden"><button onclick="showmore()">Показать еще</button></div>
И вставляем скрипт:
Код
<script>
    //После загрузки страницы проверяем, показывать ли кнопку Показать еще
    jQuery(function() {
        show_hide_btn();
    });

    function show_hide_btn() {
        //Проверяем, есть ли ссылка на след. страницу
        nexturl = jQuery(".pagination ul li.pagination-active").next().find("a").attr("href");
        // Если нашли, показываем кнопку
        if (nexturl) {
            jQuery("#more-products").removeClass("hidden");
        }
        // Если нет, скрываем
        else {
            jQuery("#more-products").addClass("hidden");
        }
    }

    function showmore(){
            nexturl = jQuery(".pagination ul li.pagination-active").next().find("a").attr("href");
        if (nexturl) {
            jQuery.ajax({
                url: nexturl,
                dataType: "html",
                type: "GET",
                cache: false,
                success: function(data){
                //    Вырезаем нужный нам код из ответа
                    var   add_html = jQuery(data).find(".list_product").html();
                    var   newPg = jQuery(data).find(".pagination").html();
                //    и вставляем его на страницу
                    jQuery(".list_product").append(add_html);
                    jQuery(".pagination ul").replaceWith(newPg);
                },
                error: function (error) {
                    console.log('Error sending AJAX request\nStatus code: ' + error.status + '\nStatus text: ' + error.statusText);
                },
                complete: function () {
                    //Проверяем, показывать ли кнопку Показать еще
                    show_hide_btn();
                }
                })
        }
    }
    </script>

Не использовал tmpl=component в url запроса, т.к. в этом случае сервер возвращает блок пагинации, где в ссылках тоже стоит этот параметр, что, естественно, не нужно. Возможно, это только мой случай, разбираться не стал, на скорость особо не влияет. И убрал обертывание ответа в div (('<div/>').append), браузер ругается на конструкцию. Думаю тоже особо не влияет.
*

goga_pgasovav

  • Захожу иногда
  • 445
  • 6 / 0
  • Внимательный джумловод
Re: ajax пагинация товара
« Ответ #7 : 12.10.2020, 15:36:25 »
Товарищи, взял за основу реализацию AJAX-пагинации от Gringo7.
Работает всё без нареканий. НО!
В пагинации, возвращаемой аяксом, какие-то модифицированные странными символами урлы получаются.
Например ссылка на первую страницу должна выглядеть так:
Код
http://mysite.com/mycategory?start=0
А AJAX возвращает следующее:
Код
http://mysite.com/mycategory?_=1602506113717&start=0
Отуда берётся это «_=1602506113717&» ?  :o
*

sivers

  • Живу я здесь
  • 2593
  • 360 / 0
Re: ajax пагинация товара
« Ответ #8 : 12.10.2020, 15:53:47 »
Отуда берётся это «_=1602506113717&» ? 
Вероятно, это работа параметра cache: false в запросе jQuery.ajax(); - он таким образом предотвращает кэширование гет-запроса браузером.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

goga_pgasovav

  • Захожу иногда
  • 445
  • 6 / 0
  • Внимательный джумловод
Re: ajax пагинация товара
« Ответ #9 : 12.10.2020, 16:01:34 »
sivers, огомное вам спасибо! Помогло. С AJAX раньше вообще дел не имел, и не знал, что такой параметр существует.
*

sivers

  • Живу я здесь
  • 2593
  • 360 / 0
Re: ajax пагинация товара
« Ответ #10 : 12.10.2020, 16:20:18 »
Помогло. С AJAX раньше вообще дел не имел, и не знал, что такой параметр существует.
Да пожалуйста. К слову, если отправлять запрос методом POST (параметр type: "GET" поменять на type: "POST"), то кэширования не будет в любом случае - пост-запросы не кэшируются.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

В списке товаров вывести названия категорий каждого товара

Автор shop-user

Ответов: 5
Просмотров: 3013
Последний ответ 25.01.2022, 06:05:12
от kit2m2
Плагин - Инфоблок товара в списке товаров [Скачать]

Автор kit2m2

Ответов: 13
Просмотров: 3193
Последний ответ 20.10.2021, 14:51:08
от kit2m2
Автоматическая генерация кода товара (плагин)

Автор maslybs

Ответов: 8
Просмотров: 3607
Последний ответ 30.08.2021, 20:21:25
от nevigen
Таблица размеров (и т.п.) Плагин модульных позиций для атрибутов на странице товара [Скачать]

Автор kit2m2

Ответов: 39
Просмотров: 8095
Последний ответ 16.05.2021, 18:16:50
от kit2m2
Усовершенствованый фильтр 3.4.0(ajax)

Автор seetvael

Ответов: 252
Просмотров: 44575
Последний ответ 06.08.2020, 14:57:19
от goga_pgasovav