php运行python脚本失败怎么解决

假设有文件:php_test.php python_test.py

在php文件中运行Python:

复制代码
exec("python python_test.py", $array, $ret);

如果运行Python出错并不能保存在数组array中,因此应该把标准错误重定向到文件中,以上代码改写如下:

复制代码
exec("python python_test.py 2>error.txt", $array, $ret);

在bash中0,1,2三个数字分代表STDIN_FILENO、STDOUT_FILENO、STDERR_FILENO,即标准输入(一般是键盘),标准输出(一般是显示屏,准确的说是用户终端控制台),标准错误(出错信息输出)。也可以通过以下方式将标准错误重定向到标准输出保存到$array中:

复制代码
exec("python python_test.py 2>error.txt 2>&1", $array, $ret);

然后就可以根据错误信息去寻求解决办法。

一般在终端通过命令运行PHP文件是可以马上看到错误信息的,但是通过浏览器运行PHP文件就只能上面所述方法去输出错误信息。因此问题也就是在命令行下PHP可以成功执行Python文件,而通过浏览器就不能成功运行,这是因为两种方式所调用的动态库不一致!通过命令行方式调用的是系统中的已有的动态库,而通过浏览器方式调用的是Web服务器中的动态库。(我安装的XAMPP,所以通过浏览器方式调用的就是lampp/lib中的动态库)。

解决办法:

1、在输出的错误信息中找到出错的动态库。

2、通过locate命令找到相关的动态库所在的位置:locate libxxx.so

3、将web服务器中的同名动态库删除或重命名。

4、将通过第2步在系统中找到的动态库链接到web服务器的lib目录中。

实例:

Python中使用hashlib模块时可能出现两个错误:

复制代码
relocation error: python: symbol OpenSSL_add_all_digests, version OPENSSL_1.0.0 not defined in file 
libcrypto.so.1.0.0
with link time reference

python: /opt/lampp/lib/libcrypto.so.1.0.0: version `OPENSSL_1.0.2' not found (required by /opt/lampp/lib/libssl.so.1.0.0)

1.找出系统中包含libcrypto.so.1.0.0的所有路径:locate libcryto.so.1.1

复制代码
/home/ubuntu/.cache/vmware/drag_and_drop/52091a33-81b7-cc30-d88c-574c47558e32/ndk/libimobiledevice-android-master/
openssl/libcrypto.so.1.0.0
/home/ubuntu/.cache/vmware/drag_and_drop/52091a33-81b7-cc30-d88c-574c47558e32/ndk/libimobiledevice-android-master/
out/fsroot/lib/libcrypto.so.1.0.0
/lib/x86_64-linux-gnu/libcrypto.so.1.0.0
/opt/lampp/lib/libcrypto.so.1.0.0

2.将web服务器中的同名动态库重命名:sudo mv /opt/lampp/lib/libcryto.so.1.1 /opt/lampp/lib/libcryto.so.1.1.bak

3.将系统中libcryto.so.1.1链接到web服务器的lib目录中:sudo ln -s /lib/x86_64-linux-gnu/libcrypto.so.1.0.0 /opt/lampp/lib/libcryto.so.1.1

libssl.so.1.0.0解决步骤同上。

相关推荐
冬奇Lab2 小时前
PowerManagerService(下):Doze模式与电池优化
android·源码阅读
砖厂小工3 小时前
Compose 中函数引用 vs Lambda:到底该用哪个?
android
用户8356290780515 小时前
使用 C# 在 Excel 中创建数据透视表
后端·python
码路飞7 小时前
FastMCP 实战:一个 .py 文件,给 Claude Code 装上 3 个超实用工具
python·ai编程·mcp
dev派9 小时前
AI Agent 系统中的常用 Workflow 模式(2) Evaluator-Optimizer模式
python·langchain
前端付豪11 小时前
AI 数学辅导老师项目构想和初始化
前端·后端·python
用户03321266636711 小时前
将 PDF 文档转换为图片【Python 教程】
python
悟空爬虫13 小时前
UV实战教程,我啥要从Anaconda切换到uv来管理包?
python
dev派13 小时前
AI Agent 系统中的常用 Workflow 模式(1)
python·langchain
Kapaseker14 小时前
详解 Compose background 的重组陷阱
android·kotlin