windows03+apache+php+mysql 搭建过程及错误

以下为一篇Apache2.2.4和php5.2.1配置方法的转载文章(来自:javaeye.com/topic/94722),虽然说得比较详细。但实际应用中不需要这样去处理。我的做法是下载一个集成APACHE&PHP&MYSQL的安装包(例如:EasyPHP),直接安装即可。

一.php的安装与调试
由于php是一个zip文件(非install版),安装较为简单,解压就行。把解压的 php5.2.1-Win32重命名为 php5。并复制到C盘目录下。即安装路径为 c:\php5
1    找到php目录下的 php.ini-dist或 php.ini.recommended文件,重命名为 php.ini
并复制到系统盘的windows目录下(以c:\windows为例).
2    再把php目录下的php5ts.dll,libmysql.dll复制到目录 c:\windows\system32下。
3    把php5\ext目录下的php_gd2.dll,php_mysql.dll,php_mbstring.dll文件复制到c:\windows\system32下
如果没有加载 php_gd2.dll    php将不能处理图像。没有加载php_mysql.dll php将不支持mysql函数库
php_mbstring.dll在后面使用phpmyadmin时支持宽字符。
4 打开c:\windows\php.ini文件(关联到mysql)
设置扩展路径
查找 extension_dir 有这么一行extension_dir = “./”
将此行改成
extension_dir = “C:\php5\ext”
其中C:\php5是你安装php的路径。路径不正确将无法加载dll
(注意:有些php版本是 ;extension_dir = “./” 要把前面的分号去掉)
查找 extension
extension=php_mbstring.dll
extension=php_gd2.dll
extension=php_mysql.dl
把上面3项前面的分号去掉,这样apache启动时就可以加载这些dll了
当然前面我们也把这些dll复制到system32下了l
php5时差问题
时间相差八小时
为什么呢?PHP5系列版本新增了时区设置,默认为格林威治时间,与中国所在的东8区正好相差8个小时
查找date.timezone有这么一行
;date.timezone =
将;去掉,改成
date.timezone = PRC
二.apache的调试和整合
1.修改网站根目录
查找 DocumentRoot有这么一行
DocumentRoot”C:/Program Files/Apache Group/Apache2/htdocs”
这就是你网站的根目录,你可以修改,也可以用默认的.如果改,还要修改下面这项,否则可能会出现 403 错误
查找    This should be changed to whatever you set DocumentRoot to .
在它下面两行有
<directory group=”" apache2=”" program=”" apache=”" files=”"></directory>
把上面两项的 C:/Program Files/Apache Group/Apache2/htdocs 改成你想要的目录
2.让apache支持*.php(网页)
查找    DirectoryIndex index.html index.html.var
修改成
DirectoryIndex index.html index.html.var    index.php
这样index.php 可以充当默认页面了
3.Apache中模块化安装php
查找 # LoadModule foo_module modules/mod_foo.so
在此行后加入一行
LoadModule php5_module C:/php5/php5apache2.dll //注意:其中C:/php5/php5apache2.dll是你安装php的相应路径.不要把php5apache2.dll和php5apache.dll混淆.php5apache.dll只适用于apache 版本1的.PHP5压缩包里的php5apache2.dll只适用于apache2.0.*版本,如果是2.2.*以上版本,就可能会出现”Cannot load C:/php/php5apache2.dll into server: The specified module could not be found.”或者:”The requested operation has failed”
4.查找 AddType application/x-gzip .gz .tgz
在此行后加入一行
AddType application/x-httpd-php .php (记住:前边有一个空格哦!!!)
这样apache就可以解释php文件了

在配置文件中加入一行:

phpinidir c:/php //定义php.ini文件路径,载入php模块相关配置(否则安装discuz时会提示没有载入mysql模块)
5.测试
在网站根目录下创建一个 phpinfo.php 文件

phpinfo();
?>

在浏览器打开
http://localhost/phpinfo.php
5.测试php和mysql数据库的关联
在网站根目录下创建一个test.php 文件
$link=mysql_connect(“localhost”,”root”,”12345″);    //12345改成你的mysql密码
if(!$link) echo “失败!”;
else echo “成功!”;
mysql_close();
?>
在浏览器打开 http://localhost/test.php
如果输出成功,则说明大功告成。

特别注意标注的红色部分。感谢原作者。

当前日期: 2010-11-05 星期五 当前时间: 11:18:30.35

再上一错误:

前几天配置iis下php,自己遇到过,网上也提到过iis和php指定版本存在兼容性问题,今天在Apache下也遇到了。

采用discuz做一个论坛,然后在iis下遇到过安装到数据库时,页面打不开,程序崩溃。

今天在Apache下做到安装数据库时,程序再次崩溃。

感觉不对劲查log:错误应用程序 httpd.exe,版本 2.2.17.0,错误模块 php5ts.dll,版本 5.2.14.14,错误地址 0x0000ac5a。

search:

php使用MySql函数导致Apache|iis崩溃的问题:错误应用程序 httpd.exe,版本 2.2.14.02010-04-20 08:24这个问题是在Windows下配置PHP环境时发生的。

具体的表现是php运行正常,但是只要一调用MySql的相关函数,Apache就会崩溃掉。

环境配置方式:

php以模块的方式运行在Apache下。自定义php.ini路径

phpinfo()显示mysql库加载成功

崩溃后在Windows的错误日志中会留下以下内容:

错误应用程序 httpd.exe,版本 2.2.14.0,错误模块 php5ts.dll,版本 5.2.10.10,错误地址 0x0000ac6a。

原因如下:

在安装MySql的时候在配置设定时把MySql的Bin目录放到了系统环境变量Path中。而Bin目录中正好有一个libmysql.dll的库。

而php在加载mysql库的时候会搜索系统环境变量Path每一个目录寻找libmysql.dll,由于mysql的bin目录也在其中,那么php就先把mysql的libmysql.dll加载了。所以就会由于库的兼容问题导致mysql的函数无法运行。 //我的确将mysql加入到了环境变量中

解决方案:

将mysql的bin目录从系统环境变量Path中移出
将libmysql.dll从MySql的bin目录中移出
或者将php的libmysql.dll文件替换mysql的bin下

php文件夹权限,会导致无法加载dll文件,再次确定mysql中的mysql.dll文件位置不在系统环境变量中,否则启动php时,以后会出错,即为兼容性问题

发表评论

删掉Powerd by Discuz!

Discuz_X1.5_SC_GBK\upload\template\default\common\header_common.htm
删掉Powerd by Discuz!
发表评论

NETWORK SERVICE没权限激活CLSID为{BA126AD1-2166-11D1-B1D0-00805FC1270E}的应用程序。可以通过使用组件服务管理工具修改此安全权限。

为应用程序池 ‘DefaultAppPool’ 提供服务的进程意外终止。进程 ID 是 ’3544′。进程退出代码是 ’0xc06d007e’。
Generate Activation Context 为 C:\WINDOWS\system32\SHELL32.dll 失败。 参考错误消息: 拒绝访问。
Resolve Partial Assembly 为 Microsoft.Windows.Common-Controls 失败。 参考错误消息: 拒绝访问。
Generate Activation Context 为 C:\WINDOWS\system32\TAPI32.dll 失败。 参考错误消息: 拒绝访问。
Generate Activation Context 为 C:\WINDOWS\system32\netshell.dll 失败。 参考错误消息: 拒绝访问。
为应用程序池 ‘DefaultAppPool’ 提供服务的进程在与 World Wide Web Publishing 服务通信时遇到致命错误。进程 ID 为 ’968′。数据字段包含错误号。
应用程序-特定 权限设置未将 COM 服务器应用程序(CLSID 为
{BA126AD1-2166-11D1-B1D0-00805FC1270E}
)的 本地 激活 权限授予用户 NT AUTHORITY\NETWORK SERVICE SID (S-1-5-20)。可以使用组件服务管理工具修改此安全权限。
根据提示信息,实际上是说NETWORK SERVICE没权限激活CLSID为{BA126AD1-2166-11D1-B1D0-00805FC1270E}的应用程序。可以通过使用组件服务管理工具修改此安全权限。
在注册表中查找出{BA126AD1-2166-11D1-B1D0-00805FC1270E}对应的AppID值{27AF75ED-20D9-11D1-B1CE-00805FC1270E}
3、然后再打开组件服务,查看方式为详细信息,找到DCOM 配置里的netman,选中按鼠标右建选属性。
4、在netman属性里的安全 -> “启动和激活权限” -> 自定义编辑,在启动权限里加入NETWORK SERVICE用户,允许本地启动和本地激活,确定后就不会再报这个DCOM错了 
需要重启生效。
然后根据日志的其它错误提示,将出现的几个DLL文件权限修改了一下,重启系统后正常了。
发表评论