Le lien principal du framework va de l'analyse initiale du routage des requêtes à la distribution du contrôleur, et de l'interaction des données du modèle à la réponse. La mise en œuvre à l'aide d'autres frameworks serait très lourde et intégrerait trop de contenu, dont beaucoup ne sont pas nécessaires, j'ai donc écrit un framework simple et pratique basé sur d'autres frameworks.
Commençons par le routage :
1) Routage
Les règles du protocole de routage utilisent la correspondance d'expressions régulières pour distribuer différents liens vers différents contrôleurs, et prennent également en charge l'appel de fonctions anonymes
// 第一种,使用匿名函数 App::router()->get('/', function () { echo "Beauty Framework."; });
// 第二种,使用url分发到控制器 App::router()->post('/user/info/[0-9]+(/[0-9]+)?', 'App\Controllers\UserController@getUserInfo');
Le code de base implémenté : ( est-ce très simple ?)
if (is_string($lostrcallable) && preg_match('!^([\a-zA-Z0-9]+)\@([a-zA-Z0-9]+)$!', $lostrcallable, $matches)) { $class = $matches[1]; $method = $matches[2]; $callable = function () use ($class, $method) { static $obj = null; if ($obj === null) { $obj = new $class; } return call_user_func_array(array($obj, $method), func_get_args()); }; }
2) S'il n'y a pas de contrôleur
, vous pouvez gérer la requête partout où vous la pointez. Cependant, selon MVC, il est recommandé de l'écrire dans le contrôleur Tout le monde si vous le pensez. , faites-le ;
3) Couche modèle
La classe Dao est directement intégrée ici pour les opérations de requête de base de données, car de nombreuses personnes utilisent maintenant MySQL, et les opérations régulières de MySQL sont couplées, car la base de données L'opération native provoquera beaucoup d'injections et d'autres problèmes, et il n'existe pas de méthode Qquery directe pour le faire.
4) Couche DAO
Parce que dans de nombreux cas, il est nécessaire de séparer la lecture et l'écriture, mais qu'il est trop fastidieux d'utiliser le proxy MySQL pour y parvenir, il a donc implémenté la prise en charge des requêtes de base de données pour utiliser respectivement les bases de données maître et esclave selon à différents SQL.
Comment faire ?
Il est directement divisé en fonction des opérations de requête inutilisées. Les opérations de requête sélectionnées sont directement affectées à la bibliothèque de lecture, et l'insertion, la mise à jour et la suppression sont directement affectées à la bibliothèque d'écriture. Vous pouvez également le spécifier directement en utilisant onMasterConnection/onSlaveConnection.
Regardez comment Select le fait. Cette partie est la logique d'implémentation :
/** * 获取查询内容,以数组形式返回,数据内为array。 * * @access public * @param integer|array $limit Array to define SQL limit in format Array ($count, $offset) * or only $count * * @return mixed Array of Clients */ protected function get($limit = null) { $this->dbClient->setQueryChannel($this->channel); $results = $this->dbClient->arrayBuilder()->get($this->dbTable, $limit, $this->fields); $this->_reset(); if ($this->dbClient->count == 0) { return []; } return $results; }
5) Classe de configuration
Différents environnements de configuration seront utilisés dans l'environnement de développement et l'environnement de production, dans le framework Vous pouvez créer un environnement .env pour basculer. Le développement et la production peuvent être définis régulièrement dans la configuration. Quel que soit l'environnement utilisé, il est défini dans .env
; This is a environment configuration file environment=development
Bien sûr, il existe également des informations de configuration publiques qui peuvent être définies directement dans le fichier de configuration, afin qu'elles puissent être utilisées dans n'importe quel environnement. environnement.
// 支持使用.连接访问配置项,访问的是config/app.php中的config key \Beauty\Core\App::config()->get("app.config");
6) Demander une réponse
Parce qu'il n'est pas nécessaire de View et que seules les données json doivent être renvoyées, text/json est écrit directement dans l'en-tête. = =
Autres implémentations
memcache et redis utilisent un hachage cohérent pour accéder à différentes instances.
Classe de vérification du validateur
Les codes spécifiques sont sur github https://github.com/tigerk/Beauty
C'est tout Si vous voulez savoir autre chose, vous pouvez cliquer ici. → →Tutoriel vidéo php
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!