?
Laravel is an MVC framework with its own folder structure, but sometimes we want to use something external which doesn’t follow the same structure. Let’s review two different scenarios – when we have external?class?and when it’s just a?.php file.
Let’s say we have a simple example, a?PagesController.php?file like this:
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | namespace App\Http\Controllers; class PagesController extends Controller { ??/** ?? * Display homepage. ?? * ?? * @return Response ?? */ ??public function getHome() ??{ ????return view('pages.home'); ??} } |
?
Pretty simple, right? Now, let’s say we want to have our product?prices?on the homepage, but they come from some kind of external class or PHP file.
Use an external class in Controller
Let’s say we have a simple class to define the prices:
?
1 2 3 4 5 6 7 | class PricesClass { ??public function getPrices() { ????return ['bronze' => 50, 'silver' => 100, 'gold' => 150]; ??} } |
?
Now, where to put this class and how to use it? A couple of steps here:
1. You can put a class itself anywhere you want within?\App?folder
By default, Laravel offers you some folders there like?Providers, but I personally prefer to create a separate one – like?App\Libraries,?App\Classes?or?App\Services. Or you can call it your own application –?App\MyApp. This is totally your choice.
So, in this example, let’s save the class as?App\Classes\PricesClass.php.
2. Namespace within the file
Now we have to tell Laravel what is the namespace of this new file – it’s the same as the folder:
?
1 2 3 4 5 6 7 8 | <?php namespace App\Classes; class PricesClass { // ... |
?
3. Use the class in your Controller
Let’s get back to our?PagesController.php?– here we have to add?use?statement for that external class, and then we’re free to use it! Like this:
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | namespace App\Http\Controllers; use App\Classes\PricesClass; class PagesController extends Controller { ??/** ?? * Display homepage. ?? * ?? * @return Response ?? */ ??public function getHome() ??{ ????$pricesClass = new PricesClass(); ????$prices = $pricesClass->getPrices(); ????return view('pages.home', compact('prices')); ??} } |
?
That’s it, nothing more complicated than that.
Go to?QuickAdminPanel.com
Use an external PHP file in Controller
Another case – it’s not always an OOP file that we want to use. For some cases it’s just a list of functions. Of course, we can wrap them in a class as well, but not always. So, how to use the same function, if we just have a?prices.php?file like this:
?
1 2 3 4 5 6 7 | <?php function getPrices() { ??return ['bronze' => 50, 'silver' => 100, 'gold' => 150]; } |
?
And that’s it – no class, no namespace, nothing.
Let’s place our function as?app/functions/prices.php?file. Then – we have?three differentways of include it:
1. Just include?the class with PHP functions like?include()?or?require()?– and don’t forget app_path() function:
?
1 2 3 4 5 6 7 | public function getHome() { ??include(app_path() . '\functions\prices.php'); ??$prices = getPrices(); ??// ... |
?
Note that you still need a slash symbol before the folder?functions.
You can read more about?app_path()?and other Helper functions?in the official documentation.
2. In composer.json?file you just add needed files in?“autoload”?section – in a new entry called?“files”:
(thanks for this suggestion to the commenters Joseph and Hisham)
?
1 2 3 4 5 6 7 8 9 10 11 12 13 | ????"autoload": { ????????"classmap": [ ????????????"database" ????????], ????????"psr-4": { ????????????"App\\": "app/" ????????}, ????????"files": [ ????????????"app/functions/prices.php" ????????] ????}, |
?
This way you don’t need to use any?include()?functions anywhere within your controllers – just use the functions straight away.
3. Autoload the whole folder in composer.json
(thanks to YOzaz for pointing this out in comments)
Another way is just autoload the folder with that file – so you would place any similar external “helpers” in that folder, and that would be included in the future. In this case – add this folder in array or?“classmap”:
?
1 2 3 4 5 6 7 8 | ????"autoload": { ????????"classmap": [ ????????????"database", ????????????"app/functions" ????????], ????}, |
?
Choose this option if you want those files to be included in a manner of “set it and forget it”.
Notice:?if you make these changes to?composer.json?file, don’t forget to run?composer dump-autoload?for changes to take effect.

?