php pear.phpの問題

WBOY
リリース: 2016-06-23 13:28:46
オリジナル
1043 人が閲覧しました

私のマシンで Pear.php を調整しましたが、アクセスすると、このファイル /usr/local/php/lib/php/PEAR.php が存在するというメッセージが表示されます。nginx +php-fpm 環境を使用しています。 、オンライン php.ini で
open_basedir ="./:/usr/local/php/lib/php/" を設定すると言われています
これはまだ機能しません
PHP バージョン 5.4.41
以下はエラーレポートです,


2015/08/ 12 16:05:14 [エラー] 4786#0: *5 FastCGI が標準エラー出力で送信されました: "PHP メッセージ: PHP 警告: require_once(): open_basedir 制限が有効です。File(/usr/local /php/lib/php/PEAR .php) は許可されたパス内にありません: (/home/wwwroot/editor.com/Mail の (/home/wwwroot/editor.com:/tmp/:/proc/)) .php (46 行目)
PHP メッセージ : PHP 警告: require_once(/usr/local/php/lib/php/PEAR.php): ストリームを開けませんでした: /home/wwwroot/editor.com/Mail では操作が許可されていません。 php 46 行目
PHP メッセージ: PHP 致命的エラー: require_once(): /home/wwwroot/editor 内の必須 'PEAR.php' (include_path='.:/usr/local/php/lib/php') を開けませんでした。 com/Mail.php の 46 行目「上流から応答ヘッダーを読み取っている間、クライアント: 1


ディスカッションに返信 (解決策)

open_basedir の値を見てください
open_basedir が空でない場合、php はアクセスのみ可能ですopen_basedirで指定されたディレクトリ

phpinfo() このファイルを確認してください
ロードされた設定ファイル /usr/local/php/etc/php.ini
php.ini の値を確認してください
--------------- -------------------------------------------------- - -------------
; open_basedir を設定すると、すべてのファイル操作が定義されたディレクトリ
以下に制限されます。 - virtualhost Web サーバー設定ファイル
; http://php.net/open-basedi
open_basedir ="./:/usr/local" は影響を受けません。 / php/lib/php/"#これは私が設定したものです
---------------------------------- - ------------------------------------------------- - -------
[root@localhost ~]# ll /usr/local/php/lib/php/
合計 84
drwxr-xr-x 2 root root 20 8 月 12 日 14:41 アーカイブ
drwxr- xr -x 2 root root 4096 Jun 12 16:22 build
drwxr-xr-x 2 root root 23 Aug 12 14:41 Console
drwxr-xr-x 5 root root 60 Aug 12 15:16 data
drwx r-xr- x 9 ルート root 124 8 月 12 日 15:16 doc
drwxr-xr-x 3 ルート root 38 6 月 12 日 16:29 拡張機能
drwxr-xr-x 2 ルート root 6 8 月 12 日 14:34 htdocs
drwx r-xr-x 3 ルート root 40 8 月 12 日 15:16 HTTP
drwxr-xr-x 2 ルート root 21 8 月 12 日 15:16 ネット
drwxr-xr-x 2 ルート root 22 8 月 12 日 14:41 OS
drwxr-xr-x 11 root root 4096 8月12日14:41 PEAR
-rw-r--r-- 1ルート root 15188 8月12日14:41 pearcmd.php
-rw-r--r-- 1ルート root 34864 8月12日14:41 PEAR php
-rw-r--r-- 1 ルート root 1033 8 月 12 日 14:41 peclcmd.php
drwxr-xr-x 3 ルート root 38 8 月 12 日 15:16 サービス
drwxr-xr-x 3 ルート root 34 8月12日 14:41 構造体
-rw-r--r-- 1 ルート root 20292 8月12日 14:41 System.php
drwxr-xr-x 9 ルート root 139 8月12日 15:16 テスト
drwxr-xr-x 3 ルート root 48 8 月 12 日 15:16 テキスト
drwxr-xr-x 2 ルート root 21 8 月 12 日 14:41 XML
----------------------- --- --------------------------------------------------- --- -------------
ディレクトリの下にファイル PEAR.php があります
---------------------- ---------------------------------------------------- ------- ---------
しかし、Nginx は次のエラーを報告しました
------------------------ ------ -------------------------------------------- ------ ----
2015/08/13 09:51:38 [エラー] 635#0: *17 FastCGI が標準エラー出力で送信されました: "PHP メッセージ: PHP 警告: require_once(): open_basedir 制限が有効ですファイル (/usr/local/php/lib/php/PEAR.php) が許可されたパス内にありません: (/home/wwwroot/editor.com:/tmp/:/proc/) /home/ wwwroot/editor.com/ Mail.php の 46 行目
PHP メッセージ: PHP 警告: require_once(/usr/local/php/lib/php/PEAR.php): ストリームを開けませんでした: /home/wwwroot では操作は許可されていません/editor.com/Mail .php 46 行目
PHP メッセージ: PHP 致命的エラー: require_once(): 必要な 'PEAR.php' (include_path='.:/usr/local/php/lib/php') を開くことができませんでした46 行目の /home/wwwroot/editor .com/Mail.php 上流からの応答ヘッダーの読み取り中、クライアント: 127.0.0.1、
-------------------------------------------------- -------------------------------------------------- -----------------------------
モデレーター、これの何が問題ですか?

open_basedir を設定しないでください

;open_basedir = " ./ :/usr/local/php/lib/php/"#これは私が自分で設定したものです

include_pathにpearのパスを追加する必要があります

モデレーターの指示に従ってください

———————— ————————— ----------------- ;open_basedir ="./:/usr/local/php/lib/php/" #I開いてみたけどダメでした
--------------------------------------------------- --------------
2015/08/13 10:18:20 [エラー] 4110#0: *1 FastCGI が標準エラー出力で送信されました: "PHP メッセージ: PHP 警告: require_once(): open_basedir 制限が有効です。ファイル (/usr/local/php/lib/php/PEAR.php) が許可されたパス内にありません: (/home/wwwroot /editor.com:/tmp/:/proc/) /home/wwwroot/editor.com/Mail.php の 46 行目
PHP メッセージ: PHP 警告: require_once(/usr/local/php/lib/php/PEAR .php): ストリームを開けませんでした: 操作は許可されていません/home/wwwroot/editor.com/Mail.php 46 行目
PHP メッセージ: PHP 致命的エラー: require_once(): 必要な 'PEAR.php' を開くことができませんでした (include_path ='.:/php/includes:/usr/local) /php/lib/php/') /home/wwwroot/editor.com/Mail.php の 46 行目」上流から応答ヘッダーを読み取り中、クライアント: 127.0. 0.1、サーバー: editor.com、リクエスト: "POST / appBaseInfoSaver.php HTTP/1.1"、アップストリーム: "fastcgi://unix:/tmp/php-cgi.sock:"、ホスト: "editor.com"、リファラー: "http://editor.com/appBaseInfo.php ?t=new&tplt=capricorn"


モデレーターこんにちは、ここで問題を解決しました
最後に、これを nginx に追加しました
fastcgi_param PHP_VALUE open_basedir= "open_basedir=$document_root:/usr/local/php/lib/php/:/ tmp/:/home/wwwroot/";

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート