php調用python失敗怎么辦?
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模塊時可能出現兩個錯誤:
<span style="font-family:Arial, Helvetica, sans-serif;">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</span> <span style="font-family:Arial, Helvetica, sans-serif;">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)</span>
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_-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_-linux-gnu/libcrypto.so.1.0.0 /opt/lampp/lib/libcryto.so.1.1
libssl.so.1.0.0解決步驟同上。
更多PHP相關知識,請訪問PHP教程!
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com