/ 中存储网

Windows系统中配置PHP5 + Apache2.2 + MySQL5.1环境

2013-12-25 09:51:01 来源:IT技术网

昨天突然又想弄点PHP,于是在我的本本上开始配置,以前也配置过,主要问题连接MySqL不成功,提示Fatal error: Call to undefined function mysql_connect() 。上网找资料,不是说设置环境变量就是把php.ini和libmysql.dll拷到system32目录下什么的,都试过了,可都没成功,最后就放弃了。这次遇到同样的问题,但我下了决心:不弄成功我就把我的本本砸了!终于,我还是心疼我的本本,刚才配置成功了。一陈喜悦^o^……

配置环境:Windows Xp Professional Sp2 + Apache 2.2.4 + PHP 5.2.5 + Mysql 5.1.33

现把经验分享如下:

关键目录表示:PHP安装目录——PHP_Dir,Apache安装目录——Apache_Dir。注意目录字串末尾都没有“/”或“”

1.安装 MySql,PHP,Apache,安装一般没有什么问题,关键在于配置。

2.配置 php.ini:

(1)把PHP_Dir目录下的php.ini-dist复制一份,重命名为 php.ini。

(2)打开 php.ini,查找定位到extension_dir,设置为extension_dir = "PHP_Dir"。注意PHP_Dir结束不包括斜杠“/”号,且把反斜杠“”改为斜杠“/”。

(3)在php.ini中,定位到extension=php_mysql.dll,把这一行的前面的“;”号删除,并且改为extension=ext/php_mysql.dll。如果要加载mysqli或其它模块,同样这样修改。

在配置extension_dir的时候,网上有很多,但基本是保留默认的"./",并且又拷贝文件又设置环境变量的,太麻烦。在我本本上从未成功过(我只在公司一台式机上配置成功过)。我现在这种配置,MYSQL模块的路径合起来就是“PHP_Dir/ext/php_mysql.dll”,否则Apache启动的时候就不能加载Mysql模块。

3.配置 httpd.conf

(1)把Apache_Dirconf目录下的httpd.conf打开(像我这样的新手最好拷贝一份,呵呵)。

(2)定位到Listen,默认为Listen 80,如果有多个服务器,可以做适当修改,我IIS占用了80端口,所以我改为Listen 81。

(3)添加LoadModule,为阅读方便,定位到一大串的LoadModule的后面,添加

LoadModule php5_module "PHP_Dir/php5apache2_2.dll"

AddType application/x-httpd-php .php

PHPIniDir "PHP_Dir"

如果使用php5apache2_2.dll也可能是php5apache2.dll,根据自己的环境设置

(4)适当设置根目录,我把DocumentRoot "Apache_Dir/htdocs"改成了其它目录,在<Directory "Apache_Dir/htdocs">也作相应修改。

至此,配置完成。等我兴冲冲地打开浏览器,输入 http://localhost:81/phpinfo.php ,搞回车,呵呵,找到MySql的相关信息了。说明加载MySql成功。

可是,福无双至,祸不单行,等我调用 mysql_connect()函数的时候,该死的VS蹦出一个框说“httpd.exe [2712] 中发生未处理的 win32 异常”,“httpd.exe 中的 0x0079ac5a 处未处理的异常: 0xC0000005: 读取位置 0x00000014 时发生访问冲突”。我晕倒!!

Google一下,发现一位仁兄是这样解决的:

1 将php.ini所在目录添加到环境变量path中

2 新建系统变量 PHPRC=“php.ini所在目录”

3 如果经过以上两部还是不成功那就出绝招:将php安装目录下libmysql.dll文件拷贝到windows/system32下

4 将libmysql.dll拷贝到apache/bin下

他/她说经过1、2、4步解决了。我很懒,不想添加环境变量,直接把PHP_Dir目录下的libmysql.dll拷到Apache_Dir/bin下,重启Apache,报告连接成功!

配置感言

==========================

在我上网找资料了时候,发现CSDN里的一位仁兄在很多人的帮助下,都没把MySql加载上,最后一气之下,说以后再也不玩PHP了。我也曾经放弃过。相信有无数的前辈和兄弟都遇到这个门槛,估计也有不少是这样放弃了的。就是没有把PHP环境配置成功,特别是没有把MySql连接上。我也试遍了网上的各种方法,与CSDN里那位一样,都没成功,只好自己思考,原来我们都离成功只差一点点,对extension_dir和extension稍等修改即可。最后只总结出四个字:路径问题。