Yii2 gii как запустить
Перейти к содержимому

Yii2 gii как запустить

  • автор:

Генератор программного кода Gii в Yii

В прошлой статье «Взаимодействие с базой данных в Yii» был разобран пример вывода списка из базы данных. Для этого в базе была создана таблица «animals» с полями «name» и «food». Таблица была заполнена примерами данных (названиями животных и их любимой едой).

Для организации вывода данных таблицы выл написан код контроллера controllers/AnimalsController.php с действием «actionList», представление views/animals/list.php и модель models/Animals.php .

Все было запрограммировано в ручном режиме. Но в Yii есть модуль Gii, который позволяет генерировать подобный код автоматически, что облегчает жизнь разработчикам. В этой статье попробуем сделать все действия из предыдущей, только с использованием Gii.

Активация Gii

Сначала необходимо убедиться, что модуль Gii активен. Для этого он должен быть перечислен в файле конфигурации config/web.php так:

$config = [ . ]; if (YII_ENV_DEV) < // если приложение в режиме разработки $config['bootstrap'][] = 'gii'; $config['modules']['gii'] = [ 'class' =>'yii\gii\Module', 'allowedIPs' => ['ваш_ip_адрес'], ]; >

Вставьте вместо «ваш_ip_адрес» свой внешний ip (его можно узнать через поисковик). Это нужно, потому что Gii позволяет получить прямой доступ к базе. Поэтому если посторонний получит доступ к системе управления Gii, то сможет навредить проекту.

Если открыть файл /index.php в корневой веб папке, то там будет строка, указывающая на то, что приложение находится в разработке:

defined('YII_ENV') or define('YII_ENV', 'dev');

Страница управления модулем Gii в фреймворке Yii

Если это строка присутствует, то остаётся только перейти на страницу управления модулем Gii. Находится эта страница по адресу /index.php?r=gii .

Создание модели Gii

Страница создение модли модулем Gii в фреймворке Yii

На странице управления Gii кликните на кнопку «Start» в разделе создания модели. Затем введите название и кликните «Preview» внизу формы: Система проверит существует ли данная модель, и нет ли других проблем. В нашем случае модель «Animals» уже создана, поэтому необходимо поставить флаг перезаписи в списке под кнопкой «Preview». А затем нажать на нопку «Generate», чтобы перезаписать модель.

Создание представления и контроллера

CRUD Generator модуля Gii в фреймворке Yii

Теперь можно перейти на второй пункт «CRUD Generator». Эта аббревиатура расшифровывается как «Create», «Read», «Update» и «Delete». С помощью этой формы можно сгенерировать контроллер и представления, в функции которых будут входить элементы управления, чтобы можно было читать, изменять, удалять и добавлять новые элементы в таблицу из публичного раздела сайта. В этой форме необходимо заполнить первые три поля такими данными для нашего примера:

  • Model Class: app\models\Animals
  • Search Model Class: app\models\AnimalsSearch
  • Controller Class: app\controllers\AnimalsController

Затем необходимо нажать на кнопу «Preview», отметить все действия в появившемся списке под кнопкой для выполнения и кликнуть «Generate».

Создание представления и контроллера

Страница, созданная с помощью модуля Gii в фреймворке Yii

Остаётся только протестировать результат на странице /index.php?r=animals/index : Как можно заметить, тут есть и функции редактирования, поиска и сортировки элементов таблицы. Если вас не устраивает визуальное представление или другие функции, то их код всегда можно отредактировать вручную, через файлы.

Как включить gii в yii2 advanced

post-image

Сразу хочу предупредить: генерация кода будет доступна только из админки (т.к. досутп к ней из фронтенда не совсем безопасное занятие).

Идем в backend\config\ и открываем main-local.php , там ищем такой код:

 if (!YII_ENV_TEST) < // configuration adjustments for 'dev' environment $config['bootstrap'][] = 'debug'; $config['modules']['debug'] = [ 'class' =>'yii\debug\Module', ]; $config['bootstrap'][] = 'gii'; $config['modules']['gii'] = [ 'class' => 'yii\gii\Module', ]; > 

Если кода нет, копируем и вставляем перед return $config; . Если он есть, но закоментирован — раскоментируй.

Разберемся что тут написано. Сначала мы спрашиваем у константы YII_ENV_TEST true она или не true. Чтобы понимать откуда растут ноги, откройте файлик backend\web\index.php . Найдите строку

 defined('YII_ENV') or define('YII_ENV', 'dev'); 

Значение константы YII_ENV может принимать другие значения:

  • prod: окружение production. YII_ENV_PROD установлена в true.
  • dev: окружение development. YII_ENV_DEV установлена в true.
  • test: окружение testing. YII_ENV_TEST установлена в true.

Соответственно, если настройка конфигурации инициализирована для среды dev, тогда мы попадем в наше условие if() .

Всё, Gii включили =) можно проверять. Открываем http://что-то-там/admin/index.php?r=gii (или http://что-то-там/admin/gii если увас настроены ЧПУ).

Дальше мы можем столкнуться с ошибкой Forbidden (#403). Исправляем

Исправляем ошибку Forbidden (#403) при включении Gii в Yii2 advanced

Если столкнулся с ошибкой 403, значит все модули подключены и генератор кода «виден». Но у нас пока нет к нему доступа. Чтобы исправить эту ошибку открываем файл backend\config\main-local.php и в массив $config[‘modules’][‘gii’] дописываем элемент ‘allowedIPs’ => [‘*’], . После этих манипуляций код будет выглядить следующим образом:

 $config['bootstrap'][] = 'gii'; $config['modules']['gii'] = [ 'class' => 'yii\gii\Module', 'allowedIPs' => ['*'], ]; 

Элемент массива allowedIPs указывает на диапазон IP адресов, которым можно работать с Gii. Значение ‘*’ указывает на то, что все IP’шники могут работать с Gii. Это не совсем безопасно (хотя мы отсеяли кучу народа, у которго нет досутпа в админку). Значением allowedIPs лучше указывать свой IP (твой IP можешь тут).

Исправляем ошибку Not Found (#404) при включении Gii в Yii2 advanced

Ошибка 404 может возникнуть по двум причинам:

1. Если в файле backend\web\index.php константе YII_ENV присваивается значение test .

В этом случае меняем значение на dev или prod (первый предпочтительнее если вы разрабатываете сайт).

2. Если в файле backend\config\main-local.php нет (или он закоментирован) кода

 if (!YII_ENV_TEST) < // configuration adjustments for 'dev' environment $config['bootstrap'][] = 'debug'; $config['modules']['debug'] = [ 'class' =>'yii\debug\Module', ]; $config['bootstrap'][] = 'gii'; $config['modules']['gii'] = [ 'class' => 'yii\gii\Module', 'allowedIPs' => ['*'], ]; > 

В этом случае просто добавляем (раскомментируем) код.

Помогло? Поделись с друзьями

а в замен я покажу анекдот 😉

Генерация кода при помощи Gii ¶

В этом разделе мы опишем, как использовать Gii для автоматической генерации кода, реализующего некоторые общие функции вебсайта. Для достижения этой цели всё, что вам нужно, это просто ввести необходимую информацию в соответствии с инструкциями, отображаемыми на веб-страницах Gii.

В этом руководстве вы узнаете:

  • Как активировать Gii в приложении;
  • Как использовать Gii для создания Active Record класса;
  • Как использовать Gii для генерации кода, реализующего CRUD для таблицы БД.
  • Как настроить код, генерируемый Gii.

Запускаем Gii ¶

Gii представлен в Yii как модуль. Вы можете активировать Gii, настроив его в свойстве modules. В зависимости от того, каким образом вы создали приложение, вы можете удостовериться в наличии следующего кода в конфигурационном файле config/web.php ,

$config = [ . ]; if (YII_ENV_DEV) < $config['bootstrap'][] = 'gii'; $config['modules']['gii'] = [ 'class' => 'yii\gii\Module', ]; > 

Приведенная выше конфигурация показывает, что находясь в режиме разработки, приложение должно включать в себя модуль с именем gii , который реализует класс yii\gii\Module .

Если вы посмотрите входной скрипт web/index.php вашего приложения, вы увидите следующую строку, устанавливающую константу YII_ENV_DEV в значение true .

defined('YII_ENV') or define('YII_ENV', 'dev'); 

Благодаря этой строке ваше приложение находится в режиме разработки, и Gii уже активирован в соответствии с описанной выше конфигурацией. Теперь вы можете получить доступ к Gii по следующему адресу:

https://hostname/index.php?r=gii 

Примечание: Если вы пытаетесь получить доступ к Gii не с локального хоста, по умолчанию, в целях обеспечения безопасности, доступ будет запрещён. Вы можете изменить настройки Gii, чтобы добавить разрешённые IP адреса, как указано ниже

'gii' => [ 'class' => 'yii\gii\Module', 'allowedIPs' => ['127.0.0.1', '::1', '192.168.0.*', '192.168.178.20'] // регулируйте в соответствии со своими нуждами ], 

Gii

Генерация класса Active Record ¶

Чтобы использовать Gii для генерации класса Active Record, выберите «Генератор модели» (нажав на ссылку на главной странице Gii). И заполните форму следующим образом:

  • Имя таблицы: country
  • Класс модели : Country

Генератор модели

Затем нажмите на кнопку «Предварительный просмотр». Вы увидите, что models/Country.php перечислен в результатах создаваемых файлов классов. Вы можете нажать на имя файла класса для просмотра его содержимого.

Если вы уже создали такой же файл и хотите перезаписать его, нажмите кнопку diff рядом с именем файла, чтобы увидеть различия между генерируемым кодом и существующей версией.

Предварительный просмотр генератора модели

Для перезаписи существующего файла установите флажок рядом с «overwrite» и нажмите кнопку «Generate». Для создания нового файла вы можете просто нажать «Generate».

После этого вы увидите страницу подтверждения, указывающую на то, что код был успешно сгенерирован. Если файл существовал до этого, вы также увидите сообщение о том, что он был перезаписан заново сгенерированным кодом.

Создание CRUD кода ¶

CRUD расшифровывается как Create, Read, Update и Delete, предоставляющий четыре основные функции, выполняемые над данными на большинстве веб-сайтов. Чтобы создать функциональность CRUD используя Gii, выберите «CRUD Генератор» (нажав на ссылку на главной странице Gii). Для нашей таблицы «country» заполните полученную форму следующим образом:

  • Model Class: app\models\Country
  • Search Model Class: app\models\CountrySearch
  • Controller Class: app\controllers\CountryController

CRUD генератор

Затем нажмите на кнопку «Preview». Вы увидите список файлов, которые будут созданы, как показано ниже.

CRUD генератор: предпросмотр

Если вы уже создали файлы controllers/CountryController.php и views/country/index.php (в разделе о базах данных), установите флажок «overwrite», чтобы заменить их. (Предыдущие версии не поддерживают CRUD полностью)

Испытываем в действии ¶

Чтобы увидеть как всё это работает, перейдите по следующему URL, используя ваш браузер:

https://hostname/index.php?r=country%2Findex 

Вы увидите таблицу, показывающую страны из таблицы БД. Вы можете сортировать, а также фильтровать данные, указывая условия фильтрации в заголовках столбцов.

Для каждой отображающейся в таблице страны вы можете просмотреть подробную информацию, обновить или удалить её. Вы также можете нажать на кнопку «Создать страну» в верхней части таблицы для получения формы создания новой страны.

Таблица данных стран

Обновление страны

Ниже приведен список файлов, созданных с помощью Gii, в том случае, если вы захотите исследовать реализацию этих функций, или изменить их:

  • Контроллер: controllers/CountryController.php
  • Модели: models/Country.php и models/CountrySearch.php
  • Вид: views/country/*.php

Информация: Gii разработан как тонконастраиваемый и расширяемый инструмент генерации кода. Используя его с умом, вы можете значительно ускорить скорость разработки приложений. Для более подробной информации, пожалуйста, обратитесь к разделу Gii.

Заключение ¶

В этом разделе вы узнали, как использовать Gii для генерации кода, реализующего полную функциональность CRUD для данных, хранящихся в таблице базы данных.

Как подключить Gii в Yii2 advanced

Я установить его через Composer, прописал настройки в frontend/config/main.php, но по адресу /index.php?r=gii ничего не показывается, то есть показывается стандартная страница. Что я сделал не так? frontend/config/main.php

'bootstrap' => ['gii'], 'modules' => [ 'gii' => 'yii\gii\Module', // . ], 

Отслеживать
задан 7 сен 2016 в 12:56
2,563 1 1 золотой знак 20 20 серебряных знаков 47 47 бронзовых знаков

прописал настройки в frontend/config/main.php . какие? добавьте конфиг в вопрос . и есть ли с common конфиг main-local ?

7 сен 2016 в 13:33
Добавил конфиг в вопрос. в папке common есть конфиг main-local
7 сен 2016 в 13:41

Это какой-то маааааленький конфиг. вы его весь выложите. А в common/main-local есть строки ‘urlManager’ => [ ‘enablePrettyUrl’ => true, ], ? . а во frontend и backend есть main-local? там же уже gii должен быть прописан

7 сен 2016 в 13:43

в common/main-local такого нету, такое есть в frontend/config/main . и да, в frontend/config/main-local gii уже прописан

7 сен 2016 в 13:50

В этом наверное и проблема. это позволяет писать красивые урлы. Т.е. можно писать mysite.ru/gii . правда при наличии опции ‘request’=>[ ‘baseUrl’=>», ], . А если поставить ‘enablePrettyUrl’ => false, то можно писать index.php?r=gii и раз в main-local подключен gii, то в main писать ‘modules’ => [ ‘gii’ => ‘yii\gii\Module’, // . ], вроде и не обязательно

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *