Apache pasajero - Prohibido No tienes permiso para acceder a este recurso

Apache pasajero - Prohibido No tienes permiso para acceder a este recurso

Estoy atascado Apachecon Passengerla configuración. Estuve unos días buscando una solución.Sigo estas instrucciones.Recibo este mensaje en el navegador:

Forbidden

You don't have permission to access this resource.

httpd.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>

En /var/log/httpd/example.com_error.log obtengo:

[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

Derechos de archivo

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/devuelve ¡Hola desde Node.js/io.js + Connect.js!

¿Hay algo que deba comprobar?

Respuesta1

Este error significa que no hay un archivo de índice predeterminado en el directorio y ese es claramente su caso considerando la lista de archivos que mencionó.

Solución:

  1. Cree una página index.html en blanco dentro de su directorio público.

    touch /var/www/example.com/index.html
    
  2. Modifique la directiva de opciones dentro de httpd.conf y agregue índices:

    Options -MultiViews -Indexes
    
  3. Reiniciar/recargar httpd

    service httpd reload
    

Editar:

Mirando nuevamente su httpd.conf, parece que no señaló a DocumentRoot dónde está su directorio público. Por lo tanto:

  1. Reemplace el DocumentRoot actual por /var/www/example.com/public:
DocumentRoot /var/www/example.com/public
  1. Cambie la ruta del directorio a la misma ruta también:
<Directory /var/www/example.com/public>

Para obtener más información, consulteSitio web de pasajeros

información relacionada