Recently, I need to use the cakephp PHP framework for my work. Since I have used it less before, and I recently read some manuals, I feel that some things in cakephp are not very clear, so I decided to take a look at its source code. Here is what I saw Some notes during the process
I think if you are interested in viewing this document, it is best to open the corresponding PHP file and compare it, otherwise you may not know what I am talking about.
Start:
When we download and install by default from the Internet, there will be three directories: app, cake, vendors, as well as .htaccess, and index.php files.
According to the manual instructions and experience, the cake directory is the core code of the framework and is also a directory that does not need to be touched during development. This will be helpful for us to upgrade the framework core in the future. If you need to write your own class during the development process, you can place the file in the vendors directory and call it using methods such as app::import. .htaccess and index.php will pass the default access request to the app/webroot/index.php file for execution (if the server does not support .htaccess, you need to modify the index.php file again). Finally, we can determine that app is our default Main battlefield! (Of course this can be changed, for example, if several applications share a core, I won’t go into details here)
When opening the app/webroot/index.php file, we will find that this file writes It is very simple. The first piece of code defines some basic path constants (such as app path, directory path, etc.), followed by a cake/bootstrap.php file, which is this file that loads all the necessary information and initialization of the framework. Work, let's see what it does. B 是 Below is part of the code in the bootstrap.php file. I appropriately add some comments
If (! Isset ($ BOOTSTRAP)) {Require core_path. 'Cake'. Ds. 'Basics.php' ; //Defines the common function methods of the framework
. 'Object.php'; // The parent class of all classes Require Libs. 'Inflector.php'; // Naming category, handling single plural hump naming: For example
,,,, ,,, ,,,, ,,, require LIBS . '; //Load cache engine class
use using ‐ ‐ ‐ ‐ ‐‐‐‐‐‐‐‐'; 'Core', array('Dispatcher')); //Import path processing class, program entry path, etc.
At the end of the app/webroot/index.php file, the $Dispatcher->dispatch method will be called to execute the program
$Dispatcher = new Dispatcher(); //Initialize the path processing class
$Dispatcher->dispatch($url); //The framework starts to determine the URL execution program
Code such as:
$url = $this->getUrl(); //Get the URL path
$this->params = array_merge($this->parseParams($url), $additionalParams); //Get the processed URL Arrays, including values passed by $_POST and $_GET, as well as controllers and methods. The program processes URL parameters through the parseParams method and calls the routes class method to obtain controller and action information, assemble it into a regular array, and pass it to $this- >params, it is worth noting that in the following code, $this->params will be assigned to $controller->params, which is why we can use $this->params in the controller. For example: $this->params['controller'] will get the controller name of the current request
Then the current action will be judged. For example, if there is an underscore (_) before the action name, it will be considered a protected method and will not be used. Access, etc.
Next, some parameters will be assigned to the current controller. The code is as follows
$controller->base = $this->base;
$controller->here = $this->here;
$controller ->webroot = $this->webroot;
$controller->plugin = $this->plugin;
$controller->params =& $this->params; //Pass all parameters to $controller->plugin, including controller and action names, form data, URL, etc.
$controller->action =& $this->params['action'];
$controller->passedArgs = array_merge($ this->params['pass'], $this->params['named']); //Assign all parameters passed by $_GET to $controller->passedArgs, including whether there are named parameters, such as /controller /action/a:1/b=2/3/4
(Note: When the controller executes the render method, it will automatically pass some variables to the view, which is what we call the template. For example, the controller will assign the value of the passedArgs variable. Give passedArgs in the view, so that we can directly call $this->passedArgs in the template)
The last modified method will call the current controller and pass the parameters for execution
Let’s take a look at the called _invoke
function _invoke(&$controller, $params) {
$controller->Component->initialize($controller); //Call component's initialize method before controller beforeFilter
$controller->beforeFilter();
$controller ->Component->startup($controller);
Here we can see that $controller->Component->initialize is executed before $controller->beforeFilter(), as shown in this manual I won’t say much more when it comes to mentioning it. What should be noted here is that the $controller->constructClasses method will merge the current user-defined controller class and some variables in AppController (app_controller.php), such as $users, helper and component, etc. , the more important thing here is that it will cycle through all the values under the $users variable and load the corresponding model. If the $this->uses variable is false, no model will be initialized: Note that if you only want to define the controller and do not want to define the corresponding model file, this variable should be empty, or if you want to automatically load other models when the controller is called, you can assign the desired model name to $this->users=array(' modelname1', 'modelname2'), etc. Another situation is that when the user does not set the value of $users himself, the framework will automatically try to call the corresponding model based on the name (the model file is not necessary, but at this time in the database There must be a corresponding table, otherwise an error will be reported)
Other explanations should not be required
$output = $controller->dispatchMethod($params['action'], $params['pass ']);
This method is to call the dispatchMethod method in the object class. In fact, the controller class executes the corresponding action method
The following is a small piece of code
if ($controller->autoRender) {
output = $ output; When the time comes, the framework will call the render function to call the corresponding template to display and output the final HTML
The execution steps of the framework are basically over. Of course, there are still many things that have not been written in. Firstly, my writing skills are limited, and secondly, calling There are too many functions, so I won’t explain them one by one here.