Новости Joomla

Перевод и публикация интервью с 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

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

alpha_ru

  • Захожу иногда
  • 86
  • 0 / 0
Url из базы
« : 08.09.2017, 12:03:35 »
В таблице com_content есть поле URLS. В нем данные представлены в виде:
Цитировать
{"urla":false,"urlatext":"","targeta":"","urlb":false,"urlbtext":"","targetb":"","urlc":false,"urlctext":"","targetc":""}
Как получить url статьи в нормальном виде?
*

NewUsers

  • Живу я здесь
  • 2310
  • 216 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
Re: Url из базы
« Ответ #1 : 08.09.2017, 12:09:33 »
Код: php
<?php $urls = new JRegistry($item->urls); ?>

Занимаюсь создание расширений для Joomla 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
*

alpha_ru

  • Захожу иногда
  • 86
  • 0 / 0
Re: Url из базы
« Ответ #3 : 08.09.2017, 12:33:10 »
а если из базы тянуть, то раскодировать через json_decode()
как это сделать?
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
Re: Url из базы
« Ответ #4 : 08.09.2017, 12:42:21 »
именно? запрос к базе?
кстати, неплохо бы вам задачу свою описать нормально, а то, чую, у вас приступ хреносозидательства может начаться :)
*

alpha_ru

  • Захожу иногда
  • 86
  • 0 / 0
Re: Url из базы
« Ответ #5 : 08.09.2017, 12:56:39 »
В виде модуля я уже получил заголовок статьи ссылкой:
Код
<a href="<?php echo $row->urls; ?>" ><span><?php echo $row->title; ?></span></a>
Выводится заголовок "Лицензии" с сылкой вида:
Цитировать
{"urla":false,"urlatext":"","targeta":"","urlb":false,"urlbtext":"","targetb":"","urlc":false,"urlctext":"","targetc":""}
Простой вариант json_decode($row->urls) не работает. Как сделать декодированние правильно?
*

alpha_ru

  • Захожу иногда
  • 86
  • 0 / 0
Re: Url из базы
« Ответ #7 : 08.09.2017, 13:21:55 »
object(stdClass)#311 (9) { ["urla"]=> bool(false) ["urlatext"]=> string(0) "" ["targeta"]=> string(0) "" ["urlb"]=> bool(false) ["urlbtext"]=> string(0) "" ["targetb"]=> string(0) "" ["urlc"]=> bool(false) ["urlctext"]=> string(0) "" ["targetc"]=> string(0) "" }
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
Re: Url из базы
« Ответ #8 : 08.09.2017, 15:00:00 »
ну так пустые строки, вы их в админке не заполнили.
может вы не правильно задачу формулируете?
эти ссылки - доп. поля материала, если их не заполнять, то их и не будет.

может вам надо ссылку на сам материал сформировать?
*

fsv

  • Живу я здесь
  • 2782
  • 411 / 2
Re: Url из базы
« Ответ #9 : 08.09.2017, 16:38:23 »
Почему бы не посмотреть, как в других модулях (com_content) формируется ссылка на статью?

в хелпере
Код
JLoader::register('ContentHelperRoute', JPATH_SITE . '/components/com_content/helpers/route.php');
...
foreach ($items as &$item)
{
    ...
$item->slug = $item->id . ':' . $item->alias;
$item->link = JRoute::_(ContentHelperRoute::getArticleRoute($item->slug, $item->catid, $item->language));
    ...
}
...
return $items;
...

в шаблоне
Код
<?php echo '<a href="' . $item->link . '">' . $item->title . '</a>'; ?>
Веб-разработка: заказ. Только новая разработка.
*

capricorn

  • Завсегдатай
  • 1949
  • 118 / 3
Re: Url из базы
« Ответ #10 : 08.09.2017, 19:02:16 »
Что значит "в нормальном виде"? Это поле не для той цели, которую вы преследуете.
Используйте API. Как в посте выше вам сказали.

Код: php
JRoute::_(ContentHelperRoute::getArticleRoute($id, $catid, $language));

2 последних параметра необязательны, если их нет, а есть только id.

Что конкретно вам нужно - сделать экспорт URL-ов для переноса в другую систему?
*

alpha_ru

  • Захожу иногда
  • 86
  • 0 / 0
Re: Url из базы
« Ответ #11 : 10.09.2017, 10:16:24 »
может вам надо ссылку на сам материал сформировать?
Да, нужна ссылка.

Похоже я ошибся. Поле urls не предназначено для формирования ссылок.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Базы данных

Автор rezchik

Ответов: 7
Просмотров: 925
Последний ответ 16.02.2023, 22:59:29
от rezchik
Ошибка базы данных с номером 1146

Автор a159cm

Ответов: 2
Просмотров: 1991
Последний ответ 27.06.2021, 14:37:44
от fsv
Какой компонент или плагин лучше для создания базы организации или фирм?

Автор Ruslandir

Ответов: 10
Просмотров: 883
Последний ответ 11.01.2021, 17:41:50
от AlexB
Могу войти в phpMyAdmin, но нужно посмотреть пароль от базы данных

Автор vova630

Ответов: 5
Просмотров: 976
Последний ответ 10.01.2021, 18:02:00
от AlexB
Как из базы вытянуть последний заказ?

Автор R31rus

Ответов: 4
Просмотров: 757
Последний ответ 23.12.2020, 00:16:24
от v42bis