Оскільки встановлення і запуску web-серверу та СУБД під Windows складніший ніж для Linux із-за відсутності менеджера пакетів, то розгянемо детальний опис цієї процедури у операційні системі Майкрософту.
Apache та PHP
Cкачайте будь-який файл з розширенням msi із репозиторію Apache Foundation http://apache.cp.if.ua//httpd/binaries/win32/Запустіть інсталяцію. Протягом цього процесу вам необхідно буде ввести ім'я серверу (localhost), домене ім'я (localhost), email адресу адміністратора (немає значення яку). Apache сервер можна запускатись лише при вході під вашим користувачем або може бути встановлений як сервіс і не залежити від того який профіль користувача буде запущений.
Після запуску web-сервера повинна завантажуватись сторіка http://localhost/ (із вмістом "It works!"). Якщо сервер не запустився, причиною може бути програма, що вже використовує (слухає) цей порт. Найчастіше це Skype, для того щоб він не слухав порт, необхідно зайтив в настройки, знайти налаштування мережі і зняти галочку «Використовувати порти 80 та 443 як альтернативні для підключення» («Use port 80 and 443 as alternatives for incoming connections»). В іншому випадку прочитайте інструкцію «Как определить, какая программа использует или блокирует порты протокола передачи определенного элемента управления в Windows»
Наступним кроком буде підключення PHP до Apache. Для цього потрібно скачати архів з модулем і інтерпретатором PHP http://windows.php.net/download/. Розпакуйте його у будь-де на диску C: (для прикладу C:\php). У теці (папці), де встановлений Apache (за замовчуванням це C:\Program Files\Apache Foundation\Apache2.2) відкрийте головний конфігураційний файл conf/httpd.conf і додайте в кінці два рядки:
Друга директива реєструє файл який містить у назві «.php» як файл програми на PHP у форматі стандарту Multipurpose Internet Mail Extensions (MIME)
У теці PHP знайдіть файл php.ini-development, скопіюйте його і змініть назву на php.ini . Це - файл налаштувань php, за замовчуванням, при запуску Apache він шукається у системні директорії Windows: C:\Windows . Якщо ви не хочете туди поміщати php.ini, то ви можете вказати директивою (у httpd.conf)
Детальніше ви можете дізнатись у офіційні документації: «Установка PHP как обработчика под Apache»
У httpd.conf знайдіть директиву
У адресі в браузері введіть localhost/ або 127.0.0.1/ повинна завантажитись сторінка
Запустіть інсталяцію, оберіть тип встановлення (Setup Type) типовий для розробника (Developer Default). Дійшовши до налаштувань серверу (MySQL Server Configuration) оберіть тип налаштування (Config Type) Developer Machine. Дозволиши мережеві підключення (Enable TCP/IP Networking) ви можете підлючитись до серверу з іншої комп'ютера.
У наступному вікні введіть пароль адміністратора (root-та) та добавте користувачів (User Account) даної машини, які зможуть працювати з базою даних. Це ж саме ви зможете зробити після встановлення за допомогою MySQL Workbench або вручну добавивши записи у таблицю user системної бази даних mysql. Для кожного web-додатку добре було би створювати відповідного користувача з обмеженнями (ролями) достатніми, щоб додаток не міг пошкодити дані інших додатків.
Для того, щоб підключитись до MySQL у коді PHP відкрийте файл php.ini, знайдіть рядок
Створіть в кореневій папці докуменів (DocumentRoot, %Apache%/htdocs) файл mysql-test.php і помістіть у нього такий код:
Перезавантажте сервер. Зайдіть http://localhost/mysql-test.php . Якщо все налаштовано правильно, то ви побачете список користувачів бази даних, в іншому випадку код виведе стрічку з помилкою, яка починається з "Error!: "
LoadModule php5_module "C:/php/php5apache2_2.dll"
AddHandler application/x-httpd-php .php
У першому рядку вказується (директивою) завантажити модуль під назвою php5_module з файлу, що знаходиться у теці, в яку розпакували архів PHP, php5apache2_2.dll, 2_2 в даному випадку вказує на те, що цей модуль може завантажуватись лише серевером Apache версії 2.2, для інших версій назва dll-бібліотеки з модулем може бути іншою, наприклад php5apache2.dll, якщо версія 2.0 і php5apache2_4.dll - 2.4Друга директива реєструє файл який містить у назві «.php» як файл програми на PHP у форматі стандарту Multipurpose Internet Mail Extensions (MIME)
У теці PHP знайдіть файл php.ini-development, скопіюйте його і змініть назву на php.ini . Це - файл налаштувань php, за замовчуванням, при запуску Apache він шукається у системні директорії Windows: C:\Windows . Якщо ви не хочете туди поміщати php.ini, то ви можете вказати директивою (у httpd.conf)
PHPIniDir "C:/php"
теку у якій забажали помістити файл конфігурацій.Детальніше ви можете дізнатись у офіційні документації: «Установка PHP как обработчика под Apache»
У httpd.conf знайдіть директиву
DocumentIndex index.html
що вказує які назви файлів повиннні відкрииватись (запускатись), якщо користувач не вказав файл він хоче переглянути, а лише директорію. Додамо до цього списку index.phpDocumentIndex index.html index.php
Директива DocumentRoot вказує на теку із якої будуть відображатись документи, для прикладуDocumentRoot "C:/Program Files/Apache Software Foundation/Apache2.2/htdocs"
Зайдіть у цю директорію, видаліть або переіменуйте файл index.html. Cтворіть файл index.php із вмістом<?php phpinfo(); ?>Перезапустіть сервер (Панель керування > Адміністрування > Служби)
У адресі в браузері введіть localhost/ або 127.0.0.1/ повинна завантажитись сторінка
MySQL
Завантажте з офіційного сайту http://dev.mysql.com/downloads/mysql/ MySQL Installer MySQL Community Server-а. Інсталятор включає в себе MySQL Server, інструмент для візуального проектування баз даних MySQL Workbench, навчальні бази даних, інструмент моніторигу MySQL Notifier, розширеня для Excel і Visual Studio та документацію.Запустіть інсталяцію, оберіть тип встановлення (Setup Type) типовий для розробника (Developer Default). Дійшовши до налаштувань серверу (MySQL Server Configuration) оберіть тип налаштування (Config Type) Developer Machine. Дозволиши мережеві підключення (Enable TCP/IP Networking) ви можете підлючитись до серверу з іншої комп'ютера.
У наступному вікні введіть пароль адміністратора (root-та) та добавте користувачів (User Account) даної машини, які зможуть працювати з базою даних. Це ж саме ви зможете зробити після встановлення за допомогою MySQL Workbench або вручну добавивши записи у таблицю user системної бази даних mysql. Для кожного web-додатку добре було би створювати відповідного користувача з обмеженнями (ролями) достатніми, щоб додаток не міг пошкодити дані інших додатків.
Для того, щоб підключитись до MySQL у коді PHP відкрийте файл php.ini, знайдіть рядок
; extension_dir = "ext"
Розкоментуйте його, забравши крапку з комою і замість ext вкажіть повний шлях до директорії з розширеннями:extension_dir = "C:/php/ext"
Знайдіть рядок;extension=php_pdo_mysql.dll
Заберіть символ коментаря. Це - PHP Data Objects драйвер для бази даних MySQL.Створіть в кореневій папці докуменів (DocumentRoot, %Apache%/htdocs) файл mysql-test.php і помістіть у нього такий код:
<?php try { $user = 'root'; $password = '1111'; $dbh = new PDO('mysql:host=localhost;dbname=mysql', $user, $password); foreach($dbh->query('SELECT User, Host from User') as $row) { echo $row['User'] . '@' . $row['Host'] . ', '; } $dbh = null; } catch (PDOException $e) { print "Error!: " . $e->getMessage(); die(); } ?>Вкажіть ім'я користувача (в коді root) і пароль (в коді 1111).
Перезавантажте сервер. Зайдіть http://localhost/mysql-test.php . Якщо все налаштовано правильно, то ви побачете список користувачів бази даних, в іншому випадку код виведе стрічку з помилкою, яка починається з "Error!: "
Встановлення у Linux на прикладі Ubuntu
Встановлення Apache 2:apt-get install apache2
Встановлення PHP 5:apt-get install php5-common php5
Встановлення Apache-модуля PHP:apt-get install libapache2-mod-php5
Встановлення PHP-інтерпретатора командної стрічки:apt-get install php5-cli
Встановлення сервера MySQL:apt-get install mysql-server
Встановлення клієнта MySQL:apt-get install mysql-client
Встановлення розширення (extension) PHP для MySQL:apt-get install php5-mysql
Встановлення модуля Apache, що дозволяє аутентифікацію використовуючи дані користувачів, записані у базу даних MySQL:libapache2-mod-auth-mysql