22
votes

I start the tutorial (as newbie) and everythings works fine till:

http://symfony.com/doc/current/book/page_creation.html#creating-a-page-route-and-controller at step Creating a Page: Route and Controller

I have created a file called /var/www/html/[projekt]/src/AppBundle/Controller/LuckyController.php

but when I open http://[Server-IP]:8000/app_dev.php/lucky/number is always get a 404:

No route found for "GET /lucky/number"
404 Not Found - NotFoundHttpException
1 linked Exception: ResourceNotFoundException »

[2/2] NotFoundHttpException: No route found for "GET /lucky/number"   +
[1/2] ResourceNotFoundException:    +

routing.yml

app: 
    resource: "@AppBundle/Controller/" 
    type: annotation

Controller

namespace AppBundle\Controller; 

use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
use Symfony\Component\HttpFoundation\Response;

class LuckyController 
{ 

    /**
     * @Route("/lucky/number") 
     */
    public function numberAction() 
    { 
        $number = rand(0, 100);
        return new Response( '<html><body>Lucky number: '.$number.'</body></html>' ); 
    }
}

No idea where is the mistake...

ERROR - Uncaught PHP Exception Symfony\Component\HttpKernel\Exception\NotFoundHttpException: "No route found for "GET /lucky/number"" at /var/www/html/[Symfony-Folder]/app/cache/dev/classes.php line 2061

php app/console debug:route
 [router] Current routes
 Name                     Method Scheme Host Path
 _wdt                     ANY    ANY    ANY  /_wdt/{token}
 _profiler_home           ANY    ANY    ANY  /_profiler/
 _profiler_search         ANY    ANY    ANY  /_profiler/search
 _profiler_search_bar     ANY    ANY    ANY  /_profiler/search_bar
 _profiler_purge          ANY    ANY    ANY  /_profiler/purge
 _profiler_info           ANY    ANY    ANY  /_profiler/info/{about}
 _profiler_phpinfo        ANY    ANY    ANY  /_profiler/phpinfo
 _profiler_search_results ANY    ANY    ANY  /_profiler/{token}/search/results
 _profiler                ANY    ANY    ANY  /_profiler/{token}
 _profiler_router         ANY    ANY    ANY  /_profiler/{token}/router
 _profiler_exception      ANY    ANY    ANY  /_profiler/{token}/exception
 _profiler_exception_css  ANY    ANY    ANY  /_profiler/{token}/exception.css
 _configurator_home       ANY    ANY    ANY  /_configurator/
 _configurator_step       ANY    ANY    ANY  /_configurator/step/{index}
 _configurator_final      ANY    ANY    ANY  /_configurator/final
 _twig_error_test         ANY    ANY    ANY  /_error/{code}.{_format}
 homepage                 ANY    ANY    ANY  /
11
Please share your routing.yml and your controllerBENARD Patrick
routing.yml (/app/config/routing.yml): ` app: resource: "@AppBundle/Controller/" type: annotation `Atreides78
Don't post your files in the comments. Edit your post and add your code.Abdelaziz Dabebi
@MarcelBurkhard Is there a way to find out if it uses annotations? Sorry I am a realy newbie in Symfony.Atreides78
Add to LuckyController.php <?phpRhim

11 Answers

22
votes

I have just added a

<?php

to the file "LuckyNumberController" and it works.... really strange.

Thanks everybody

6
votes

Try this URL:

http://[Server-IP]:8000/app_dev.php/en/lucky/number

There's a bug in the Symfony Book: they forgot the demo app support i18n.

Just add the "/en" parameter before the routing ones.


I know this question it's closed but I hope my answer can help others that are still facing this problem.

5
votes

Sometimes is a cache problem. Try to remove dev folder from /project/var/cache/dev.

As authentictech says, also you can try the command:

php bin/console cache:clear

If you want to specify the environment, you should add the --env=prod property.

1
votes

You actually don't extend Symfony Controller class. It should be class LuckyController extends Controller

// src/AppBundle/Controller/LuckyController.php 
namespace AppBundle\Controller; 

use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route; 
use Symfony\Component\HttpFoundation\Response;

class LuckyController extends Controller {

     /** 
      * @Route("/lucky/number") 
      */ 
     public function numberAction() { 
         $number = rand(0, 100); 
         return new Response('<html><body>Lucky number: '.$number.'</body></html>');
     }

}

EDIT: after all, the problem in this question was not in extending controller, so ignore my answer.

0
votes

I copied and pasted your controller in an existing Symfony project and the route immediately appeared. So nothing wrong with the controller.

I also compared the routing.yml and it's the same.

The only thing that's left is to check the folder structure and make sure you don't have different Symfony projects mixed together; maybe you're editing the right file but starting the web server from a different path.

Check carefully or rebuild the project in a completely different path. Since you're testing with the embedded web server, you don't need to put your project into /var/www/html (in fact it's better not to).

0
votes

http://localhost:8080/SymfonyProject/web/app_dev.php/lucky/number

It works for me. Change "SymfonyProject" with your project name folder or delete it if your project is pointed directly by the Server. Also pay attention to the port that works for you (localhost:8080). In my case is 8080, in your could be 8000 or something else.

0
votes

Another reason you might get a "No route found for "GET /luck/number" is because you have a tab in front of the @Route annotation. I thought I programmed my code exactly like the example, and was getting this error, but turned out it was the tab.

See the following code below, and notice the first one produces the "No Route found..." exception:

/**
 *  @Route("/lucky/number")
 */

 /**
 * @Route("/lucky/number")
 */
0
votes

In case someone else runs into this problem: for me the problem was twofold:

  1. i forgot to assign a namespace namespace AppBundle\Controller;
  2. i didn't add a use statement for the template use Sensio\Bundle\FrameworkExtraBundle\Configuration\Template;
0
votes

Had the same issue, but for a completely different reason than those shown here so far...

Somehow my demo wasn't defining a default locale. There appear to be a number of configurations that could address this, but I'm not familiar enough with Symfony yet to know the exact cause. My solution until then is to simply define the locale in the URL, for example:

/app_dev.php/en/lucky/number

0
votes

Extending the base class Controller did not work for me. To solve the problem I had to do the following change in web/app.php

$kernel = new AppKernel('prod', true);

Also I had to add 'en' in the url: http://scotchbox.demo/en/lucky/number

0
votes

If you're using apache server with Symfony 4 (not the Symfony server) just add :

composer require symfony/apache-pack

Don't forget to address your Document Root to

where/is/your/symfony/public

in apache configuration.