CentOS 6 (64 ビット) + Nginx で静的ファイルサーバーを構築
Nginx は静的ファイル サーバーを構築します
次のコマンドを使用して Nginx 構成ファイルを開きます:
sudo vim /etc/nginx/conf.d /default.conf
設定を次のように変更します:
server { ...... ...... # 下面的东西是需要自行添加的配置 location ~ \.(png|gif|jpg|jpeg)$ { root /usr/share/nginx/images; #这个将替换`server->root`配置 # expires 1d; index default.jpg; } # 上面就是需要添加的东西了 # 对于满足以 .png/.gif/.jpg 结尾的url请求, # 将其根目录定义为 /usr/share/nginx/images # 文件的有效期为一天(如果需要可以取消注释) ...... ......}
設定後、コマンドを渡します:
sudo service nginx restart Nginxを再起動すると有効になります。
起動に失敗した場合は、次のコマンドを使用します:
nginx -t
エラー メッセージを表示します
Nginx セットアップ PHP 実行環境
PHP 実行環境は php-fpm パッケージをインストールできます:
sudo yum install php-fpm
コマンドを実行します対応する構成ファイルを開きます:
sudo vim /etc/nginx/conf.d/default.conf
server_name を次のように変更します:
server_name localhost;
最初のデフォルトのロケールを次のように変更します:
location / { try_files $uri $uri=404;}
404 を次のように変更します:
error_page 404 /404.html;
コマンドを実行します:
vim /etc/php-fpm.d/www.conf
リッスンコンテンツを見つけて記憶します (次の 127.0.0.1:9000 は私のローカル設定です):
listen = 127.0.0.1:9000
Nginx 設定ファイル内の PHP 設定を削除し、次のように変更します:
# 同样是在server的区块里location ~ \.php$ { try_files $uri = 404; fastcgi_pass 127.0.0.1:9000; # 就是上面查找到的127.0.0.1:9000这个内容 fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params;}
私たちについて学ぶ 設定は正しいです。
PHP を使用してファイルをアップロードします
「php.ini」ファイルを構成します
sudo vim /etc/php.ini
場合php.ini ファイルの場所がわからない場合は、次のコマンドを実行してください:
php -i grep "Loaded Configuration File"
Settings:
file_uploads = On
PHP サービスを再起動します:
sudo service php-fpm restart
in / usr/share/nginx HTML フォームの作成 update.php:
<!DOCTYPE html><html><body><form action="upload.php" method="post" enctype="multipart/form-data"> Select image to upload: <input type="file" name="fileToUpload" id="fileToUpload"> <input type="submit" value="Upload Image" name="submit"></form></body></html>
注:
- フォームのメソッドが post であることを確認してください
- enctype はマルチパートです/form-data ファイルを受信できることを確認します
アップロードされた PHP スクリプトを作成します
<?php $target_dir = "images/"; $target_file = $target_dir . basename($_FILES["fileToUpload"]["name"]); $uploadOk = 1; $imageFileType = pathinfo($target_file,PATHINFO_EXTENSION); // Check if image file is a actual image or fake image if(isset($_POST["submit"])) { $check = getimagesize($_FILES["fileToUpload"]["tmp_name"]); if($check !== false) { echo "File is an image - " . $check["mime"] . "."; $uploadOk = 1; } else { echo "File is not an image."; $uploadOk = 0; } }?>
説明:
- $target_dir = "images /" はファイルが保存されているディレクトリを示します
- $target_file はファイルをアップロードするパスを示します
- $uploadOk=1 はまだ使用されていません
- $imageFileType には拡張子が含まれていますファイルの
- ファイルが画像であるかどうかを判断します
ファイルが既に存在するかどうかを確認します
// Check if file already existsif (file_exists($target_file)) { echo "Sorry, file already exists."; $uploadOk = 0;}
ファイルサイズを制限します
// Check file sizeif ($_FILES["fileToUpload"]["size"] > 500000) { echo "Sorry, your file is too large."; $uploadOk = 0;}
制限ファイルタイプ
// Allow certain file formatsif($imageFileType != "jpg" && $imageFileType != "png" && $imageFileType != "jpeg"&& $imageFileType != "gif" ) { echo "Sorry, only JPG, JPEG, PNG & GIF files are allowed."; $uploadOk = 0;}
完全なコード
500000) { echo "Sorry, your file is too large."; $uploadOk = 0;}// Allow certain file formatsif($imageFileType != "jpg" && $imageFileType != "png" && $imageFileType != "jpeg"&& $imageFileType != "gif" ) { echo "Sorry, only JPG, JPEG, PNG & GIF files are allowed."; $uploadOk = 0;}// Check if $uploadOk is set to 0 by an errorif ($uploadOk == 0) { echo "Sorry, your file was not uploaded.";// if everything is ok, try to upload file} else { if (move_uploaded_file($_FILES["fileToUpload"]["tmp_name"], $target_file)) { echo "The file ". basename( $_FILES["fileToUpload"]["name"]). " has been uploaded."; } else { echo "Sorry, there was an error uploading your file."; }}?>
php が 500 Server 内部エラーを報告した場合はどうすればよいですか?
対応する PHP ファイルに追加します:
ini_set('display_errors', 1);
.htaccess ファイル内 ( Ifそのようなファイルはありません。空のファイルを手動で作成してください) 追加:
php_flag display_errors 1
php report move_uploaded_file が発生したとき: ストリームを開けませんでした: 権限/usr/share/nginx/images で何をすればよいですか?
対応する PHP ファイルに追加します:
echo exec('whoami');
たとえば、出力は次のようになります。 🎜 >
www-data
次のステートメントを実行してアクセス許可を付与します (ステートメント内の www-data は whoami の出力値に対応する必要があります):
sudo chown www-data /usr/share/nginx/imagessudo chmod 0755 /usr/share/nginx/images
【参考記事】 https://www.digitalocean.com/community /tutorials/how-to-install-linux-nginx-mysql-php-lemp-stack-on-centos-7

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

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

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

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