A modern, Bootstrap 5-powered Yii2 application template designed for rapid web-application development. Built with best practices, clean architecture, and developer-friendly configuration, it lets you create production-ready apps with minimal setup while maintaining code quality and extensibility.

- ✅ Asset Management - Optimized asset bundles for CSS, JS, and resource management.
- ✅ Clean Architecture - Well-organized directory structure following Yii2 best practices.
- ✅ Console Commands - Example console commands for background tasks and maintenance.
- ✅ Developer Tools - Debugging tools, logging, and development-friendly configurations.
- ✅ Modern Bootstrap 5 UI - Responsive, mobile-first design with latest Bootstrap components.
- ✅ Testing Ready - Codeception test suite with examples for functional and unit testing.
Classic web-server + PHP-FPM setup; simple and widely supported for deployment.
Long-running PHP workers for higher throughput and lower latency.
For setup instructions, see
README.md
in each branch.
The Yii2 Web Application Basic template provides a complete foundation for building modern web applications. Unlike starting from scratch, this template includes.
- Pre-configured structure with organized directories for assets, views, models, and controllers.
- Bootstrap 5 integration for responsive, mobile-first user interfaces.
- Security features including CSRF protection and input validation.
- Development tools for debugging, logging, and testing.
Why use this template
- Rapid development: Start building features immediately without setup overhead.
- Best practices: Follow Yii2 conventions and modern web development standards.
- Extensible: Easy to customize and extend for specific project requirements.
- Production-ready: Includes security features and optimizations for deployment.
Note: Also, make sure to install
npm
for frontend dependency management.
composer create-project --prefer-dist yii2-extensions/app-basic:^0.1 app-basic
cd app-basic
Start development server
# Using built-in PHP server
php -S localhost:8080 -t web
# Or using Yii console command
./yii serve
Your application will be available at
http://localhost:8080
or at the address set in--address
option.
root/
├── config/ Configuration files
│ ├── common/ Common configuration
│ ├── console/ Console configuration
│ ├── web/ Web configuration
│ └── messages.php Translation config
├── src/
│ ├── framework/ Framework assets & resources
│ │ ├── asset/ Asset bundles
│ │ └── resource/ CSS, JS, layouts, messages
│ └── usecase/ Application use cases
│ ├── hello/ Console command example
│ └── site/ Site pages
├── tests/ Test suites
├── vendor/ Composer dependencies
└── web/ Web server document root
<?php
// src/usecase/site/SiteController.php
declare(strict_types=1);
namespace app\usecase\site;
use yii\web\Controller;
final class SiteController extends Controller
{
public function actionIndex(): string
{
return $this->render('index');
}
}
# Run the hello command
./yii hello/index
# Generate translations
./yii message config/messages.php
# Clear cache
./yii cache/flush-all
For detailed configuration options and advanced usage: