Yii спочатку спроектований таким чином, щоб використання сторонніх бібліотек
з метою розширення функціоналу Yii, відбувалося легко і невимушено.
Дуже часто при використанні в роботі сторонніх бібліотек, розробники стикаються
з проблемами іменування класів і підключення файлів. Оскільки всі класи Yii мають префікс C
,
то ймовірність виникнення конфліктів імен істотно нижче.
А завдяки тому, що для підключення файлів Yii використовує
автозавантаження SPL,
робота з бібліотеками, що використовують для підключення файлів класів цей механізм
автозавантаження або ж відносний шлях підключення в РНР (PHP include path), стає істотно приємніше.
Нижче наведено приклад, що ілюструє використання в Yii-додатку компонента Zend_Search_Lucene із Zend framework.
Насамперед, розпаковуємо реліз з Zend framework в папку protected/vendors
,
де protected
— це базова директорія додатку.
Переконайтеся в тому, що файл protected/vendors/Zend/Search/Lucene.php
існує.
Далі, на самому початку класу контролера, додаємо рядок:
Yii::import('application.vendors.*');
require_once('Zend/Search/Lucene.php');
Код, наведений вище, підключає файл класу Lucene.php
.
Оскільки використовується відносний шлях, то необхідно змінити відносний шлях підключення
в РНР (PHP include path) таким чином, щоб додаток міг знайти файл. Р
обиться це шляхом виклику методу Yii::import
перед require_once
.
Після того, як зроблено все описане, можна використовувати клас Lucene
в діях контролера наступним чином:
$lucene=new Zend_Search_Lucene($pathOfIndex);
$hits=$lucene->find(strtolower($keyword));
Для того, щоб підключити бібліотеку, що використовує простір імен відповідно до угоди PSR-0 (наприклад, Zend Framework 2 або Symfony2), необхідно зареєструвати її корінь як псевдонім шляху.
У якості прикладу будемо використовувати Imagine.
Якщо ми скопіюємо директорію Imagine
в protected/vendors
, то використовувати бібліотеку можна буде наступним чином:
Yii::setPathOfAlias('Imagine',Yii::getPathOfAlias('application.vendors.Imagine'));
// Далі стандартний код із керівництва Imagine:
// $imagine = new Imagine\Gd\Imagine();
// і т.д.
У наведеному вище коді імʼя заданого нами псевдоніма має відповідати першій частині простору імен, яке використовується в бібліотеці.
Деякі сторонні бібліотеки (наприклад PHPUnit) використовують свої власні автозавантажувачі класів, які виконують підключення файлу класа за правилами, які відрізняються від тих, що використовуються автозавантажувачем у Yii. Оскільки Yii використовує шлях підключення PHP як "останнє джерело" файлів класів, реєстрація таких стороннії автозавантажувачів може призвести до Попередження PHP (Warning):
include(PHPUnit_Framework_TestCase.php) [function.include]: failed to open stream: No such file or directory
Для уникнення такої проблеми - переконайтеся, що будь-який сторонній автозавантажувач класів зареєстрований до автозавантажувача Yii:
require_once('PHPUnit/Autoload.php'); // реєструємо сторонній автозавантажувач
require_once('/path/to/framework/yii.php'); // реєструємо автозавантажувач Yii
...
Якщо сторонній автозавантажувач классів йде як окрема функція або метод,
ви можете використовувати Yii::registerAutoloader()
для його реєстрації.
У цьому випадку Yii зареєструє його перед власним автозавантажувачем автоматично.
require_once('/path/to/framework/yii.php'); // реєструємо автозавантажувач Yii
...
Yii::registerAutoloader(array('SomeLibrary','autoload')); // реєструємо сторонній автозавантажувач
...
Ви також можете уникнути проблем із сторонніми автозавантажувачами,
відключаючи використання шляху підключення PHP перед виконанням додатка за допомогою параметра
YiiBase::$enableIncludePath
рівним false
:
require_once('/path/to/framework/yii.php');
$configFile='/path/to/config/main.php';
Yii::$enableIncludePath = false; // відключаємо використання шляху підключення PHP
Yii::createWebApplication($configFile)->run();
Yii може бути використаний як бібліотека для розробки і поліпшення сторонніх систем, таких як WordPress, Joomla та інших. Для того, щоб скористатися Yii необхідно включити наведений нижче код у сторонню систему:
require_once('шлях/до/yii.php');
Yii::createWebApplication('шлях/до/config.php');
Даний код дуже схожий на той, який використовується в index.php
звичайного додатку.
Відмінність у тому, що після створення екземпляра додатку не викликається метод run()
.
Тепер при розробці сторонньої системи можна використовувати більшість можливостей Yii.
Наприклад, для отримання доступу до екземпляра додатку можна використовувати Yii::app()
.
Також можна використовувати DAO, ActiveRecord моделі, валідацію і т.д.