解决PHP在DOS命令行下却无法链接MySQL的技术笔记

 更新时间:2010年12月29日 23:49:26   作者:  
前段时间,由于要用 php 进行 Shell 编程时,碰到了 PHP 在 WEB 下可以连接 MySQL 而在 DOS COMMAND 命令行下却连接失败的问题。
正好今天朋友 xjb 也碰到了这个问题,所以写了这篇笔记,将此问题的描述以及解决记录下。
问题描述:用 web 方式, 可以链接 mysql, 但是在命令行下, 却提示:
  Fatal Error: undefined function mysql_connect()
  环境: Windows 2003, PHP 5.2.0, MYSQL 5.0, Apache 2.0
  在 php.ini 中, 已经将 php_mysql.dll 的模块选项给打开了;测试的脚本也很简单,就一个 mysql_conect 函数,内容如下:
复制代码 代码如下:

php.ini:
extension=php_mysql.dll
测试脚本 test.php 内容如下:
text.php
<?
if ( !mysql_connect(DBHOST, DBUSER,DBPWD) )
{
echo "连接失败!";
exit;
}
echo "连接成功!t";
?>

用 web 方式调用 http://localhost/test.php, 执行正常, 显示"连接成功".
  但用 dos command 命令行的方式调用 d:/php/php.exe test.php 却显示连接失败, 错误信息为: Fatal Error: undefined function mysql_connect()
  很显然, 在 dos command 命令行的环境下,mysql 的模块没有被调用。方法弄尽, 仍无法解决. 百思不得其解. 后来, 用写了个脚本, 看看 php 的配置, 在两个环境下有什么不同:
test.php
复制代码 代码如下:

<?
echo phpinfo();
?>


仔细查看两个环境下 phpinfo() 输入的 php 配置信息,终于发现了问题所在:
Web 方式 http://localhost/test.php 方式调用时, 其 Configuration File (php.ini) Path 显示为 C:WINDOWSphp.ini。
DOS COMMAND 命令行方式 d:/php/php.exe test.php 调用时, 其 Configuration File (php.ini) Path 为 d:phpphp.ini。
  而在 c:windows 和 d:php 目录下, 都存在一个 php.ini 文件,d:php 目录下的 php.ini 没有将 extension=php_mysql.dll 模块打开.于是将 d:phpphp.ini 删除,只保留 c:windowsphp.ini,问题解决.
  总结:在 windows 下安装 php 时, 为了避免配置文件混乱,将安装目录下的 php.ini 复制到 windows 目录下之后,应该将原来安装目录下的 php.ini 文件重命名或删除,以免造成在不同环境下执行时,查找配置文件不一致的情况发生。问题发生的原因一般都是非常非常简单,但查找、排除问题的过程,却是相当的烦人。

相关文章

  • php中数据格式判断方法总结

    php中数据格式判断方法总结

    这篇文章主要为大家详细介绍了php中数据格式判断方法,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-12-12
  • php常用字符串String函数实例总结【转换,替换,计算,截取,加密】

    php常用字符串String函数实例总结【转换,替换,计算,截取,加密】

    这篇文章主要介绍了php常用字符串String函数,结合实例形式总结分析了php常用字符串函数的功能与使用技巧,包括字符串的转换、替换、计算、截取、加密等各种常用操作相关函数,需要的朋友可以参考下
    2016-12-12
  • php计划任务之ignore_user_abort函数实现方法

    php计划任务之ignore_user_abort函数实现方法

    这篇文章主要介绍了php计划任务之ignore_user_abort函数实现方法,以实例形式分析了php计划任务的ignore_user_abort函数实现方法,并对ignore_user_abort函数的用法进行了较为详尽的分析说明,需要的朋友可以参考下
    2015-01-01
  • php批量删除超链接的实现方法

    php批量删除超链接的实现方法

    有时候我们会遇到这种需求,清除掉一段html文本内容中的超链接,这时有什么好办法呢?下面就总结几种简单的方法清除html文本中的超链接,需要的朋友可以参考下
    2015-10-10
  • javascript,php获取函数参数对象的代码

    javascript,php获取函数参数对象的代码

    javascript,php获取函数参数对象的代码,需要的朋友可以参考下。
    2011-02-02
  • php实现将Session写入数据库

    php实现将Session写入数据库

    这篇文章主要介绍了php实现将Session写入数据库的相关资料,需要的朋友可以参考下
    2015-07-07
  • PHP将HTML转换成文本的实现代码

    PHP将HTML转换成文本的实现代码

    这篇文章主要介绍了PHP将HTML转换成文本的实现代码,需要的朋友可以参考下
    2015-01-01
  • 一文解决PHP中生成随机数遇到的重复问题

    一文解决PHP中生成随机数遇到的重复问题

    项目开发中很多地方需要用到唯一编码,比如说订单、卡券、邀请码等等,这些编号是需要严格保证唯一性的,因为如果系统中订单的编号存在俩一模一样的,那造成很多数据的错乱,所以本文给大家介绍了如何解决PHP中生成随机数遇到的重复问,需要的朋友可以参考下
    2023-12-12
  • php获取linux命令结果的实例

    php获取linux命令结果的实例

    下面小编就为大家带来一篇php获取linux命令结果的实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03
  • 浅谈php错误提示及查错方法

    浅谈php错误提示及查错方法

    本文给大家简单总结了下php的3种错误提示和3种查错的方法,非常简单,记录一下,以后补全,有需要的小伙伴先来MARK下吧
    2015-07-07

最新评论