前段时间重装了系统,后来讲是又要用php,就从新搭建了apache+php+mysql的环境,因为以前搭建过好屡次,感受很easy,很快就搭建完成,而后写了下面的经常使用的测试环境的代码:php
1 <?php 2 3 phpinfo(); 4 5 ?>
而后正常输出,感受环境没问题,就没管了……mysql
最近要用了,运行之前的项目代码(使用了CI框架)却一直显示空白页面,得不到任何正确输出。sql
囧了……数据库
本身从新写简单的php语句都能正常运行,看来环境是没问题的。apache
直到,使用了date()函数,才发现了一丝端倪。服务器
Warning: date(): It is not safe to rely on the system's timezone settings. You are *required* to use the date.timezone setting or the date_default_timezone_set() function. In case you used any of those methods and you are still getting this warning, you most likely misspelled the timezone identifier. We selected the timezone 'UTC' for now, but please set date.timezone to select your timezone.框架
可是,我明明已然在php.ini文件中配置了 date.timezone = Asia/Shanghai ide
好吧,php.ini文件中配置的信息没有生效函数
最早想到的是服务器读取的不是这个php.ini配置文件,由于之前遇到过wamp没有删除,而后本身从新配置环境,系统内存在不止一个php.ini文件,读取的是历史的配置文件。测试
查找系统文件,只有一个php.ini文件,并且重装了系统,即使以往有如今也没了。
再次查看phpinfo();
读取的确实是我如今配置的php.ini
那么问题就多是php.ini文件有问题没有被正确解析了。
我试着使用php代码链接下数据库,发现找不到相关的函数……
看来php.ini确实存在问题。
仔细检查本身修改过的配置,没有什么问题……
再检查一遍,仍是没有问题……
……
……
而后,到天天散步的点了,决定不弄了,实在不行全都删了,从新搭建环境,关了电脑,下楼散步,而后打个电话吐槽今天的“幸福”生活……
散步回来以后,不甘心,仍是要弄明白,否则睡不着……
而后,不死心的最后一次检查了php.ini,终于让我捉到这个bug了
配置扩展所在目录时,漏写了半边引号,致使后面的解析都出现了问题,因此配置时区,访问数据库都没能正确进行。
添加上半边引号,重启apache服务,OK了,一切又都运行得那么美好
总结:粗枝大叶要不得……