ホームページ >バックエンド開発 >PHPチュートリアル >CentOS 6 (64 ビット) + Nginx で静的ファイルサーバーを構築

CentOS 6 (64 ビット) + Nginx で静的ファイルサーバーを構築

WBOY
WBOYオリジナル
2016-06-20 12:34:21856ブラウズ

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

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