Cet article vous présente le framework Beauty Framework (avec code) basé sur php7. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. J'espère qu'il vous sera utile
Le noyau. Le lien du framework va de la résolution initiale du routage de la demande à la distribution du contrôleur, et de l'interaction des données du modèle à la réponse.
Utiliser d'autres frameworks pour l'implémenter sera très fastidieux, et il y a trop de contenus intégrés, 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. Up, il prend également en charge les appels anonymes fonctions
// 第一种,使用匿名函数 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 qui y est 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) Contrôleur
Non, où que ce soit vous indiquez, vous pouvez traiter la demande. Cependant, selon MVC, il est recommandé de l'écrire dans le contrôleur. Tout le monde le pense, alors 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. Parce que de nombreuses personnes utilisent désormais MySQL, les opérations régulières de MySQL sont couplées et implémentées, car les opérations natives de la base de données provoqueront beaucoup d'injections. méthode Qquery directe pour résoudre le problème.
4) Couche DAO
Parce que dans de nombreux cas, il est nécessaire de séparer la lecture et l'écriture, mais il est trop fastidieux d'utiliser le proxy MySQL pour y parvenir, il a donc implémenté le support pour les requêtes de base de données basées sur différents SQL, ils utilisent respectivement les bases de données maître et esclave.
Comment ?
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 base de données de lecture, et l'insertion, la mise à jour et la suppression sont directement affectées à la base de données 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. Vous pouvez créer un environnement .env dans le framework pour basculer. Le développement et la production peuvent être définis régulièrement dans la configuration. L'environnement utilisé 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, donc que vous pouvez définir quel environnement All peut être utilisé.
// 支持使用.连接访问配置项,访问的是config/app.php中的config key \Beauty\Core\App::config()->get("app.config");
6) Demander une réponse
Comme il n'y a pas besoin de View et que seules les données json doivent être renvoyées, text/json est écrit directement dans l'en-tête. = =
D'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
Articles connexes recommandés :
Méthode d'implémentation de l'extension Zend Framework Smarty, zendsmarty
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!