Download the PHP package voskobovich/yii2-seo-toolkit without Composer

On this page you can find all versions of the php package voskobovich/yii2-seo-toolkit. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package yii2-seo-toolkit

Yii2 SEO Toolkit

Помогает реализовать управление урлами страниц системы как в CMS WordPress, с управлением из админпанели таблицей маршрутизации и редиректами.

License Latest Stable Version Latest Unstable Version Total Downloads

Support

GutHub issues.

Usage

  1. Создать таблицу для хранения роутинга (применить миграцию)
  2. Создать свой экземпляр модели UrlRoute
  3. Настроить UrlManager
    1. Подключить класс UrlManager из пакета
    2. Подключить классы правил роутинга
    3. ClearUrlRule для очистки урлов от мусора (двойные слэши, слэш в окончании ...)
    4. UrlRule отвечает непосредственно за роутинг
  4. В нужной AR модели
    1. Реализовать интерфейс SeoModelInterface
    2. Подключить поведение CreateUrlBehavior
  5. Подключить ActualityUrlBehavior
  6. Создаем CRUD для управления роутами

  7. Создаем таблицу (применяем миграцию)

Унаследуйте созданный класс миграции от \voskobovich\seo\migrations\create_table__url_route.
Например:

Применяем миграцию

  1. Создаем свой экземпляр модели UrlRoute

    Yii2 SEO toolkit не знает с какими моделями и роутами ему придется работать.
    Чтобы это исправить, нужно унаследоваться от модели UrlRoute из пакета и реализовать 2 метода из UrlRouteInterface.
    Вот пример из моего проекта.

Из примера видно, что роутинг будет работать с 4-я объектами.
Для каждого объекта сконфигурирован список стандартных действий "показать все" (index) и "показать один" (view).
Действия нужны для того, чтобы различать логику обработки роута. Например, мы можем сделать вот так:

  1. Роут /foo это действие index для объекта post. В итоге, перейдя по /foo мы получим список всех постов (в yii роутинге это равняется переходу на post/index).
  2. Роут /bar это действие view для объекта post c id=3. В итоге, перейдя по /bar мы увидим запись с id=5 (в yii роутинге это равняется переходу на post/view).
    Список действий можно расширить, дополнив список в методе getActionItems.

  3. Настраиваем UrlManager

    В стандартном классе UrlManager реализовано кеширование роутов которое помогает ускорить процесс генерации ссылок в стандартном роутинге Yii2. Суть кеширования в том, чтобы запоминать для каких роутов нет правил в конфиге и больше не пытаться построить ссылку для этого роута. То есть, если для роута post/view нет правила, то больше для этого роута правил искаться не будет, что и логично. Но для нас это беда, и вот почему. Для роута post/view id=4 может быть правило в таблице маршрутизации, а для post/view id=5 может не быть. Если не отключить кеширование, то при генерации ссылок на посты если первой будет сгенерирована ссылка для post/view id=5 то UrlManager запомнит, что правила для этого роута нет и больше не будет его обрабатывать. В итоге мы не получим наших красивых ссылок для остальных постов. Итак, подключаем класс UrlManager из пакета.

Правило ClearUrlRule умеет:

  1. Заменить множество слэшей на один
  2. Удалить слэш в конце ссылки
  3. Буквы верхнего регистра перевести в нижний

Внимание! В целях оптимизации рекомендую настроить эти правила на уровне вашего веб-сервера.

Правило UrlRule отвечает за наш волшебный роутинг.
В атрибут modelClass передается модель UrlRoute которая была создана на прошлом шаге.

  1. Настраиваем AR модель

    Чтобы для новых моделей ссылки автоматом попадили в таблицу роутинга, нужно подключить CreateUrlBehavior и реализовать интерфейс SeoModelInterface.
    Привожу пример модели Post из моего проекта.

Метод getSeoPath() должен возвращать путь, по которому будет доступна запись поста.
У меня этот роут состоит из пути к главной категории поста и короткого имени самого поста (/cat/subcat/post-slug).

Поведению нужно передать нашу модель UrlRoute и сообщить каким объектом является наша AR модель используя ранее созданные константы в модели UrlRoute.

  1. Подключаем ActualityUrlBehavior

    После настройки всего пользователь все еще может перейти по старой ссылке и увидеть страницу. Например, мы для /post/view?id=6 создали красивый урл /best-post. Но пользователь все еще может перейти по старой ссылке и получить страницу, хотя в идеале его нужно отправить на новый урл с 301-м редиректом.
    Вот пример обработчика запроса из моего проекта.

Говорю сразу, подключать поведение на весь контролер не нужно. Это поведение нужно только для view экшена.
Этому поведению так же нужно передать класс нашей созданной модели UrlRoute и название объекта из константы.

  1. Создаем CRUD для управления роутами

    Во вьюхах есть небольшая логика, так что привожу примеры основных кусков кода из своего проекта.

Файл create.php

Файл update.php

Файл index.php

Installation

The preferred way to install this extension is through composer.

Either run

or add

to the require section of your composer.json file.


All versions of yii2-seo-toolkit with dependencies

PHP Build Version
Package Version
Requires php Version >=5.4.0
yiisoft/yii2 Version ~2.0.0
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package voskobovich/yii2-seo-toolkit contains the following files

Loading the files please wait ....