php将可以正常的和apache结合,并且常见的诸如:PHP Warning: PHP Startup: Unable to load dynamic library……、Fatal error: Call to undefined function mysql_connect() 错误
不过今天在弄一个CMS时还是出现了一个不可饶恕的错误,无法连接mysql,写了一个测试mysql的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 |
注意,最后一行是关键,告诉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 |