Mac下搭建php开发环境教程
Mac OS X 内置了Apache 和 PHP,这样使⽤起来⾮常⽅便。本⽂以Mac OS X 10.6.3为例。主要内容包括:
启动Apache
运⾏PHP
安装MySQL
使⽤phpMyAdmin
配置PHP的MCrypt扩展库
设置虚拟主机
有两种⽅法:
打开“系统设置偏好(System Preferences)” -> “共享(Sharing)” -> “Web共享(Web Sharing)”
打开“终端(terminal)”,然后(注意:sudo需要的密码就是系统的root帐号密码)
运⾏“sudo apachectl start”,再输⼊帐号密码,这样Apache就运⾏了。
运⾏“sudo apachectl -v”,你会看到Mac OS X 10.6.3中的Apache版本号:
Server version: Apache/2.2.14 (Unix)
Server built:  Feb 11 2010 14:40:31
在终端中运⾏“sudo vi /etc/f”,打开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”,这样就可以通过php.ini来配置各种PHP功能了。⽐如:
;通过下⾯两项来调整PHP提交⽂件的最⼤值,⽐如phpMyAdmin中导⼊数据的最⼤值
upload_max_filesize = 2M
post_max_size = 8M
;⽐如通过display_errors来控制是否显⽰PHP程序的报错
display_errors = Off
运⾏“sudo apachectl restart”,重启Apache,这样PHP就可以⽤了。
运⾏“cp /Library/WebServer/Documents/ /Library/WebServer/Documents/info.php”,即在Apache的根⽬录下复制⽂件并重命名为info.php
由于Mac OS X中并没有预装MySQL,所以需要⾃⼰⼿动安装,⽬前MySQL的最稳定版本是5.1。MySQL提供了Mac OS X下的安装说明。
下载MySQL 5.1。选择合适的版本,⽐如这⾥选择的是mysql-5.1.46-osx10.6-x86_64.dmg。
运⾏dmg,会发现⾥⾯有4个⽂件。⾸先点击安装mysql-5.1.46-osx10.6-x86_64.pkg,这是MySQL的主安装包。⼀般情况下,安装⽂件会⾃动把MySQL安装到/usr/local下的同名⽂件夹下。⽐如点击运⾏“
mysql-5.1.46-osx10.6-x86_64.dmg”会把MySQ安装到“/usr/local/mysql-5.1.46-osx10.6-x86_64”中。⼀路默认安装完毕即可。
点击安装第2个⽂件MySQLStartupItem.pkg,这样MySQL就会⾃动在开机时⾃动启动了。
点击安装第3个⽂件MySQL.prefPane,这样就会在“系统设置偏好”中看到名为“MySQL”的ICON,通过它就可以设置MySQL开始还是停⽌,以及是否开机时⾃动运⾏。到这⾥MySQL就基本安装完毕了。
通过运⾏“sudo vi /etc/bashrc”,在bash的配置⽂件中加⼊mysql和mysqladmin的别名
复制代码代码如下:
#mysql
alias mysql='/usr/local/mysql/bin/mysql'
alias mysqladmin='/usr/local/mysql/bin/mysqladmin'
这样就可以在终端中⽐较简单地通过命令进⾏相应的操作,⽐如安装完毕之后MySQL的root默认密码为空,如果要设置密码可
以在终端运⾏“mysqladmin -u root password "mysqlpassword"”来设置,其中mysqlpassword即root的密码。更多相关内容可以参考B.5.4.1. How to Reset the Root Password。
注意:Mac OS X的升级或者其他原因可能会导致MySQL启动或者开机⾃动运⾏,在MySQL的操作⾯板上会提
⽰“Warning:The /usr/local/mysql/data directory is not owned by the 'mysql' or '_mysql' ”,或者在命令⾏下提⽰“Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)”,这应该是某种情况下导致/usr/local/mysql/data的宿主发⽣了改变,只需要运⾏“sudo chown -R mysql /usr/local/mysql/data”即可。
另外,使⽤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:
mysql.default_socket = /tmp/mysql.sock
phpMyAdmin是⽤PHP开发的管理MySQL的程序,⾮常的流⾏和实⽤。能够实⽤phpMyAdmin管理MySQL是检验前⾯⼏步成果的⾮常有效⽅式。
下载phpMyAdmin。选择合适的版本,⽐如我选择的是phpMyAdmin-3.3.2-all-languages.tar.bz2这个版本。
把“下载(downloads)”中的phpMyAdmin-3.32-all-languages⽂件夹复制到“/Users/[⽤户名]/Sites”中,名改名为phpmyadmin。
复制“/Users/[⽤户名]/Sites/phpmyadmin/”中的config.sample.inc.php,并命名为config.inc.php
打开config.inc.php,做如下修改:
⽤于Cookie加密,随意的长字符串
$cfg['blowfish_secret'] = '';
当phpMyAdmin中出现“#2002 ⽆法登录 MySQL 服务器”时,
请把localhost改成127.0.0.1就ok了,
这是因为MySQL守护程序做了IP绑定(bind-address =127.0.0.1)造成的
$cfg['Servers'][$i]['host'] = 'localhost';
mysql下载下来是一个文件夹把false改成true,这样就可以访问⽆密码的MySQL了,
即使MySQL设置了密码也可以这样设置,然后在登录phpMyAdmin时输⼊密码
$cfg['Servers'][$i]['AllowNoPassword'] = false;
MCrypt是⼀个功能强⼤的加密算法扩展库,它包括有22种算法,phpMyAdmin依赖这个PHP扩展库。但是它在Mac OS X下的安装却不那么友善,具体如下:
下载并解压libmcrypt-2.5.8.tar.bz2。
在终端执⾏如下命令(注意如下命令需要安装xcode⽀持):
复制代码代码如下:
cd ~/Downloads/libmcrypt-2.5.8/
./configure --disable-posix-threads --enable-static
make
sudo make install
下载并解压PHP源码⽂件php-5.3.1.tar.bz2。Mac OS X 10.6.3中预装的PHP版本是5.3.1,⽽现在最新的PHP版本是5.3.2,你需要依据⾃⼰的实际情况选择对应的版本。
复制代码代码如下:
cd ~/Downloads/php-5.3.1/ext/mcrypt
phpize
./configure
make
cd modules
sudo cp mcrypt.so /usr/lib/php/extensions/no-debug-non-zts-20090626/
打开php.ini
sudo vi /etc/php.ini
在php.ini中加⼊如下代码,并保存后退出,然后重启Apache
extension=/usr/lib/php/extensions/no-debug-non-zts-20090626/mcrypt.so
在终端运⾏“sudo vi /etc/f”,打开Apche的配置⽂件
在f中到“#Include /private/etc/apache2/f”,去掉前⾯的“#”,保存并退出。
运⾏“sudo apachectl restart”,重启Apache后就开启了它的虚拟主机配置功能。
运⾏“sudo vi /etc/apache2/f”,这样就打开了配置虚拟主机的⽂件f,配置你需要的虚拟主机了。需要注意的是该⽂件默认开启了两个作为例⼦的虚拟主机:
复制代码代码如下:
<VirtualHost *:80>
ServerAdmin ample
DocumentRoot "/usr/ample"
ample
ErrorLog "/private/var/log/ample-error_log"
CustomLog "/private/var/log/ample-access_log" common
</VirtualHost>
<VirtualHost *:80>
ServerAdmin ample
DocumentRoot "/usr/ample"
ample
ErrorLog "/private/var/log/ample-error_log"
CustomLog "/private/var/log/ample-access_log" common
</VirtualHost>
⽽实际上,这两个虚拟主机是不存在的,在没有配置任何其他虚拟主机时,可能会导致访问localhost时出现如下提⽰:
Forbidden
You don't have permission to access /index.php on this server
最简单的办法就是在它们每⾏前⾯加上#,注释掉就好了,这样既能参考⼜不导致其他问题。
增加如下配置
复制代码代码如下:
<VirtualHost *:80>
DocumentRoot "/Users/[⽤户名]/Sites"
ServerName sites
ErrorLog "/private/var/log/apache2/sites-error_log"
CustomLog "/private/var/log/apache2/sites-access_log" common
</VirtualHost>
保存退出,并重启Apache。
这是利⽤Mac OS X 10.6.3中原⽣⽀持的⽅式来实现的配置,也可以参考“Mac OS X Leopard: 配置Apache, PHP, SQLite, MySQL, and phpMyAdmin(⼀) ”和“Mac OS X Leopard: 配置Apache, PHP, SQLite, MySQL, and phpMyAdmin(⼆) ”。实际上,你还可以使⽤XAMPP或MacPorts这种第三⽅提供的集成⽅案来实现简单的安装和使⽤。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。