php将可以正常的和apache结合,并且常见的诸如:PHP Warning: PHP Startup: Unable to load dynamic library……、Fatal error: Call to undefined function mysql_connect() 错误.
不过今天在弄一个CMS时还是出现了一个不可饶恕的错误,无法连接mysql,写了一个测试mysql的php文件如下:
- <?php
- $link=mysql_connect('localhost','root','root');
- if(!$link) echo "失败!";
-
- else echo "成功!";
- mysql_close();
- ?>
结果报错误:Fatal error: Call to undefined function mysql_connect(),明显没法找到mysql相应的库,百度了一大堆,又是什么复制mysql的lib库、又是复制到windows的system32目录,过于复杂,其实正确的配置应该是在apache的httpd.conf文件中加入下设置:
LoadModule php5_module d:/tools/php-5.3.1/php5apache2_2.dll
AddType application/x-httpd-php .php
PHPIniDir d:/tools/php-5.3.1
注意,最后一行是关键,告诉apache你的php配置文件在哪里,不然你就得把php.ini文件复制到windows的系统目录下了,一般我们通过这里配置就可以完成apache和php的结合,而在php.ini文件中只需要修改如下几个地方即可.
# 修改php的扩展库目录为你的实际路径
extension_dir = "D:/tools/php-5.3.1/ext"
# 去掉前面的;
extension=php_mysql.dll
最后一个步骤就是在系统环境变量,注意是系统环境变量,而非用户环境变量,path中加入你的PHP安装路径,在设置成功后,通过phpinfo()应该可以在Apache Environment段的path中可以看到你的PHP安装目录,否则就是环境变量没有配置成功,注意,配置环境变量后重启下apache.
完成这些步骤后就可以正确连接数据库了,不过前提是你的apache和php的整合是正常的,然后再考虑这个mysql配置,如果还不能够达到效果,你可以质问我,呵呵.
总结,windows平台下apache和php,包括mysql,整合的正确配置步骤如下:
1、安装apache,并保证apache可以单独正常运行
2、将php(如5.2.17或5.3.1)的zip包解压到一个目录,比如D:php-5.3.1
3、在apache的httpd.conf文件的最后加入如下段:
# php5 supportLoadModule php5_module D:/php-5.3.1/php5apache2_2.dll
AddType application/x-httpd-php .php
PHPIniDir D:/php-5.3.14
在操作系统的环境变量,必须是系统变量而非用户变量,path中加入D:/php-5.3.1路径
5、将php安装目录下的php.ini-dist重命名为php.ini,并修改如下内容:
# 设置php的扩展文件目录,代码如下:
extension_dir = "D:/php-5.3.17/ext"
# 开启mysql扩展,去掉前面的;注释,代码如下:
extension=php_mysql.dll |