PHP服务器安装

来源:互联网 发布:小米手机暂无卡片数据 编辑:程序博客网 时间:2024/06/01 08:13
先从www.apache.com上下一个http服务器,然后到www.php.com下载php包,它将作为apache服务器的一个模块.

1.现在apache http服务器最新版本是2.2.3.我开始下载的也是这个,安装过程很简单.

2.然后安装php包,最新版本是5.1.6,也很简单,解压缩到任意的地方,比如C:php,然后把这个文件夹路径C:php加入到环境变量path中.

3.配置php:
把php文件夹中的php.ini-recommended复制为php.ini就ok了.

4.更改apache服务器来加入php模块:
在conf/httpd.conf文件中加入:

# For PHP 5 do something like this:
LoadModule php5_module "C:/php/php5apache2.dll"              <---- LINE 117
AddType application/x-httpd-php .php

# configure the path to php.ini
PHPIniDir "C:/php"

然后重新启动apache服务器,结果报错:
httpd.exe: Syntax error on line 117 of C:/apache/conf/httpd.conf: Cannot load C:
/php/php5apache2.dll into server: The specified module could not be found.
Note the errors or messages above, and press the <ESC> key to exit. 20...

花了我两个小时时间...哭...

解决办法:
下个2.0.59的apache服务器就ok了,前面的错误是版本问题造成的.

要检查是否装好了,把下面的代码存为hello.php,放在安装apache服务器主文件夹下的htdocs里面.运行服务器,
在浏览器里输入:localhost/hello.php查看.

   <?php
$time = time();
$thetime = date("l, jS F Y g:ia",$time);
echo "Hello world! The time is currently". $thetime .".";
?>

Updated:2006-10-10

哎,第二天又遇到了新的问题,连接不了数据库,提示错误:

Call to undefined function mysql_connect() in ...

原因是php5取消了捆绑mysql client ,需要我们自己更改配置文件.
取消extension php_mysql.dll的注释,然后设置好extension_dir就ok了.

可以参考这两篇文章:
http://www.faqts.com/knowledge_base/view.phtml/aid/23162
http://php.net/manual/en/faq.databases.php#faq.databases.mysql.php5

我的配置没有问题,ddl文件也都在正确的地方,可是问题依旧,最后只好再次更换软件版本,我把php换成了4.4.4的。
因为4.4.4是自动配置好mysql的,所以不需要更改php.ini,只需要编辑一下apache的配置文件:
#LoadModule php5_module "c:/php/php5apache2.dll"
LoadModule php4_module "c:/php/sapi/php4apache2.dll"
AddType application/x-httpd-php .php

可以用这个php测试代码来测试:
<?php

echo phpinfo();
        
$link = mysql_connect('localhost', 'root', '123456');
if (!$link) {
   
die('Could not connect: ' . mysql_error());
}
echo 'Connected successfully';
mysql_close($link);
?>

令人欣慰的是这一次能够找到mysql_connect方法了,但是又有新的错误:

Client does not support authentication protocol

到这里差点就想放弃了!想到PHP的重要性,最后还是咬咬牙坚持挺了过来。

这个错误是因为php4里的mysql客户端程序的密码算法和新的mysql服务器不兼容,对于php4解决办法好象只有一个,在mysql里面执行下面的命令就可以了:
mysql> UPDATE mysql.user SET Password = OLD_PASSWORD('newpwd')
    
-> WHERE Host = 'some_host' AND User = 'some_user';
mysql
> FLUSH PRIVILEGES;


可以参考这里:
http://dev.mysql.com/doc/refman/5.0/en/old-client.html

 

原创粉丝点击