Contexto:

El día 24 de febrero del 2025, se lanzó la versión 12 de laravel. Un framework con PHP. En lo personal y para versiones en desarrollo, se me facilita más configurar el entorno y el acceso a los proyectos usando XAMPP y usando una url directa, es decir, usar localhost/nombre-proyecto en lugar de lanzar el proyecto con el comando artisan serve, simplemente porque es más simple.

https://laravel.com

Configuración

1.- Instalar un proyecto nuevo con el siguiente comando:

composer create-project laravel/laravel proyecto

Esperar que termine de descargar los archivos

2.- Copiar el archivo index.php del directorio de public/ y pegarlo en la ruta raíz del proyecto

Buscar las líneas siguientes, y modificar como se muestra:

[...]
require __DIR__.'/../vendor/autoload.php';

$app = require_once __DIR__.'/../bootstrap/app.php';
[...]

Modificar a:

[...]
require __DIR__.'/vendor/autoload.php';

$app = require_once __DIR__.'/bootstrap/app.php';
[...]

3.- Crear el archivo .htaccess en el directorio raíz del proyecto

# Disable directory browsing
Options All -Indexes

# ----------------------------------------------------------------------
# Rewrite engine
# ----------------------------------------------------------------------

# Turning on the rewrite engine is necessary for the following rules and features.
# FollowSymLinks must be enabled for this to work.
<IfModule mod_rewrite.c>
	Options +FollowSymlinks
	RewriteEngine On

	# If you installed CodeIgniter in a subfolder, you will need to
	# change the following line to match the subfolder you need.
	# http://httpd.apache.org/docs/current/mod/mod_rewrite.html#rewritebase
	# RewriteBase /

	# Redirect Trailing Slashes...
	RewriteCond %{REQUEST_FILENAME} !-d
    	RewriteRule ^(.*)/$ /$1 [L,R=301]

	# Rewrite "www.example.com -> example.com"
	RewriteCond %{HTTPS} !=on
	RewriteCond %{HTTP_HOST} ^www\.(.+)$ [NC]
	RewriteRule ^ http://%1%{REQUEST_URI} [R=301,L]

	# Checks to see if the user is attempting to access a valid file,
    # such as an image or css document, if this isn't true it sends the
    # request to the front controller, index.php
	RewriteCond %{REQUEST_FILENAME} !-f
	RewriteCond %{REQUEST_FILENAME} !-d
	RewriteRule ^(.*)$ index.php/$1 [L]

	# Ensure Authorization header is passed along
    RewriteCond %{HTTP:Authorization} .
    RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
</IfModule>

<IfModule !mod_rewrite.c>
    # If we don't have mod_rewrite installed, all 404's
    # can be sent to index.php, and everything works as normal.
    ErrorDocument 404 index.php
</IfModule>

4.- Asignar permisos a directorios del proyecto, y de storage

Permisos al proyecto

sudo chmod 775 -R proyecto
sudo chown -R daemon:blip proyecto

Permisos a storage

sudo chmod 777 proyecto/storage -R

5.- Acceder a la URL del proyecto desde el navegador

http://localhost/proyecto

Gracias por visitar.

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *