解決php執行python腳本失敗的方法
釋出時間:2020-09-03 10:08:25
來源:億速雲
閱讀:102
作者:小新
這篇文章將為大家詳細講解有關解決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解決步驟同上。
關於解決php執行python腳本失敗的方法就分享到這裡了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。