パッセンジャー Apache - 禁止 このリソースにアクセスする権限がありません

パッセンジャー Apache - 禁止 このリソースにアクセスする権限がありません

私は行き詰まってApacheいるPassenger。解決策を探すのに数日かかりました。私はこの指示に従います。ブラウザに次のメッセージが表示されます:

Forbidden

You don't have permission to access this resource.

confファイル

# Use /usr/bin/node by default.
PassengerNodejs /usr/bin/node

<VirtualHost *:80>

    ServerName example.com

    RewriteEngine On 
    RewriteCond %{HTTPS} off
    RewriteCond %{SERVER_NAME} =example.com
    RewriteRule ^ https://%{SERVER_NAME}%{REQUEST_URI} [END,NE,R=permanent]

</VirtualHost>

<VirtualHost *:443>

    ServerName example.com

    # Tell Apache and Passenger where your app's code directory is
        DocumentRoot /var/www/example.com
        PassengerAppRoot /var/www/example.com/

    # Tell Passenger that your app is a Node.js app
        PassengerAppType node
        PassengerStartupFile app.js

    # Relax Apache security settings
    <Directory /var/www/example.com>
        Options FollowSymLinks
        AllowOverride None
        Order allow,deny
        Allow from all
        Options -MultiViews
        # Uncomment this if you're on Apache >= 2.4:
        Require all granted
    </Directory>

    CustomLog /var/log/httpd/example.com_access.log combined
    ErrorLog /var/log/httpd/example.com_error.log

    SSLEngine on
    SSLCertificateFile    /etc/letsencrypt/live/example.com/cert.pem
    SSLCertificateKeyFile /etc/letsencrypt/live/example.com/privkey.pem
    SSLCertificateChainFile /etc/letsencrypt/live/example.com/fullchain.pem
    Include /etc/letsencrypt/options-ssl-apache.conf

</VirtualHost>

/var/log/httpd/example.com_error.log には次の内容が出力されます:

[Sat Sep 04 07:24:00.473120 2021] [autoindex:error] [pid 907862:tid 139932467173120] [client 85.89.184.79:50337] AH01276: Cannot serve directory /var/www/example.com/: No matching DirectoryIndex (index.html,index.php) found, and server-generated directory index forbidden by Options directive

ファイル権限

drwxr-xr-x. 5 root   root  102 Sep  3 23:53 ..
drwxr-xr-x. 8 root   root  163 Sep  4 07:11 .git
-rw-r--r--. 1 root   root   35 Sep  4 07:11 .gitignore
-rw-r--r--. 1 root   root  215 Sep  4 07:11 README.md
-rw-r--r--. 1 root   root  390 Sep  4 07:11 app.js
drwxr-xr-x. 3 root   root   21 Sep  4 07:12 node_modules
-rw-r--r--. 1 root   root 2655 Sep  4 07:12 npm-shrinkwrap.json
-rw-r--r--. 1 root   root  318 Sep  4 07:11 package.json
drwxr-xr-x. 2 root   root   22 Sep  4 07:11 public

curl http://127.0.0.1:3000/Node.js/io.js + Connect.js から Hello を返します。

確認すべきことはありますか?

答え1

このエラーは、ディレクトリ内にデフォルトのインデックス ファイルが存在しないことを意味します。これは、あなたが言及したファイル リストを考慮すると明らかに当てはまります。

解決:

  1. パブリック ディレクトリ内に空の index.html ページを作成します。

    touch /var/www/example.com/index.html
    
  2. httpd.conf 内のオプション ディレクティブを変更し、インデックスを追加します。

    Options -MultiViews -Indexes
    
  3. httpdを再起動/リロードする

    service httpd reload
    

編集:

httpd.conf をもう一度確認すると、DocumentRoot がパブリック ディレクトリの場所を指していないようです。したがって、次のようになります。

  1. 現在の DocumentRoot を /var/www/example.com/public に置き換えます。
DocumentRoot /var/www/example.com/public
  1. ディレクトリ パスも同じパスに変更します。
<Directory /var/www/example.com/public>

詳細については、乗客ウェブサイト

関連情報