


Build your own PHP framework with Composer using ORM, composerrom_PHP tutorial
Use Composer to build your own PHP framework using ORM, composerrom
Review
After the basic preparation, routing and MVC design in the first three articles, we have obtained a PHP micro-framework with a relatively complete MVC architecture, but there is still one thing missing from a framework that can actually be used: database encapsulation. This article will describe how to integrate an ORM Composer package.
This article is the last article in this series. Next, I may share some experiences and insights with the series title Let’s Open and Open the Composer Package, which will be mainly published on this site.
Text
We choose Laravel’s illuminate/database as our ORM package. I tried several famous ORMs and found that Laravel's Eloquent is the best! The ORM that makes us happy is opened again and again! :-D
In this series of tutorials, each Composer package must meet the following basic requirements:
Natively relies on Composer for management
Try to be as simple as possible on the basis of ease of use (such as our super simple routing package)
Be as up-to-date as possible and use the new features of PHP
Speaking of the new features of PHP, there is a digression. PHP5.3 introduced namespaces, which is a function planned in PHP6, so PHP5.3 is actually PHP6 to a certain extent. The next version of PHP is PHP7, which will be released soon. The main contributor is the famous Bird Brother @Laruence . In addition, our frontline reporter (that’s me) just reported from Weibo that Brother Niao is stepping up his game to create the legendary PHP7 on JIT. The historical wheel of my big PHP is unstoppable, hahaha! :-P
Install illuminate/database
Add a require item to composer.json:
"illuminate/database": "*"
Run composer update and wait for the installation to complete.
Using Eloquent
Modify public/index.php to:
use IlluminateDatabaseCapsuleManager as Capsule;
// Autoload automatically loads
require '../vendor/autoload.php';
// Eloquent ORM
$capsule = new Capsule;
$capsule->addConnection(require '../config/database.php');
$capsule->bootEloquent();
// Routing configuration
require '../config/routes.php';
Add config/database.php (note to replace the database password):
return [
'driver' => 'mysql',
'host' => 'localhost',
'database' => 'mffc',
'username' => 'root',
'password' => 'password',
'charset' => 'utf8',
'collation' => 'utf8_general_ci',
'prefix' => ''
];
Modify models/Article.php:
/**
* Article Model
*/
class Article extends IlluminateDatabaseEloquentModel
{
public $timestamps = false;
}
controllers/HomeController.php requires no changes.
Refresh, the page remains:
Congratulations! Successful use of Eloquent!
More ways to use Eloquent
Eloquent is extremely powerful and can be said to be the most special and valuable part of Laravel.
Like Article::first() called in HomeController, it used more than a dozen lines of code before, but now you don’t need to do anything, just inherit a class.
For more usage of Eloquent, please see: Eloquent ORM Chinese Documentation
Other famous ORMs
There are also many famous ORM and Datamapping (database migration, etc.) packages, see: ORM and Datamapping
ORM can greatly improve development efficiency, and Eloquent is truly a magic tool!
Although various language camps in the web world are constantly launching new so-called rapid development frameworks, they are still becoming more and more like Rails. Eloquent is almost the ORM most similar to Rails on the surface, but it cannot be compared with Rails. Ruby's super object-oriented features are not blind. Laravel author Taylor Otwell said in an interview that Eloquent is the most difficult part to implement in Laravel. When I was debugging, I also found that the file MFFC/vendor/illuminate/database/Illuminate/Database/Eloquent/Model.php has more than 3,000 lines...
The current work of building a full and usable PHP framework is basically completed. Next, I will continue to improve the MFFC framework to make it richer and easier to use!
In the future, there may be content such as template engine, form validation, sending emails, permission system management, asynchronous queues, video and audio processing (instant:-D), etc. Please pay attention to the yet-to-be-released Composer that we have opened again and again. Package series of articles.
Thank you everyone for reading and accompanying me! goodbye!
Question 1: Why must we use manager as capsule
Because the name is too long, so rename it to make it easier to use
Question 2: What is the function of autoload.php under vendor , let alone automatic loading, I want to know how to load it
require '../vendor/autoload.php';
The code of this file cannot be seen, so I don’t know What is he doing
Question 3: What is the function of bootEloquent()
I didn’t see where this function is defined, so I can’t judge its function
Yes, the domestic full image has pkg.phpcomposer.com/
built by the laravel framework project team. There is also a proxy: 218.244.132.204/proxy/packagist. This proxy cannot use composer’s search and notice methods

Effective methods to prevent session fixed attacks include: 1. Regenerate the session ID after the user logs in; 2. Use a secure session ID generation algorithm; 3. Implement the session timeout mechanism; 4. Encrypt session data using HTTPS. These measures can ensure that the application is indestructible when facing session fixed attacks.

Implementing session-free authentication can be achieved by using JSONWebTokens (JWT), a token-based authentication system where all necessary information is stored in the token without server-side session storage. 1) Use JWT to generate and verify tokens, 2) Ensure that HTTPS is used to prevent tokens from being intercepted, 3) Securely store tokens on the client side, 4) Verify tokens on the server side to prevent tampering, 5) Implement token revocation mechanisms, such as using short-term access tokens and long-term refresh tokens.

The security risks of PHP sessions mainly include session hijacking, session fixation, session prediction and session poisoning. 1. Session hijacking can be prevented by using HTTPS and protecting cookies. 2. Session fixation can be avoided by regenerating the session ID before the user logs in. 3. Session prediction needs to ensure the randomness and unpredictability of session IDs. 4. Session poisoning can be prevented by verifying and filtering session data.

To destroy a PHP session, you need to start the session first, then clear the data and destroy the session file. 1. Use session_start() to start the session. 2. Use session_unset() to clear the session data. 3. Finally, use session_destroy() to destroy the session file to ensure data security and resource release.

How to change the default session saving path of PHP? It can be achieved through the following steps: use session_save_path('/var/www/sessions');session_start(); in PHP scripts to set the session saving path. Set session.save_path="/var/www/sessions" in the php.ini file to change the session saving path globally. Use Memcached or Redis to store session data, such as ini_set('session.save_handler','memcached'); ini_set(

TomodifydatainaPHPsession,startthesessionwithsession_start(),thenuse$_SESSIONtoset,modify,orremovevariables.1)Startthesession.2)Setormodifysessionvariablesusing$_SESSION.3)Removevariableswithunset().4)Clearallvariableswithsession_unset().5)Destroythe

Arrays can be stored in PHP sessions. 1. Start the session and use session_start(). 2. Create an array and store it in $_SESSION. 3. Retrieve the array through $_SESSION. 4. Optimize session data to improve performance.

PHP session garbage collection is triggered through a probability mechanism to clean up expired session data. 1) Set the trigger probability and session life cycle in the configuration file; 2) You can use cron tasks to optimize high-load applications; 3) You need to balance the garbage collection frequency and performance to avoid data loss.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 English version
Recommended: Win version, supports code prompts!

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 Chinese version
Chinese version, very easy to use

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function
