CakePHP – Folder Structure

CakePHP - Folder Structure

Here, we will learn about the Folder structure in CakePHP and the Naming Convention in CakePHP. Let us begin by understanding the Folder structure.

Folder Structure

Take a look at the following screenshot. It shows the folder structure of CakePHP.

CakePHP - Folder Structure

The following table describes the role of each folder in CakePHP āˆ’

Sr.NoFolder Name & Description
1bin
TheĀ binĀ folder holds the Cake console executables.
2config
TheĀ configĀ folder holds the (few) configuration files CakePHP uses. Database connection details, bootstrapping, core configuration files and more should be stored here.
3logs
TheĀ logsĀ folder normally contains your log files, depending on your log configuration.
4plugins
The plugins folder is where the Plugins of your application uses are stored.
5resources
The files for internationalization in the respective locale folder will be stored here. E.g. locales/en_US.
6src
TheĀ srcĀ folder will be where you work your magic. It is where your applicationā€™s files will be placed and you will do most of your application development. Letā€™s look a little closer at the folders inside src.Console āˆ’ Contains the console commands and console tasks for your application.Controller āˆ’ Contains your applicationā€™s controllers and their components.Model āˆ’ Contains your applicationā€™s tables, entities and behaviors.View Presentational classes are placed here: cells, helpers, and template files.
7templates
Template Presentational files are placed here: elements, error pages, layouts, and view template files.
8tests
TheĀ testsĀ folder will be where you put the test cases for your application.
9tmp
TheĀ tmpĀ folder is where CakePHP stores temporary data. The actual data it stores depends on how you have CakePHP configured, but this folder is usually used to store model descriptions and sometimes session information.
10vendor
TheĀ vendorĀ folder is where CakePHP and other application dependencies will be installed. Make a personal commitment not to edit files in this folder. We canā€™t help you, if youā€™ve modified the core.
11webroot
TheĀ webrootĀ directory is the public document root of your application. It contains all the files you want to be publically reachable.

Naming Convention

The naming convention is not something mandatory to be followed, but is a good coding practice and will be very helpful as your project goes big.

Controller Convention

The controller class name has to be plural, PascalCased and the name has to end with Controller. For example, for the Students class, the name of the controller can beĀ StudentsController. Public methods on Controllers are often exposed as ā€˜actionsā€™ accessible through a web browser.

For example, the /users /view maps to the view() method of the UsersController out of the box. Protected or private methods cannot be accessed with routing.

File and Class Name Convention

Mostly, we have seen that our class name file name is almost the same. This is similar in CakePHP.

For example, the class StudentsController will have the file named as StudentsController.php. The files have to be saved as the module name and in the respective folders in the app folder.

Database Conventions

The tables used for CakePHP models, mostly have names plural with underscores.

For example, student_details, student_marks. The field name has an underscore if it is made up of two words, for example, first_name, last_name.

Model Conventions

For the model, the classes are named as per the database table, the names are plural, PascalCased, and suffixed with Table.

For example, StudentDetailsTable, StudentMarksTable

View Conventions

For view templates, the files are based on controller functions.

For example, if the class StudentDetailsController has the function showAll(), the view template will be named as show_all.php and saved inside template/yrmodule/show_all.php.

Next Topic : Click Here

Leave a Reply