Route is in debug list but returns 404 in Symfony 4
Asked Answered
B

3

15

Ok, so I just installed latest version Symfony 4. Run the browser after installation and a nice welcome greeting shows. All good!

Then I created a new controller using make:controller. I named this controller Client and is using Annotations, same with the other Default Controller. I configured the routing as follows:

/**
 * @Route("/client", name="client")
 */
public function index()
{
    // replace this line with your own code!
    return $this->render('@Maker/demoPage.html.twig', [ 'path' => str_replace($this->getParameter('kernel.project_dir').'/', '', __FILE__) ]);
}

I refreshed the browser and all good, no errors.

Then I manually typed the path into the browser to check if it's really working:

localhost:8000/client

Problem. The url returned standard apache 404

Not Found
The requested URL /client was not found on this server.

Apache/2.4.18 (Ubuntu) Server at new.staff-fdr.dev Port 80

The debug route sees this though:

-------------------------- -------- -------- ------ ------------------
  Name                       Method   Scheme   Host   Path   

 -------------------------- -------- -------- ------ -----------------
  client                     ANY      ANY      ANY    /client  
  index                      ANY      ANY      ANY    /       
  _twig_error_test           ANY      ANY      ANY    /_error/{code}.
Borlow answered 31/1, 2018 at 14:40 Comment(1)
Missing htaccess.Cahoot
C
41

Missing .htaccess file.

composer config extra.symfony.allow-contrib true

composer req symfony/apache-pack
Cahoot answered 31/1, 2018 at 15:59 Comment(1)
This solved my problem, I did only composer req symfony/apache-packOringa
A
6

I also had this issue and here are a couple of other ideas if this isn't working for you. One is to configure your web server as documented here. The optimized apache with mod_php worked for me:

https://symfony.com/doc/master/setup/web_server_configuration.html

Second, I didn't have mod rewrite enabled on my web server. This was ultimately the fix that got me up and going. Run:

sudo a2enmod rewrite

Then

sudo service apache2 restart

That should get you going.

Aggappe answered 23/2, 2018 at 20:34 Comment(1)
Had the same problem on 2 different projects and had no clue about the cause. This was the solution, thank you very much!Okeefe
A
0

In my case, I simply had forgotten to change my vhost configuration from the web to public folder when migrating to symfony flex.

<VirtualHost *:80>
    ServerAdmin [email protected]
    DocumentRoot "C:/xampp/htdocs/myproject/web/"
    ServerName dev.myproject.com
    ServerAlias dev.myproject.com
    <Directory "C:/xampp/htdocs/myproject/web/">
        Options Indexes FollowSymLinks Includes ExecCGI
        AllowOverride All
        Require all granted
        Order allow,deny
        Allow from all
    </Directory>
</VirtualHost>

TO

<VirtualHost *:80>
    ServerAdmin [email protected]
    DocumentRoot "C:/xampp/htdocs/myproject/public/"
    ServerName dev.myproject.com
    ServerAlias dev.myproject.com
    <Directory "C:/xampp/htdocs/myproject/public/">
        Options Indexes FollowSymLinks Includes ExecCGI
        AllowOverride All
        Require all granted
        Order allow,deny
        Allow from all
     </Directory>
</VirtualHost>
Avent answered 21/11, 2018 at 19:20 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.