ホームページ バックエンド開発 PHPチュートリアル PHP画像アップロード500内部サーバーエラーエラー

PHP画像アップロード500内部サーバーエラーエラー

Jun 20, 2016 pm 12:53 PM

単純に画像をアップロードするために PHP を作成したところ、200k の画像をアップロードするときに内部サーバー エラーが発生したことがわかりました。upload_max_filesize、その他の post_max_size、max_input_time、memory_limit、max_execution_time の設定項目を確認しましたが、問題はありませんでした。ログ: mod_fcgid: HTTP リクエストの長さ 138296 (これまでのところ) MaxRequestLen (131072) を超えており、問題が見つかりました。

fastcgi モードの設定の問題であることが判明しました。HTTP リクエスト長 (138296) が長すぎて、既存の最大リクエスト長 131072 を超えていたためと思われます。 fcgid 構成ファイルを確認したところ、MaxRequestLen パラメーターが構成されていないことがわかりました。 131072の設定がデフォルトのようです。そこで、この設定を fcgid 設定ファイルに追加しました。 15728640 は 15M です。php.ini に設定されている最大 POST 長は 15M なので、同じ長さに設定しました: MaxRequestLen 15728640

MaxRequestLen 15728640

AddHandler fcgid-script .fcgi .php

# php.ini ファイルはどこで探しますか?

FcgidInitialEnv PHPRC ”e:/wamp/bin/apache/apache2.3.14 / bin”

# PHP_FCGI_MAX_REQUESTS を FcgidMaxRequestsPerProcess

# すべてのリクエストが完了する前に php-cgi プロセスが終了しないように設定します

FcgidInitialEnv PHP _FCGI_MAX_REQUESTS 1000

#プロセスが終了するまでに処理する必要があるリクエストの最大数

FcgidMaxRequestsPerProcess 1000

#PHP プロセスの最大数

FcgidMaxProcess es 15

# php-cgi プロセスが終了するまでのアイドル時間の秒数

FcgidIOTimeout 120

#php-cgi へのパス

FcgidWrapper 「e:/wamp/bin/php」 /php5.4/php-cgi.exe” .php

# ”.php” フ​​ァイルの MIME タイプを定義します

AddType application/x-httpd The "

MaxRequestLen" -php .php

は、fastcgi モードでファイルをアップロードするときに http によって受け入れられる最大ファイル長です。 問題は解決しました

注:

PHP のデフォルトのアップロード制限は最大 2M です。この設定を超えるファイルをアップロードする場合は、 PHP、Apacheの一部パラメータなどを調整します。以下に、PHP ファイルのアップロードに関連するいくつかのパラメーターを簡単に紹介します。

file_uploads

: HTTP を介したファイルのアップロードを許可するかどうかを切り替えます。デフォルトは ON です。

upload_tmp_dir

:upload_tmp_dir は、PHP によってアップロードされたファイルが配置される一時ディレクトリを記述するために使用されます。ファイルをアップロードする場合は、サーバーが一時ファイルを閉じていないことを確認する必要があります。フォルダーへの書き込み権限があります。指定されていない場合、PHP はシステムのデフォルトを使用します。

upload_max_filesize

: アップロードできる最大ファイル サイズ。デフォルトは 2M です。

post_max_size

: POST メソッドを使用したフォーム送信中に PHP が受信できるデータの最大量を制御します。 PHPファイルアップロード機能を使用する場合は、この値をupload_max_filesizeより大きく変更する必要があります。

max_input_time

: POST、GET、および PUT メソッドを介してデータを受信する時間を秒単位で制限します。アプリケーションが低速リンクで実行されている場合は、データの受信に必要な追加時間に対応するために、この値を増やす必要がある場合があります。

memory_limit

: スクリプトの実行によってシステムで使用可能な大量のメモリが使用されるのを避けるために、PHP ではメモリ使用量の制限を定義できます。単一のスクリプトが使用できる最大メモリ容量を指定するには、memory_limit 変数を使用します。memory_limit 変数の値は、post_max_size の値よりも適切に大きくする必要があります。

max_execution_time

: max_execution_time は、スクリプトを強制終了する前に PHP がスクリプトの完了を待機する時間を設定します。この時間は秒単位で計算されます。この変数は、スクリプトが無限ループに入った場合に役立ちます。ただし、完了までに時間がかかる正当なアクティビティ (大きなファイルのアップロードなど) がある場合、この機能により操作が失敗する可能性もあります。このような場合、重要なプロセスの実行中に PHP がスクリプトをシャットダウンしないように、この変数の値を増やすことを検討する必要があります。

Linux ホストの場合、/etc/httpd/conf.d/access.conf/ に php.conf ファイルがある可能性があり、このファイルにより、一部のシステムのファイル サイズ制限の問題が解決される可能性があります。


このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 Apr 05, 2025 am 12:04 AM

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

PHPにおける後期静的結合の概念を説明します。 PHPにおける後期静的結合の概念を説明します。 Mar 21, 2025 pm 01:33 PM

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

フレームワークセキュリティ機能:脆弱性から保護します。 フレームワークセキュリティ機能:脆弱性から保護します。 Mar 28, 2025 pm 05:11 PM

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。

フレームワークのカスタマイズ/拡張:カスタム機能を追加する方法。 フレームワークのカスタマイズ/拡張:カスタム機能を追加する方法。 Mar 28, 2025 pm 05:12 PM

この記事では、フレームワークにカスタム機能を追加し、アーキテクチャの理解、拡張ポイントの識別、統合とデバッグのベストプラクティスに焦点を当てています。

PHPのCurlライブラリを使用してJSONデータを含むPOSTリクエストを送信する方法は? PHPのCurlライブラリを使用してJSONデータを含むPOSTリクエストを送信する方法は? Apr 01, 2025 pm 03:12 PM

PHP開発でPHPのCurlライブラリを使用してJSONデータを送信すると、外部APIと対話する必要があることがよくあります。一般的な方法の1つは、Curlライブラリを使用して投稿を送信することです。

確固たる原則と、それらがPHP開発にどのように適用されるかを説明してください。 確固たる原則と、それらがPHP開発にどのように適用されるかを説明してください。 Apr 03, 2025 am 12:04 AM

PHP開発における固体原理の適用には、次のものが含まれます。1。単一責任原則(SRP):各クラスは1つの機能のみを担当します。 2。オープンおよびクローズ原理(OCP):変更は、変更ではなく拡張によって達成されます。 3。Lischの代替原則(LSP):サブクラスは、プログラムの精度に影響を与えることなく、基本クラスを置き換えることができます。 4。インターフェイス分離原理(ISP):依存関係や未使用の方法を避けるために、細粒インターフェイスを使用します。 5。依存関係の反転原理(DIP):高レベルのモジュールと低レベルのモジュールは抽象化に依存し、依存関係噴射を通じて実装されます。

セッションのハイジャックはどのように機能し、どのようにPHPでそれを軽減できますか? セッションのハイジャックはどのように機能し、どのようにPHPでそれを軽減できますか? Apr 06, 2025 am 12:02 AM

セッションハイジャックは、次の手順で達成できます。1。セッションIDを取得します。2。セッションIDを使用します。3。セッションをアクティブに保ちます。 PHPでのセッションハイジャックを防ぐための方法には次のものが含まれます。1。セッション_regenerate_id()関数を使用して、セッションIDを再生します。2。データベースを介してストアセッションデータを3。

See all articles