Mac OS X 內置Apache 和 PHP,使用起來很是方便。本文以Mac OS X 10.6.3和 10.8.1爲例。主要內容包括:php
有兩種方法:html
sudo apachectl start
」,再輸入賬號密碼,這樣Apache就運行了。sudo apachectl -v
」,你會看到Mac OS X的Apache版本信息,如10.8.1中: Server version: Apache/2.2.22 (Unix) Server built: Jun 20 2012 13:57:09
如此在瀏覽器中輸入「http://localhost」,就能夠看到一個內容爲「It works!」的頁面,其位於「/Library(資源庫)/WebServer/Documents/」下,這就是Apache的默認根目錄。mysql
注意:開啓了Apache就是開啓了「Web共享」,這時聯網用戶就會經過「http://[本地IP]/」來訪問「/Library(資源庫)/WebServer/Documents/」目錄,經過「http://[本地IP]/~[用戶名]」來訪問「/Users/[用戶名]/Sites/」目錄。值得注意的是,Mac OS X在10.8中取消」Web共享(Web Sharing)」時,也移除了「/Users/[用戶名]/Sites/」目錄,因此10.8中訪問「http://[本地IP]/~[用戶名]」會顯示「403 Forbidden」,但http://[本地IP]/依舊能夠訪問。能夠到「系統偏好設置」 -> 「安全(Security)」 -> 「防火牆(Firewall)」,開啓防火牆,而後在「防火牆選項(Firewall Options)」中勾上「組織全部進入鏈接(block all incoming connections)」便可。也能夠經過設置httpd.conf來只容許localhost和127.0.0.1訪問「/Library(資源庫)/WebServer/Documents/」。web
<Directory "/Library/WebServer/Documents"> ...... # # Controls who can get stuff from this server. # Order allow,deny #Allow from all Allow from 127.0.0.1 Allow from localhost </Directory>
sudo vi /etc/apache2/httpd.conf
」,打開Apache的配置文件。(若是不習慣操做終端和vi,能夠設置在Finder中顯示全部系統隱藏文件,記得設置完畢後須要重啓Finder,而後就能夠找到對應文件,爲所欲爲編輯了,須要注意的是某些文件的修改仍是須要開啓root賬號,但總體上仍是在終端上使用sudo
來臨時獲取root權限比較安全。)#LoadModule php5_module libexec/apache2/libphp5.so
」,把前面的#號去掉,保存(在命令行輸入:w
)並退出vi(在命令行輸入:q
)。sudo cp /etc/php.ini.default /etc/php.ini
」,這樣就能夠運行sudo vi /etc/php.ini
來編輯php.ini配置各類功能了。好比: ;經過下面兩項來調整PHP提交文件的最大值,如phpMyAdmin中導入數據的最大值 upload_max_filesize = 2M post_max_size = 8M ;經過display_errors來控制是否顯示PHP程序的報錯信息,這在調試PHP程序時很是有用 display_errors = Off
sudo apachectl restart
」,重啓Apache,這樣PHP就能夠用了。sudo cp /Library/WebServer/Documents/index.html.en /Library/WebServer/Documents/info.php
」,即在Apache的根目錄下複製index.html.en文件並重命名爲info.php。sudo vi /Library/WebServer/Document/info.php
」,這樣就能夠在vi中編輯info.php文件了。在「It’s works!」後面加上「<?php phpinfo(); ?>
」,而後保存之。如此就能夠在http://localhost/info.php中看到有關PHP的信息,好比10.8中內置PHP版本號是5.3.13。Mac OS X沒有內置MySQL,因此須要本身手動安裝,目前MySQL的最穩定版本是5.5。MySQL提供了Mac OS X下的安裝說明。算法
/usr/local
下的同名文件夾下。如運行「mysql-5.5.27-osx10.6-x86_64.dmg
」會把MySQL安裝到「/usr/local/mysql-5.5.27-osx10.6-x86_64
」中,一路默認安裝完畢。(注意,從10.8開始Mac OS X的權限更加嚴格,直接點擊會提示「mysql-5.5.27-osx10.6-x86_64.pkg can’t be opened because it is from an unidentified developer. Your security preferences allow installation of only apps from the Mac App Store and identified developers.」阻止了安裝,你可使用雙指單擊該安裝文件,在彈出菜單中選擇「用…打開(open with)」,再選擇「安裝(Installer)」就能夠接着安裝了。)sudo vi /etc/bashrc
」,在bash配置文件中加入mysqlstart
、mysql
和mysqladmin
的別名(注意:修改完畢以後須要退出「終端(Terminal)」以後從新進入,這些命令纔會生效): #mysql alias mysqlstart='sudo /Library/StartupItems/MySQLCOM/MySQLCOM restart' alias mysql='/usr/local/mysql/bin/mysql' alias mysqladmin='/usr/local/mysql/bin/mysqladmin'
這樣就能夠在終端中比較簡單地經過命令進行相應的操做。因爲開始安裝MySQLStartupItem.pkg到「/Library/StartupItems/MySQLCOM/
」來控制MySQL的運行、自動運行、中止、關閉之類。在MySQL沒有啓動時,直接運行mysql
或mysqladmin
命令會提示「Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
」,因此咱們能夠經過控制面板或者直接運行mysqlstart
命令來啓動MySQL,以後再運行mysql
或mysqladmin
命令就正常了。好比安裝完畢後MySQL的root
默認密碼爲空,若是要設置密碼能夠在終端運行「mysqladmin -u root password "mysqlpassword"
」來設置,其中mysqlpassword即root的密碼。更多相關內容能夠參考B.5.4.1. How to Reset the Root Password。sql
注意:Mac OS X的升級或其餘緣由可能會致使MySQL啓動或開機自動運行時,在MySQL操做面板上會提示「Warning:The /usr/local/mysql/data directory is not owned by the 'mysql' or '_mysql'
」,這應該是某種狀況下致使/usr/local/mysql/data
的宿主發生了改變,只須要運行「sudo chown -R mysql /usr/local/mysql/data
」便可。macos
另外,使用PHP鏈接MySQL可能會報錯「Can’t connect to local MySQL server through socket ‘/var/mysql/mysql.sock’」,或使用localhost沒法鏈接MySQL而須要127.0.0.1,緣由是鏈接時php默認去找/var/mysql/mysql.sock
了,但MAC版的MYSQL改動了文件位置,放在/tmp下了。處理辦法是按以下修改php.ini:apache
mysql.default_socket = /tmp/mysql.sock
phpMyAdmin是用PHP開發的管理MySQL的程序,很是的流行和實用。可以使用phpMyAdmin管理MySQL是檢驗前面幾步效果的很是有效方式。xcode
/Library/WebServer/Documents/
」中,並更名爲phpmyadmin。 sudo tar -xf ~/Downloads/phpMyAdmin-3.5.2.2-all-languages.tar.bz2 -C /Library/WebServer/Documents/ sudo mv /Library/WebServer/Documents/phpMyAdmin-3.5.2.2-all-languages /Library/WebServer/Documents/phpmyadmin
/Library/WebServer/Documents/phpmyadmin/
」中的config.sample.inc.php,並命名爲config.inc.php用於Cookie加密,隨意的長字符串 $cfg['blowfish_secret'] = 'a8b7c6d'; 當phpMyAdmin中出現「#2002 沒法登陸 MySQL 服務器(#2002 Cannot log in to the MySQL server)」時, 請把localhost改爲127.0.0.1就ok了, 這是由於MySQL守護程序作了IP綁定(bind-address =127.0.0.1)形成的 $cfg['Servers'][$i]['host'] = 'localhost'; 把false改爲true,這樣就能夠訪問無密碼的MySQL了, 即便MySQL設置了密碼也能夠這樣設置,而後登陸phpMyAdmin時輸入密碼 $cfg['Servers'][$i]['AllowNoPassword'] = false;
http://localhost/phpmyadmin
訪問phpMyAdmin了。此時會看到一個提示「沒法加載 mcrypt 擴展,請檢查您的 PHP 配置。(The mcrypt extension is missing. Please check your PHP configuration.)」,這會涉及到下一節安裝MCrypt擴展了。MCrypt是一個功能強大的加密算法擴展庫,它包括有22種算法,phpMyAdmin依賴這個PHP擴展庫。但在Mac OS X下的安裝卻不那麼友善,具體以下:瀏覽器
./configure --disable-posix-threads --enable-static
會報錯,運行make
會提示命令不存在,此時還須要打開Xcode,而後在Xcode的軟件「配置(Preference…)」)-> 「下載(Downloads)」 中安裝 「命令行工具(Command Line Tools)」: cd ~/Downloads tar -zxvf libmcrypt-2.5.8.tar.bz2 cd libmcrypt-2.5.8 ./configure --disable-posix-threads --enable-static make sudo make install
phpize
命令: cd ~/Downloads tar -zxvf php-5.3.13.tar.bz2 cd php-5.3.13/ext/mcrypt curl -O http://ftp.gnu.org/gnu/autoconf/autoconf-latest.tar.gz tar -zxvf autoconf-latest.tar.gz cd autoconf-2.69 ./configure make sudo make install cd .. phpize ./configure make sudo make install
sudo vi /etc/php.ini
在php.ini中加入以下代碼,並保存後退出,而後重啓Apache
extension=mcrypt.so
當你再訪問http://localhost/phpmyadmin
時,會發現「沒法加載 mcrypt 擴展,請檢查您的 PHP 配置。」提示沒有了,這就表示MCrypt擴展庫安裝成功了。若是還不能加載,嘗試把php.ini中的加入的extension
修改成:
extension=/usr/lib/php/extensions/no-debug-non-zts-20090626/mcrypt.so
Mac OS X下安裝MCrypt擴展的確比較複雜,並且稍微不當心會有各類小問題出現,你們還能夠參考How to Install mcrypt for php on Mac OSX Lion 10.8 & 10.7 Development Server和Adding MCRYPT to your OSX Lion PHP install
sudo vi /etc/apache2/httpd.conf
」,打開Apche的配置文件#Include /private/etc/apache2/extra/httpd-vhosts.conf
」,去掉前面的「#
」,保存並退出。sudo apachectl restart
」,重啓Apache後就開啓了虛擬主機配置功能。sudo vi /etc/apache2/extra/httpd-vhosts.conf
」,就打開了配置虛擬主機文件httpd-vhost.conf,配置虛擬主機了。須要注意的是該文件默認開啓了兩個做爲例子的虛擬主機: <VirtualHost *:80> ServerAdmin webmaster@dummy-host.example.com DocumentRoot "/usr/docs/dummy-host.example.com" ServerName dummy-host.example.com ErrorLog "/private/var/log/apache2/dummy-host.example.com-error_log" CustomLog "/private/var/log/apache2/dummy-host.example.com-access_log" common </VirtualHost> <VirtualHost *:80> ServerAdmin webmaster@dummy-host2.example.com DocumentRoot "/usr/docs/dummy-host2.example.com" ServerName dummy-host2.example.com ErrorLog "/private/var/log/apache2/dummy-host2.example.com-error_log" CustomLog "/private/var/log/apache2/dummy-host2.example.com-access_log" common </VirtualHost>
而實際上,這兩個虛擬主機是不存在的,在沒有配置任何其餘虛擬主機時,可能會致使訪問localhost時出現以下提示:
Forbidden You don't have permission to access /index.php on this server
最簡單的辦法就是在它們每行前面加上#,註釋掉就行了,這樣既能參考又不致使其餘問題。
<VirtualHost *:80> DocumentRoot "/Library/WebServer/Documents" ServerName localhost ErrorLog "/private/var/log/apache2/localhost-error_log" CustomLog "/private/var/log/apache2/localhost-access_log" common </VirtualHost> <VirtualHost *:80> DocumentRoot "/Users/[用戶名]/Sites" ServerName sites ErrorLog "/private/var/log/apache2/sites-error_log" CustomLog "/private/var/log/apache2/sites-access_log" common <Directory /> Options Indexes FollowSymLinks MultiViews AllowOverride None Order deny,allow Allow from all </Directory> </VirtualHost>
保存退出,並重啓Apache。
sudo vi /etc/hosts
」,打開hosts配置文件,加入"127.0.0.1 sites
",這樣就能夠配置完成sites虛擬主機了,能夠訪問「http://sites」了,在10.8以前Mac OS X版本其內容和「http://localhost/~[用戶名]」徹底一致。ErrorLog "/private/var/log/apache2/sites-error_log"
」也能夠刪掉,但記錄日誌實際上是一個好習慣,在出現問題時能夠幫助咱們判斷。若是保留這些log代碼,必定log文件路徑都是存在的,若是隨便修改一個不存在的,會致使Apache沒法服務而沒有錯誤提示,這個比較噁心。這裏利用Mac OS X 10.6.3和10.8.1中原生支持的方式來實現的配置,也能夠參考「Mac OS X Leopard: 配置Apache, PHP, SQLite, MySQL, and phpMyAdmin(一) 」和「Mac OS X Leopard: 配置Apache, PHP, SQLite, MySQL, and phpMyAdmin(二) 」。實際上,還可使用XAMPP或MacPorts這種第三方提供的集成方案來實現簡單的安裝和使用。