
If you're asking, "what's Yii?" check out my earlier tutorial: Introduction to the Yii Framework, which reviews the benefits of Yii and includes an overview of what's new in Yii 2.0, released October 12th, 2014.
This tutorial will walk you through installing Yii 2.0, setting up your local development environment, building a simple Hello World application, setting up your remote production environment for hosting and deploying your code from a GitHub repository.Installing Yii 2.0
Documentation
You can find detailed installation instructions here; I'll walk you through the basics for a typical Mac OS X development environment. Yii 2.0 has a Definitive Guide (PDF) and a Class Reference which cover every detail of Yii. caInstalling Composer
Yii2 requires Composer, a popular dependency manager for PHP. If you don't already have Composer installed, do the following:| 1 2 | curl -s http://getcomposer.org/installer| phpmvcomposer.phar /usr/local/bin/composer | 
Installing Yii2
Then, use Composer to install Yii2. The installation request requires that you use your own Github account credentials; sign up if you don't have an account.Let's call this first project, "hello":
| 1 2 3 | cd~/Sitescomposer global require "fxp/composer-asset-plugin:1.0.0-beta2"composer create-project --prefer-dist yiisoft/yii2-app-basichello | 
Setting Up Your Local Development Environment
I'm using free, open source MAMP for OS X for my LAMP development. Make sure MAMP is running and its web and database servers are active. Then, create a symlink for MAMP to yourSites app directory:| 1 2 | cd/Applications/MAMP/htdocsln-s ~/Sites/hello//Applications/MAMP/htdocs/hello | 

That page will likely excite Yii 1.1 developers who've not had pre-configured support for the latest version of Bootstrap, the outstanding open source responsive CSS framework that's taken over quite a bit of the web.
Yii Application Architecture
One of the most important features of the Yii Framework is that it provides a Model View Controller for PHP. Not only does this provide a more structured programming environment and easier to understand code, it simplifies a number of things that are difficult to do in PHP, like security and automated code generation. It also makes our code easier to extend and more reusable.With a Yii application, we direct all traffic to a single file:
/web/index.php file. This built-in file loads Yii, any dependencies, and then runs your application.| 01 02 03 04 05 06 07 08 09 10 11 12 | <?php// comment out the following two lines when deployed to productiondefined('YII_DEBUG') ordefine('YII_DEBUG', true);defined('YII_ENV') ordefine('YII_ENV', 'dev');require(__DIR__ . '/../vendor/autoload.php');require(__DIR__ . '/../vendor/yiisoft/yii2/Yii.php');$config= require(__DIR__ . '/../config/web.php');(newyii\web\Application($config))->run(); | 
/controllers/SiteController.php:| 1 2 3 4 | publicfunctionactionIndex()    {        return$this->render('index');    } | 
By default, Yii will render
/views/layouts/main.php around your index view in /views/site/index.php. The main.php layout provides the HTML and CSS structure to the page, e.g. the toolbar and content area. Inside main.php, you'll see a brief call out to the content:| 1 2 3 4 5 6 | <div class="container">            <?= Breadcrumbs::widget([                'links'=> isset($this->params['breadcrumbs']) ? $this->params['breadcrumbs'] : [],            ]) ?>            <?= $content?>        </div> | 
$content variable will be replaced with the generated code from /views/site/index.php, which currently is static HTML code that generates the Congratulations! page shown above.Building Hello World!
Turning on Pretty URLs
First, let's enable Yii2's pretty URLs withmod_rewrite. On the Yii home page, if you click on the About menu option, the URL will be something like http://localhost:8888/hello/web/index.php?r=site%2Fabout. We'd like to change that to http://localhost:8888/hello/web/site/about.The
config subdirectory includes environment configurations for your web and  console applications as well as the future database settings. Edit /config/web.php to add urlManagement to the current web application. Add the following urlManager section within the components array:| 1 2 3 4 5 6 7 8 | 'components'=> [//...  'urlManager'=> [          'showScriptName'=> false,          'enablePrettyUrl'=> true                  ],    //...'request'=> [ | 
.htaccess file within /web where the primary index.php file exists:| 1 2 3 4 5 6 7 | RewriteEngine on# If a directory ora file exists, useit directlyRewriteCond %{REQUEST_FILENAME} !-fRewriteCond %{REQUEST_FILENAME} !-d# Otherwise forward it to index.phpRewriteRule . index.php | 
mod_rewrite is running locally on MAMP; if not, check out this Stack Overflow guide.In your browser, visit this URL: http://localhost:8888/hello/web/site/about. You should see the Yii application About page and clicking on other menu options should bring up pretty URLs.
Building the Say Hello World! Action
Next, we'll add a controller action calledSay to repeat a target message of our choosing. In /controllers/SiteController.php, add the following action:| 1 2 3 4 | public function actionSay($target = 'World'){    return $this->render('say', ['target' => $target]);} | 
SiteController class, we use public function actionSay. Yii uses the prefix "action" to differentiate action methods from other methods.The default behavior of the render method will look for a file in
views/ControllerID/ViewName.php. So, in /views/site/, create a say.php view file:| 1 2 3 4 5 | <?phpuseyii\helpers\Html;?><h1>Hello <?= Html::encode($target) ?></h1><p>Welcome to your Yii2 demonstration application.</p> | 
h1 with Hello followed by the target variable. Note: We encode the target variable to secure the URL parameter argument from malicious code.If you visit the url, http://localhost:8888/hello/web/site/say?target=Tuts%20Readers, you should see this:

Now, let's set up our application with GitHub and deploy it to a production server.
Setting Up Your Remote Hosting Environment
The basic Yii application should run fine out of the box with Apache or an Nginx, I'll provide instructions for Apache and you can find instructions for Nginx here.Create a Repository at GitHub
Once I set up a Yii application template, I create a repository at Github:
I've been using the Mac OS X GitHub app more frequently but you can also use the command line to initialize the repository. Below, I'm following the instructions for adding an existing project to GitHub using the command line (replace "youraccount" with your GitHub account name):
| 1 2 3 4 5 | cd ~/Sites/hellogit initgit commit -m "first commit of hello world for yii2"git remote add origin git@github.com:youraccount/hello.gitgit push -u origin master | 
Configure an Apache Site on Your Server
If you don't already have a LAMP server or cloud instance, follow my generic Ubuntu installation instructions to get started. Once you have your IP address, modify your DNS records to have an A record point to your server.| 1 | yourdomain.com A 192.161.234.17 | 
| 1 | sshroot@yourserver.com | 
mod_rewrite for Apache and mcrypt for PHP:| 1 2 3 4 | sudoapt-get updatesudoapt-get upgradesudoa2enmod rewritephp5enmod mcrypt | 
Configure GitHub Access on the Remote Server
Now, we'll set up a user for pulling code from Github that can be served by Apache. First, install git on your server.| 1 | sudoapt-get installgit | 
| 1 2 3 4 5 6 7 | adduser githubaddgroup www adduser github wwwadduser www-data wwwchown-R :www /var/wwwchmod+s -R /var/wwwchmod-vR g+w /var/www/ | 
| 1 2 3 4 | sugithubssh-keygen -t rsa -C "yourgithubaccount@youremail.com"exitcat/home/github/.ssh/id_rsa.pub | 



| 1 | git clone git@github.com:youraccount/hello.git /var/www/hello | 

Create the Apache Site Configuration
Create an Apache site configuration file:| 1 | nano /etc/apache2/sites-available/hello.conf | 
| 01 02 03 04 05 06 07 08 09 10 11 12 13 14 | <VirtualHost *:80> ServerName yourdomain.com# Set document root to be "basic/web"DocumentRoot "/var/www/hello/web"<Directory "/var/www/hello/web">    # use mod_rewrite for pretty URL support    RewriteEngine on    # If a directory or a file exists, use the request directly    RewriteCond %{REQUEST_FILENAME} !-f    RewriteCond %{REQUEST_FILENAME} !-d    # Otherwise forward the request to index.php    RewriteRule . index.php</Directory></VirtualHost> | 
| 1 2 3 | a2ensite hello.confa2dissite 000-default.conf service apache2 reload | 

If you have any questions or corrections on this tutorial, please post them in the comments.
 
 
 
 
No comments:
Post a Comment