Apache正在记录日志PHP Fatal error: Call to undefined function json_decode()
。经过一番谷歌搜索,似乎这个问题是由于没有最新版本的php导致的。奇怪的是,运行php --version
输出
PHP 5.5.1-2+debphp.org~precise+2 (cli) (built: Aug 6 2013 10:49:43)
Copyright (c) 1997-2013 The PHP Group
Zend Engine v2.5.0, Copyright (c) 1998-2013 Zend Technologies
with Zend OPcache v7.0.2-dev, Copyright (c) 1999-2013, by Zend Technologies
with Xdebug v2.2.3, Copyright (c) 2002-2013, by Derick Rethans
清楚表明我的php
版本大于5.1
。
关于什么可能导致这种情况的任何想法,或者要采取哪些措施找出答案?
编辑:脚本回显phpversion的结果是 5.5.1-2+debphp.org~precise
编辑:的结果phpinfo()
也是PHP Version 5.5.1-2+debphp.org~precise+2
此外,在中phpinfo()
,它列出了模块JSON和模块作者(Omar Kilani,Scott MacVicar)。
简短答案:
sudo apt-get install php7.2-json
(或php7.1-json
或 php5-json
取决于你正在运行的PHP版本)
然后当然 要确保重新启动Apache :
sudo service apache2 restart
或者,如果您使用的是PHP-FPM:
sudo service php7.2-fpm restart
(或php7.1-fpm
或php5-fpm
)
由于许可证冲突,Debian从PHP 5.5rc2开始删除了先前的JSON扩展。
该JSON许可证具有规定的条款:
该软件应用于善良,而非邪恶。
这导致自由软件基金会对自由软件的定义出现问题,该定义指出:
出于任何目的运行程序的自由度(自由度0)。
FSF继续专门列出了JSON许可证为nonfree。
是的,这似乎有点愚蠢。尽管如此,Debian删除了不兼容的JSON扩展,而是提供了功能上等效的替代扩展。
需要明确的是:PHP本身尚未删除JSON,但仍在master中。这是发行版/程序包管理器问题。
Rasmus明确指出:
我们没有删除json,并且如果没有内置的json支持,我们将永远不会发布php版本。5.5中的任何更改都归因于您使用的任何发行版打包,而我们对此无法控制。
http://iteration99.com/2013/php-json-licensing-and-
php-5-5/
http://liorkaplan.wordpress.com/2013/06/01/bye-bye-non-free-php-json-
extension/
https://bugs.php.net/bug.php?id=63520
http://philsturgeon.co.uk/blog/2013/08/fud-cracker-php-55-never-lost-json-
support
问题内容: 我不断收到错误PHP致命错误:调用未定义函数mysqli_stmt_get_result()。我正在使用PHP版本5.6,并在主机提供商c面板中启用了扩展mysqlind,但我不知道为什么仍然出现此错误。我进行了研究,发现每次需要启用mysqli nd才能使用mysqli_stmt_get_result。任何人都可以协助/教导我在做什么错。谢谢。 SIGNUP.PHP: 问题答案: 您
Apache正在记录。在谷歌搜索之后,这个问题似乎是由于没有最新版本的php造成的。奇怪的是,运行outputs 清楚地显示我的版本大于。 关于是什么导致了这种情况,或者应该采取什么措施来找出原因? 编辑:脚本回显phpversion的结果是 编辑:的结果也是 此外,在中,它列出了模块JSON和模块作者(Omar Kilani,Scott MacVicar)。
问题内容: 当我尝试将旧的sql切换到sqli时,有人可以告诉我为什么这不起作用: 至: 它一直给我一个错误:“致命错误:调用未定义函数mysqli_result()” 问题答案: 不要使用这种代码。这是非常低效的。使用来代替: 一个SINGLE数据库操作,而不是您尝试执行的3个以上操作。
问题内容: 我正在尝试连接到安装了PostgreSQL的数据库(远程服务器)。我的PHP代码正在尝试使用pg_connect()连接到数据库,但出现错误消息:-“致命错误:在第82行的/var/www/website/functions.php中调用未定义的函数pg_connect()”。 82行只是: (所有先前定义的变量) 我检查了很多论坛,建议的唯一解决方案是找到包含一行的php.ini文件
问题内容: 我的代码是这样的: 当我运行通过Web套接字创建连接的php文件时,出现致命错误:调用if(($ this-> master = socket_create(AF_INET,SOCK_STREAM,SOL_TCP))<0)行中的未定义函数socket_create() 因此,我无法连接Web套接字,也无法从套接字获取响应消息,因为在运行客户端页面时,浏览器中显示的是套接字状态:3(关闭
问题内容: 我正在尝试通过本地主机访问我的Gmail帐户。但是,我得到的答复: 致命错误:调用未定义的函数imap_open() 这是我的代码: 问题答案: 很简单,在您的PHP安装中未激活IMAP扩展。默认情况下未启用它。如果本地安装在Windows上运行XAMPP,则必须按照XAMPP FAQ 中的说明启用它: IMAP对PHP的支持在哪里? 默认情况下,由于一些家庭版本(例如Windows