質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.10%

nginxを起動後ブラウザ上で403 forbidden

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 23K+

tixure55

score 356

http {
  server {      
    listen      8001 default;
    server_name  localhost;
    root /var/www/ruby;

    location /var/www/ruby {
      autoindex on;
      if (!-e $request_filename) {
        rewrite ^/(.+)#  /index.php?q=$1 last;
        break;
      }
    }
    location ~ \.php$ {
      fastcgi_pass 127.0.0.1:9000;
      fastcgi_param SCRIPT_FILENAME /var/www/wordpress$fastcgi_script_name;
      fastcgi_param PATH_INFO $fastcgi_script_name;
      include fastcgi_params;
    }
  }


  include       /etc/nginx/mime.types;
  default_type  application/octet-stream;

  log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    '$status $body_bytes_sent "$http_referer" '
    '"$http_user_agent" "$http_x_forwarded_for"';
  access_log  /var/log/nginx/access.log  main;
  sendfile        on;
#tcp_nopush     on;  
  keepalive_timeout  65;

#gzip  on;
}

上記nginx.confです。(便宜上PHPとしています。)rootのディレクトリのパーミッションは755になっているのですが、ブラウザ上で403 Forbidden nginx/1.8.0と表示されてしまいます。

パーミッション以外の設定を見直す必要があるのでしょうか?

追記: 回答ありがとうございます。

下記confでも同一状態になるので、locationディレクティブが原因ではないようです。

user  nginx;
worker_processes  1;  

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
  worker_connections  1024;
}


http {
  server {
    listen      8001;
    server_name  localhost;
    root /var/www/ruby;
  }


  include       /etc/nginx/mime.types;
  default_type  application/octet-stream;

  log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    '$status $body_bytes_sent "$http_referer" '
    '"$http_user_agent" "$http_x_forwarded_for"';
  access_log  /var/log/nginx/access.log  main;
  sendfile        on;
#tcp_nopush     on; 
  keepalive_timeout  65; 

#gzip  on; 
}

/var/log/nginx/error.log ↓

2015/12/09 19:36:12 [error] 9643#0: *1 directory index of "/var/www/ruby/" is forbidden, client: 127.0.0.1, server: localhost, request: "GET / HTTP/1.1", host: "localhost:8001"
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

0

存在しないURI/URLにアクセスされた場合 index.phpにそのPATH/FILE名を渡したいということでしょうか。 アクセス権限の他、当該プログラムが動作していない場合にも403となります。 上記のconfigが便宜上ということで、本当のものでないとすると、回答が困難です・・・

このサイトのような振り分けをされたいということでしょうか。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/12/09 19:57

    nginx.confは他の方の書いたブログを参照しただけなので、よくわかっておりません。おっしゃっている当該プログラムとはなんでしょうか?
    提示いただいたサイトのように振り分けたいわけではなく、とりあえずforbiddenにならないようにブラウザ上に表示させたいだけです。

    キャンセル

  • 2015/12/09 23:41 編集

    設定に php やら rubyやら location が登場しているが為に、目的を誤認してしまったようです。普通にnginxで htmlなコンテンツが表示される事を期待されているということで進めます。
    OSがわかりませんので、ubuntuを例にします。

    /etc/nginx/nginx.conf を以下のようにしてください。
    ----
    user www-data;
    worker_processes 1;
    pid /run/nginx.pid;
    events {
    worker_connections 768;
    }
    http {
    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;
    keepalive_timeout 65;
    types_hash_max_size 2048;
    include /etc/nginx/mime.types;
    default_type application/octet-stream;
    ssl_prefer_server_ciphers on;
    access_log /var/log/nginx/access.log;
    error_log /var/log/nginx/error.log;
    gzip on;
    gzip_disable "msie6";
    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;
    }
    ---

    /etc/nginx/sites-enabled/default を以下のように作成してください。
    ---
    server {
    listen 80 default_server;
    root /usr/share/nginx/html;
    index index.html index.htm;
    server_name localhost;
    }
    ---

    いづれのディレクトリにおいてもnginxからのアクセスおよび、ログやpidにおいては、書き込み権限が有る事を確認してください。
    nginxの起動ユーザを www-data としています。(ubuntu標準)

    /run/nginx.pid が作成できるか確認してください。
    /etc/nginx/mime.types はnginxのパッケージについているものをそのまま置いてください。
    /var/log/nginx/access.logにアクセスログが出力されます。ディレクトリが有る事を確認してください。ディレクトリがなければ作成してください。
    /var/log/nginx/error.logにエラーログが出力されます。
    /usr/share/nginx/html/ 以下に index.html を設置してください。ディレクトリがなければ作ってください。
    index.htmlの中身は何でもOKです。
    ----
    <html><body>TEST</body></html>
    ---
    こんな感じ


    /etc/init.d/nginx restart で再起動してください。

    ブラウザ等で、

    http://サーバのIPアドレス/

    で、index.htmlが表示されることを確認してください。

    キャンセル

  • 2015/12/11 12:10

    回答ありがとうございます、おっしゃるとおり、ファイルを書き換えたところ、welcomeページが表示されました。ありがとうございました。

    キャンセル

0

location にはディレクトリではなく URL のパスを設定するのではないでしょうか。

location /var/www/ruby → location /

あと、rewrite の正規表現の「#」は「$」の Typo でしょうか。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/12/09 19:45

    回答ありがとうございます、正規表現やlocationの記述は他の方のブログから抽出したものなのでよくわかりません。
    やりたいことはこのforbiddenのエラーを消したいのですが、ディレクトリのパーミッション以外に疑うところはありますでしょうか?

    キャンセル

  • 2015/12/09 21:21

    URL「http://サーバー名/foo」でアクセスすると、nginx にはパス「/foo」にマッチする
    location が無いので "403 Forbidden" になるのだと思います。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.10%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る