zoukankan      html  css  js  c++  java
  • 我的PHP5 + Apache2.2 + MySql5.1配置经历

    昨天突然又想弄点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_Dir\conf目录下的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稍等修改即可。最后只总结出四个字:路径问题。

  • 相关阅读:
    非常优秀的iphone学习文章总结!
    转载:开源一款酷跑游戏源码完整版
    Faiss学习:一
    揭开Faiss的面纱 探究Facebook相似性搜索工具的原理
    集成学习总结 & Stacking方法详解
    转:fastText原理及实践(达观数据王江)
    转:ubuntu 下GPU版的 tensorflow / keras的环境搭建
    转:PCA的Python实现
    2017知乎看山杯总结(多标签文本分类)
    转:TensorFlow入门(六) 双端 LSTM 实现序列标注(分词)
  • 原文地址:https://www.cnblogs.com/heiing/p/1439075.html
Copyright © 2011-2022 走看看