SlideShare a Scribd company logo
PHP & Zend Framework Tutorial
I did a lot of googling, installing, re-installing, … but finally got my first php project to
work. I used WAMP for the apache install, the Zend Framework as an MVC, and
PostGreSQL as a backend database. Below you can find a basic tutorial on how to get
started. Included are following steps:

   1.   Install & configure WAMP
   2.   Configure PHP
   3.   Install & configure PostGres
   4.   Set up the Zend Framework
   5.   Start programming

I’m gonna try to keep everything as simple as possible. Downside is that you’ll have to
try & configure some things on your own. On the other hand it’ll keep this tutorial from
becoming too big (and you probably didn’t even got to reading this sentence)… Oh yeah,
I’m doing this on my Windows XP system, I don’t know how differently all of this
should be done on other systems.

1. Install & configure WAMP.
Why WAMP? Well it’s the Windows version of the popular LAMP distribution and the
installer configures a lot of things for you. I started with installing & configuring
everything (Apache, MySQL/PostGres & PHP) separately which worked (after some
time), but I want to spare you the frustrations I had to endure.

I’m not gonna tell you how to download it and click next during the installer. The most
important thing is the ‘httpd.conf’-file which configures the server. Following parameters
are quite important (but should be set correctly after installing WAMP):
    - the parameter “documentRoot” points to your ‘www’-folder, where you can drop
        your PHP-files that can be viewed by browser when the server’s URL is given
    - the parameter “loadModule” points to the PHP configuration that should be used
        (PHP runtime environment normally is a separate install – Apache can’t handle
        PHP on his own)

Important! I installed WAMP in my “program files” folder, so I recommend you do this
too, otherwise you will have to adjust the php.ini file, which is discussed later.

So, normally no configuration is need, and after installing you should see an “It works!”
when you browse to your http://localhost. If you are having problems, make sure all
service are running.

2. Configure PHP
The WAMP install will do a lot for you, but you will still have to set your system
variables:

   -   Path: add your php folder (e.g: …existingPathValues…;C:Program
       Fileswampphp)
   - PHPRC (=PHP Runtime Conf): e.g. “C:Program Fileswampphp”
You can google if you don’t know how to set system variables, but remember to restart
your PC after having done this.

A very important file is php.ini! It configures your PHP runtime environment. I’ll list the
most important parameters (to me):
(remember to remove the “;” in front of a parameter to uncomment it)
    - display_errors: set it to “On”
    - display_startup_errors: set it to “On”
    - log_errors: set it to “On”
       (this is good for a dev environment but remember it affects performance)
    - extension=… (to add dll’s – we’ll need some to connect to PostGres, so I’ll come
       back to it later)
    - extension_dir: to tell PHP where it can find dll’s that are added through the
       ‘extension’ parameters
    - include_path: used to include external (php-)classes that can be used in your
       project (we’ll include the Zend framework classes, so I’ll come back to this later)

Also something nice is PDO, when learning PHP you’ll stumble on to this – give it some
extra attention!

3. Install & configure PostGres
Why PostGres? Well, because we’re going to need it for a client. We’ll have an expert
setting it up, but it always to know a little bit about what (or who) you are ‘doing’.
Normally I would have gone for MySQL (which is part of and configured by WAMP).

I suggest you follow the installer. Then open PgAdminIII (part of the installer) and
double-click on your server. Enter your password (the one you entered during install) ,
right-click on ‘databases’ and select “New database…”. For this tutorial enter
“firstphpdb” for the name and click “OK”.

Then goto ‘Tools’ in the menu and select ‘Query tool’. Enter the following query:

   CREATE TABLE users (
      id serial PRIMARY KEY,
      firstname varchar(50) UNIQUE NOT NULL,
      lastname varchar(50) UNIQUE NOT NULL,
      dateCreated timestamp DEFAULT current_timestamp
   );
Then click the ‘Run’ button. This will create the “Users” table for you (under Schema’s
  Public Tables). I guess you can find out on your how to enter some names in there.

This cheat sheet is quite useful.

4. Set up the Zend Framework
OK, why Zend? Well it’s quite popular and IBM also likes it. Since I’m a big fan of
Lotus Notes I’ll follow IBM on this. I’ll leave the discussion on which framework to use
to the real PHP freaks.

First, we need to make sure we can use the Zend classes. We do this in our php.ini
through the ‘include_path’ parameter:

   ; Windows: "path1;path2"
   include_path = ".;C:Program FilesZendZendFramework-1.0.1library"

Of course this setting depend on where you extracted your Zend Framework. Don’t
forget to download it.

Secondly, you’ll need to understand how it works and should be used. I’ll just explain the
MVC setup, but Zend can do much more (I haven’t tried the other features, I’ll
probably some more when I do). I’ll try to explain the MVC on a step-by-step basis:

   1. Remove everything from you document root (the www-folder of your WAMP
      installation). First we’re going to create an .htaccess file in this folder. This file…
      Tip: You can’t create a file that starts with a dot in Explorer, use the “Save as…”
      function in Notepad.
   2. Now, we’ll create an index.php file and drop it in our root folder (the www-folder
      of your WAMP installation). This file will launch when users browse to your
      server. You can find the file here. Everything is explained in the file itself:

   <?php
   try {
         // full error reporting (you can actually omit this because we also set this in php.ini)
         error_reporting(E_ALL);

        //includes: (remember the include_path in your php.ini? it’s used here)
        include_once('Zend/Loader.php');

        //load the classes
        //the following translates into 'include(Zend/Controller/Front.php)'
        Zend_Loader::loadClass('Zend_Controller_Front');
        Zend_Loader::loadClass('Zend_Db');
        Zend_Loader::loadClass('Zend_Db_Table');

        //configure the database
        $options = array(
                 'host' => 'localhost' ,
'username' => 'postgres' ,
              'password' => 'lotusnotes' ,
              'dbname' => 'firstphpdb'
     );
     $db = Zend_Db::factory( 'PDO_PGSQL' , $options );
     //Using Zend_Db_Table is not mandatory,
     //But it will help write models because it assists in 'fast-writing' sql-queries
     //If we omit Zend_Db_Table we should use the PDO model
     Zend_Db_Table::setDefaultAdapter( $db );

     //configure the front controller (everything start here!)
     $controller = Zend_Controller_Front::getInstance();
     $controller->setControllerDirectory( './FirstPHPProject/controllers');

     //disable automatic view rendering (important, but look at Zend docs for the explanation)
     $controller->setParam('noViewRenderer' , true);

     //run the controller
     $controller->dispatch();
} catch (Exception $e) {
              echo $e->getMessage() . ' in ' . $e->getFile() . ' on line ' . $e->getLine() . "n";
}

3. Now, because of the Zend_Controller in the index.php file, we need to create a
   directory structure for our project that the Zend_Controller can use. It is very
   important that you create it exactly like the Zend framework wants it:
                                           The Zend_Controller will translate the
                                           url’s that are used. E.g. if you enter
                                           “localhost/index/index, Zend_Controller
                                           will look for the ‘indexAction’ in the
                                           ‘IndexController’ class in the controllers
                                           directory. If you enter
                                           “localhost/users/view”, it will look for the
                                           ‘viewAction’ in the ‘UsersController’.

                                                  Now, you can ignore the “.cache” and
                                                  “.settings” folder. Because I’m using
                                                  Eclipse PDT as an editor, Eclipse created
                                                  these folders.
                                                  You can’t see the files, but .htaccess and
                                                  index.php are at the same level as the folder
                                                  “FirstPHPProject” and “public”.

     Now it’s up to you to create the same folder structure.

4. I hope you already know the basics of an MVC framework, because I’m not going
   to explain it. I’m just going to list the files you should create in each folder and
   explain some thing in the files themselves in the next chapter…
7. Start programming
Is started of using the Zend Editor, which is very nice, but Sven Dens recommended
using the Eclipse PDT plugin which has recently got it’s first 1-release. Since I’ve
already used Eclipse and this is becoming our company ‘standard’ I went with it. So for
no problems…

You can find my entire www-folder in the post, so I suggest you download it. This is how
it should look like (left is in Eclipse, right in Zend Editor):




Most explanations are found in the files themselves. I’ll discuss the basics here.
The Controllers

As mentioned before, the Zend_Controller handles the requests and translates them into
‘actions’ from ‘controller’ classes in the “Controllers” folder.

Let’s take the ‘contactAction’ ‘IndexController’ as an example which we can call through
http://localhost/index/contact.

The ‘init()’ function as called every time an instance of the IndexController is created. In
here, we initialize the view (which we will render at the end of the the ‘contactAction’).
We don’t need to specify which view to use: Zend will look for a file called
contact.phtml (=action name + .phtml) the in the “index” directory (=controller name) in
the “scripts” folder. So make sure it exists. Note that everything is case sensitive!

Note: if you omit something, Zend will default to ‘index’. E.g. if you enter
http://localhost is will translate to http://localhost/index/index. If you enter
http://localhost/users is will translate to http://localhost/users/index.

The Views

As mentioned in the Controllers, Zend will look for a file with the same name as the
action that’s called (in the folder with the same name as the Controller that’s called (in
the “Script” folder)). So if you call http://localhost/users/view zend will execute the
‘viewAction’ in the ‘UsersController’ and when the ‘viewAction’ renders the view, zend
will open the view.phtml file.


The Model

A model represents the database model. In our example we created the model
“users.php”. This class inherits from the ‘Zend_Db_Table’ class. It has one constant
‘$_name’ which represent the name of the table in the database. The initial connection to
the database was made in index.php.

Now, we can use this model in our controllers. I suggest you look at the ‘addAction’ in
the ‘UsersController’ to get started.

More Related Content

What's hot (17)

KEY
LvivPy - Flask in details
Max Klymyshyn
 
PDF
Introduction to Apache Ant
Shih-Hsiang Lin
 
PPTX
Apache ant
koniik
 
PDF
20130528 solution linux_frousseau_nopain_webdev
Frank Rousseau
 
PDF
Automated Testing with Ruby
Keith Pitty
 
ODP
CodeIgniter PHP MVC Framework
Bo-Yi Wu
 
PDF
Java Server Faces
Mario Jorge Pereira
 
KEY
Puppet for Java developers - JavaZone NO 2012
Carlos Sanchez
 
PPT
Ant
Manav Prasad
 
PDF
Finally, Professional Frontend Dev with ReactJS, WebPack & Symfony (Symfony C...
Ryan Weaver
 
PDF
BPMS1
tutorialsruby
 
ODP
Custom module and theme development in Drupal7
marif4pk
 
PDF
Intro to drupal_7_architecture
Hai Vo Hoang
 
PDF
Connect2017 DEV-1550 Why Java 8? Or, What's a Lambda?
Julian Robichaux
 
PPT
Servlet/JSP course chapter 1: Introduction to servlets
JavaEE Trainers
 
PDF
JEE Programming - 04 Java Servlets
Danairat Thanabodithammachari
 
LvivPy - Flask in details
Max Klymyshyn
 
Introduction to Apache Ant
Shih-Hsiang Lin
 
Apache ant
koniik
 
20130528 solution linux_frousseau_nopain_webdev
Frank Rousseau
 
Automated Testing with Ruby
Keith Pitty
 
CodeIgniter PHP MVC Framework
Bo-Yi Wu
 
Java Server Faces
Mario Jorge Pereira
 
Puppet for Java developers - JavaZone NO 2012
Carlos Sanchez
 
Finally, Professional Frontend Dev with ReactJS, WebPack & Symfony (Symfony C...
Ryan Weaver
 
Custom module and theme development in Drupal7
marif4pk
 
Intro to drupal_7_architecture
Hai Vo Hoang
 
Connect2017 DEV-1550 Why Java 8? Or, What's a Lambda?
Julian Robichaux
 
Servlet/JSP course chapter 1: Introduction to servlets
JavaEE Trainers
 
JEE Programming - 04 Java Servlets
Danairat Thanabodithammachari
 

Viewers also liked (18)

PPS
1 George
Mireia Buchaca
 
PDF
7 deadly sins in marketing
Tuan Anh Nguyen
 
PPTX
Owi presentation to rotaract
Stephen Chiunjira
 
PPTX
Elaboracion de un blog
Ana Belén Córdoba
 
PDF
ChinasLargestCorpReport2009
Owen B. Brewer
 
PPTX
Help Growing Trees Grow Stronger After a Storm
Rebekah Black
 
PDF
Promo Shops Promotional And Marketing Services
MCrosby
 
PPTX
Open Access Advocacy
Sridhar Gutam
 
PPTX
How to get a domain name using FatCow.com
ulee007
 
PPTX
Naturaleza y-evbolucion-de-la-tecnologia
santiago cisneros
 
PPT
Social Media voor het MKB
Gewoon Groen
 
PPS
New Zeeland 22 0 Lecointe
Mireia Buchaca
 
PPTX
A Sustainable Waste Oil Solution
Sanskrit44
 
DOC
I F E E L D O Y O U D R
banothkishan
 
PDF
INLS890_ProjectPlan
tutorialsruby
 
PDF
El incienso de_la_alabanza
ANTONIO COTRINA OSORIO
 
PPT
1 8 Landscape Business Taxes & Licenses
Fauquier Horticulture
 
1 George
Mireia Buchaca
 
7 deadly sins in marketing
Tuan Anh Nguyen
 
Owi presentation to rotaract
Stephen Chiunjira
 
Elaboracion de un blog
Ana Belén Córdoba
 
ChinasLargestCorpReport2009
Owen B. Brewer
 
Help Growing Trees Grow Stronger After a Storm
Rebekah Black
 
Promo Shops Promotional And Marketing Services
MCrosby
 
Open Access Advocacy
Sridhar Gutam
 
How to get a domain name using FatCow.com
ulee007
 
Naturaleza y-evbolucion-de-la-tecnologia
santiago cisneros
 
Social Media voor het MKB
Gewoon Groen
 
New Zeeland 22 0 Lecointe
Mireia Buchaca
 
A Sustainable Waste Oil Solution
Sanskrit44
 
I F E E L D O Y O U D R
banothkishan
 
INLS890_ProjectPlan
tutorialsruby
 
El incienso de_la_alabanza
ANTONIO COTRINA OSORIO
 
1 8 Landscape Business Taxes & Licenses
Fauquier Horticulture
 
Ad

Similar to php-and-zend-framework-getting-started (20)

PPT
Getting Started with Zend Framework
Juan Antonio
 
PDF
Zend Framework 1.8 workshop
Nick Belhomme
 
PDF
Introduction To CodeIgniter
Muhammad Hafiz Hasan
 
PPT
Introduction To Code Igniter
Amzad Hossain
 
ODP
Codegnitorppt
sreedath c g
 
ODP
Zend Framework 1.9 Setup & Using Zend_Tool
Gordon Forsythe
 
PDF
Intro To Mvc Development In Php
funkatron
 
PPTX
Zend framework
Prem Shankar
 
PDF
Getting started-with-zend-framework
Marcelo da Rocha
 
PPT
Phpwebdevelping
mohamed ashraf
 
PPT
Phpwebdev
Luv'k Verma
 
PPTX
My Very First Zf App Part One
isaaczfoster
 
PDF
Getting started-with-zend-framework
Nilesh Bangar
 
PDF
Building Web Applications with Zend Framework
Phil Brown
 
PPTX
PHP on IBM i Tutorial
ZendCon
 
PPTX
Software development
BALUJAINSTITUTE
 
PDF
Zend Framework Handout
lucianb
 
PDF
Zend Framework Handout
lucianb
 
PDF
Zend Lab
Leo Nguyen
 
Getting Started with Zend Framework
Juan Antonio
 
Zend Framework 1.8 workshop
Nick Belhomme
 
Introduction To CodeIgniter
Muhammad Hafiz Hasan
 
Introduction To Code Igniter
Amzad Hossain
 
Codegnitorppt
sreedath c g
 
Zend Framework 1.9 Setup & Using Zend_Tool
Gordon Forsythe
 
Intro To Mvc Development In Php
funkatron
 
Zend framework
Prem Shankar
 
Getting started-with-zend-framework
Marcelo da Rocha
 
Phpwebdevelping
mohamed ashraf
 
Phpwebdev
Luv'k Verma
 
My Very First Zf App Part One
isaaczfoster
 
Getting started-with-zend-framework
Nilesh Bangar
 
Building Web Applications with Zend Framework
Phil Brown
 
PHP on IBM i Tutorial
ZendCon
 
Software development
BALUJAINSTITUTE
 
Zend Framework Handout
lucianb
 
Zend Framework Handout
lucianb
 
Zend Lab
Leo Nguyen
 
Ad

More from tutorialsruby (20)

PDF
&lt;img src="../i/r_14.png" />
tutorialsruby
 
PDF
TopStyle Help &amp; &lt;b>Tutorial&lt;/b>
tutorialsruby
 
PDF
The Art Institute of Atlanta IMD 210 Fundamentals of Scripting &lt;b>...&lt;/b>
tutorialsruby
 
PDF
&lt;img src="../i/r_14.png" />
tutorialsruby
 
PDF
&lt;img src="../i/r_14.png" />
tutorialsruby
 
PDF
Standardization and Knowledge Transfer – INS0
tutorialsruby
 
PDF
xhtml_basics
tutorialsruby
 
PDF
xhtml_basics
tutorialsruby
 
PDF
xhtml-documentation
tutorialsruby
 
PDF
xhtml-documentation
tutorialsruby
 
PDF
0047ecaa6ea3e9ac0a13a2fe96f4de3bfd515c88f5d90c1fae79b956363d7f02c7fa060269
tutorialsruby
 
PDF
0047ecaa6ea3e9ac0a13a2fe96f4de3bfd515c88f5d90c1fae79b956363d7f02c7fa060269
tutorialsruby
 
PDF
HowTo_CSS
tutorialsruby
 
PDF
HowTo_CSS
tutorialsruby
 
PDF
BloggingWithStyle_2008
tutorialsruby
 
PDF
BloggingWithStyle_2008
tutorialsruby
 
PDF
cascadingstylesheets
tutorialsruby
 
PDF
cascadingstylesheets
tutorialsruby
 
&lt;img src="../i/r_14.png" />
tutorialsruby
 
TopStyle Help &amp; &lt;b>Tutorial&lt;/b>
tutorialsruby
 
The Art Institute of Atlanta IMD 210 Fundamentals of Scripting &lt;b>...&lt;/b>
tutorialsruby
 
&lt;img src="../i/r_14.png" />
tutorialsruby
 
&lt;img src="../i/r_14.png" />
tutorialsruby
 
Standardization and Knowledge Transfer – INS0
tutorialsruby
 
xhtml_basics
tutorialsruby
 
xhtml_basics
tutorialsruby
 
xhtml-documentation
tutorialsruby
 
xhtml-documentation
tutorialsruby
 
0047ecaa6ea3e9ac0a13a2fe96f4de3bfd515c88f5d90c1fae79b956363d7f02c7fa060269
tutorialsruby
 
0047ecaa6ea3e9ac0a13a2fe96f4de3bfd515c88f5d90c1fae79b956363d7f02c7fa060269
tutorialsruby
 
HowTo_CSS
tutorialsruby
 
HowTo_CSS
tutorialsruby
 
BloggingWithStyle_2008
tutorialsruby
 
BloggingWithStyle_2008
tutorialsruby
 
cascadingstylesheets
tutorialsruby
 
cascadingstylesheets
tutorialsruby
 

Recently uploaded (20)

PDF
Transcript: Book industry state of the nation 2025 - Tech Forum 2025
BookNet Canada
 
PDF
What’s my job again? Slides from Mark Simos talk at 2025 Tampa BSides
Mark Simos
 
PDF
AI Agents in the Cloud: The Rise of Agentic Cloud Architecture
Lilly Gracia
 
PDF
“Squinting Vision Pipelines: Detecting and Correcting Errors in Vision Models...
Edge AI and Vision Alliance
 
PPTX
COMPARISON OF RASTER ANALYSIS TOOLS OF QGIS AND ARCGIS
Sharanya Sarkar
 
PPTX
Designing_the_Future_AI_Driven_Product_Experiences_Across_Devices.pptx
presentifyai
 
PDF
“Computer Vision at Sea: Automated Fish Tracking for Sustainable Fishing,” a ...
Edge AI and Vision Alliance
 
PPTX
New ThousandEyes Product Innovations: Cisco Live June 2025
ThousandEyes
 
PDF
Automating Feature Enrichment and Station Creation in Natural Gas Utility Net...
Safe Software
 
PDF
How do you fast track Agentic automation use cases discovery?
DianaGray10
 
PPTX
Future Tech Innovations 2025 – A TechLists Insight
TechLists
 
PDF
CIFDAQ Market Wrap for the week of 4th July 2025
CIFDAQ
 
PDF
Newgen Beyond Frankenstein_Build vs Buy_Digital_version.pdf
darshakparmar
 
PDF
“NPU IP Hardware Shaped Through Software and Use-case Analysis,” a Presentati...
Edge AI and Vision Alliance
 
PPTX
From Sci-Fi to Reality: Exploring AI Evolution
Svetlana Meissner
 
DOCX
Cryptography Quiz: test your knowledge of this important security concept.
Rajni Bhardwaj Grover
 
PPT
Ericsson LTE presentation SEMINAR 2010.ppt
npat3
 
PDF
LOOPS in C Programming Language - Technology
RishabhDwivedi43
 
PDF
POV_ Why Enterprises Need to Find Value in ZERO.pdf
darshakparmar
 
PDF
Agentic AI lifecycle for Enterprise Hyper-Automation
Debmalya Biswas
 
Transcript: Book industry state of the nation 2025 - Tech Forum 2025
BookNet Canada
 
What’s my job again? Slides from Mark Simos talk at 2025 Tampa BSides
Mark Simos
 
AI Agents in the Cloud: The Rise of Agentic Cloud Architecture
Lilly Gracia
 
“Squinting Vision Pipelines: Detecting and Correcting Errors in Vision Models...
Edge AI and Vision Alliance
 
COMPARISON OF RASTER ANALYSIS TOOLS OF QGIS AND ARCGIS
Sharanya Sarkar
 
Designing_the_Future_AI_Driven_Product_Experiences_Across_Devices.pptx
presentifyai
 
“Computer Vision at Sea: Automated Fish Tracking for Sustainable Fishing,” a ...
Edge AI and Vision Alliance
 
New ThousandEyes Product Innovations: Cisco Live June 2025
ThousandEyes
 
Automating Feature Enrichment and Station Creation in Natural Gas Utility Net...
Safe Software
 
How do you fast track Agentic automation use cases discovery?
DianaGray10
 
Future Tech Innovations 2025 – A TechLists Insight
TechLists
 
CIFDAQ Market Wrap for the week of 4th July 2025
CIFDAQ
 
Newgen Beyond Frankenstein_Build vs Buy_Digital_version.pdf
darshakparmar
 
“NPU IP Hardware Shaped Through Software and Use-case Analysis,” a Presentati...
Edge AI and Vision Alliance
 
From Sci-Fi to Reality: Exploring AI Evolution
Svetlana Meissner
 
Cryptography Quiz: test your knowledge of this important security concept.
Rajni Bhardwaj Grover
 
Ericsson LTE presentation SEMINAR 2010.ppt
npat3
 
LOOPS in C Programming Language - Technology
RishabhDwivedi43
 
POV_ Why Enterprises Need to Find Value in ZERO.pdf
darshakparmar
 
Agentic AI lifecycle for Enterprise Hyper-Automation
Debmalya Biswas
 

php-and-zend-framework-getting-started

  • 1. PHP & Zend Framework Tutorial I did a lot of googling, installing, re-installing, … but finally got my first php project to work. I used WAMP for the apache install, the Zend Framework as an MVC, and PostGreSQL as a backend database. Below you can find a basic tutorial on how to get started. Included are following steps: 1. Install & configure WAMP 2. Configure PHP 3. Install & configure PostGres 4. Set up the Zend Framework 5. Start programming I’m gonna try to keep everything as simple as possible. Downside is that you’ll have to try & configure some things on your own. On the other hand it’ll keep this tutorial from becoming too big (and you probably didn’t even got to reading this sentence)… Oh yeah, I’m doing this on my Windows XP system, I don’t know how differently all of this should be done on other systems. 1. Install & configure WAMP. Why WAMP? Well it’s the Windows version of the popular LAMP distribution and the installer configures a lot of things for you. I started with installing & configuring everything (Apache, MySQL/PostGres & PHP) separately which worked (after some time), but I want to spare you the frustrations I had to endure. I’m not gonna tell you how to download it and click next during the installer. The most important thing is the ‘httpd.conf’-file which configures the server. Following parameters are quite important (but should be set correctly after installing WAMP): - the parameter “documentRoot” points to your ‘www’-folder, where you can drop your PHP-files that can be viewed by browser when the server’s URL is given - the parameter “loadModule” points to the PHP configuration that should be used (PHP runtime environment normally is a separate install – Apache can’t handle PHP on his own) Important! I installed WAMP in my “program files” folder, so I recommend you do this too, otherwise you will have to adjust the php.ini file, which is discussed later. So, normally no configuration is need, and after installing you should see an “It works!” when you browse to your http://localhost. If you are having problems, make sure all service are running. 2. Configure PHP
  • 2. The WAMP install will do a lot for you, but you will still have to set your system variables: - Path: add your php folder (e.g: …existingPathValues…;C:Program Fileswampphp) - PHPRC (=PHP Runtime Conf): e.g. “C:Program Fileswampphp” You can google if you don’t know how to set system variables, but remember to restart your PC after having done this. A very important file is php.ini! It configures your PHP runtime environment. I’ll list the most important parameters (to me): (remember to remove the “;” in front of a parameter to uncomment it) - display_errors: set it to “On” - display_startup_errors: set it to “On” - log_errors: set it to “On” (this is good for a dev environment but remember it affects performance) - extension=… (to add dll’s – we’ll need some to connect to PostGres, so I’ll come back to it later) - extension_dir: to tell PHP where it can find dll’s that are added through the ‘extension’ parameters - include_path: used to include external (php-)classes that can be used in your project (we’ll include the Zend framework classes, so I’ll come back to this later) Also something nice is PDO, when learning PHP you’ll stumble on to this – give it some extra attention! 3. Install & configure PostGres Why PostGres? Well, because we’re going to need it for a client. We’ll have an expert setting it up, but it always to know a little bit about what (or who) you are ‘doing’. Normally I would have gone for MySQL (which is part of and configured by WAMP). I suggest you follow the installer. Then open PgAdminIII (part of the installer) and double-click on your server. Enter your password (the one you entered during install) , right-click on ‘databases’ and select “New database…”. For this tutorial enter “firstphpdb” for the name and click “OK”. Then goto ‘Tools’ in the menu and select ‘Query tool’. Enter the following query: CREATE TABLE users ( id serial PRIMARY KEY, firstname varchar(50) UNIQUE NOT NULL, lastname varchar(50) UNIQUE NOT NULL, dateCreated timestamp DEFAULT current_timestamp );
  • 3. Then click the ‘Run’ button. This will create the “Users” table for you (under Schema’s Public Tables). I guess you can find out on your how to enter some names in there. This cheat sheet is quite useful. 4. Set up the Zend Framework OK, why Zend? Well it’s quite popular and IBM also likes it. Since I’m a big fan of Lotus Notes I’ll follow IBM on this. I’ll leave the discussion on which framework to use to the real PHP freaks. First, we need to make sure we can use the Zend classes. We do this in our php.ini through the ‘include_path’ parameter: ; Windows: "path1;path2" include_path = ".;C:Program FilesZendZendFramework-1.0.1library" Of course this setting depend on where you extracted your Zend Framework. Don’t forget to download it. Secondly, you’ll need to understand how it works and should be used. I’ll just explain the MVC setup, but Zend can do much more (I haven’t tried the other features, I’ll probably some more when I do). I’ll try to explain the MVC on a step-by-step basis: 1. Remove everything from you document root (the www-folder of your WAMP installation). First we’re going to create an .htaccess file in this folder. This file… Tip: You can’t create a file that starts with a dot in Explorer, use the “Save as…” function in Notepad. 2. Now, we’ll create an index.php file and drop it in our root folder (the www-folder of your WAMP installation). This file will launch when users browse to your server. You can find the file here. Everything is explained in the file itself: <?php try { // full error reporting (you can actually omit this because we also set this in php.ini) error_reporting(E_ALL); //includes: (remember the include_path in your php.ini? it’s used here) include_once('Zend/Loader.php'); //load the classes //the following translates into 'include(Zend/Controller/Front.php)' Zend_Loader::loadClass('Zend_Controller_Front'); Zend_Loader::loadClass('Zend_Db'); Zend_Loader::loadClass('Zend_Db_Table'); //configure the database $options = array( 'host' => 'localhost' ,
  • 4. 'username' => 'postgres' , 'password' => 'lotusnotes' , 'dbname' => 'firstphpdb' ); $db = Zend_Db::factory( 'PDO_PGSQL' , $options ); //Using Zend_Db_Table is not mandatory, //But it will help write models because it assists in 'fast-writing' sql-queries //If we omit Zend_Db_Table we should use the PDO model Zend_Db_Table::setDefaultAdapter( $db ); //configure the front controller (everything start here!) $controller = Zend_Controller_Front::getInstance(); $controller->setControllerDirectory( './FirstPHPProject/controllers'); //disable automatic view rendering (important, but look at Zend docs for the explanation) $controller->setParam('noViewRenderer' , true); //run the controller $controller->dispatch(); } catch (Exception $e) { echo $e->getMessage() . ' in ' . $e->getFile() . ' on line ' . $e->getLine() . "n"; } 3. Now, because of the Zend_Controller in the index.php file, we need to create a directory structure for our project that the Zend_Controller can use. It is very important that you create it exactly like the Zend framework wants it: The Zend_Controller will translate the url’s that are used. E.g. if you enter “localhost/index/index, Zend_Controller will look for the ‘indexAction’ in the ‘IndexController’ class in the controllers directory. If you enter “localhost/users/view”, it will look for the ‘viewAction’ in the ‘UsersController’. Now, you can ignore the “.cache” and “.settings” folder. Because I’m using Eclipse PDT as an editor, Eclipse created these folders. You can’t see the files, but .htaccess and index.php are at the same level as the folder “FirstPHPProject” and “public”. Now it’s up to you to create the same folder structure. 4. I hope you already know the basics of an MVC framework, because I’m not going to explain it. I’m just going to list the files you should create in each folder and explain some thing in the files themselves in the next chapter…
  • 5. 7. Start programming Is started of using the Zend Editor, which is very nice, but Sven Dens recommended using the Eclipse PDT plugin which has recently got it’s first 1-release. Since I’ve already used Eclipse and this is becoming our company ‘standard’ I went with it. So for no problems… You can find my entire www-folder in the post, so I suggest you download it. This is how it should look like (left is in Eclipse, right in Zend Editor): Most explanations are found in the files themselves. I’ll discuss the basics here.
  • 6. The Controllers As mentioned before, the Zend_Controller handles the requests and translates them into ‘actions’ from ‘controller’ classes in the “Controllers” folder. Let’s take the ‘contactAction’ ‘IndexController’ as an example which we can call through http://localhost/index/contact. The ‘init()’ function as called every time an instance of the IndexController is created. In here, we initialize the view (which we will render at the end of the the ‘contactAction’). We don’t need to specify which view to use: Zend will look for a file called contact.phtml (=action name + .phtml) the in the “index” directory (=controller name) in the “scripts” folder. So make sure it exists. Note that everything is case sensitive! Note: if you omit something, Zend will default to ‘index’. E.g. if you enter http://localhost is will translate to http://localhost/index/index. If you enter http://localhost/users is will translate to http://localhost/users/index. The Views As mentioned in the Controllers, Zend will look for a file with the same name as the action that’s called (in the folder with the same name as the Controller that’s called (in the “Script” folder)). So if you call http://localhost/users/view zend will execute the ‘viewAction’ in the ‘UsersController’ and when the ‘viewAction’ renders the view, zend will open the view.phtml file. The Model A model represents the database model. In our example we created the model “users.php”. This class inherits from the ‘Zend_Db_Table’ class. It has one constant ‘$_name’ which represent the name of the table in the database. The initial connection to the database was made in index.php. Now, we can use this model in our controllers. I suggest you look at the ‘addAction’ in the ‘UsersController’ to get started.