
先从路由开始来说:
1)路由
路由协议的规则是使用了正则表达的匹配,将不同的链接分发到不同的控制器上去,也支持调用匿名函数
// 第一种,使用匿名函数
App::router()->get('/', function () {
echo "Beauty Framework.";
});// 第二种,使用url分发到控制器
App::router()->post('/user/info/[0-9]+(/[0-9]+)?', 'App\Controllers\UserController@getUserInfo');其中实现的核心代码:(是不是很简单)
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)控制器
没有的,你指向的哪里,就可以在哪里进行请求处理,但是按照MVC,建议写到Controller里,大家都是这么认为的,就这么做;
3)模型层
这里直接集成了Dao类,用于数据库查询操作,因为现在很多都在使用MySQL,就耦合地实现了MySQL的常规操作,因为数据库的原生操作会引起很多的注入等问题,没有支持直接Qquery的方式来做。
4)DAO层
因为很多情况下都要进行读写分离,但是要使用MySQL Proxy来实现,有太过笨重,所以实现了支持数据库query根据不同的sql分别使用master和slave数据库。
怎么做的?
就是根据不用的查询操作直接划分,Select查询操作直接分到读库,Insert、Update、Delete直接分到写库。也可以直接使用onMasterConnection/onSlaveConnection直接指定.
看看Select怎么做的,这部分是实现逻辑:
/**
* 获取查询内容,以数组形式返回,数据内为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)配置类
在开发环境和生产环境会使用不同的配置环境,在框架中可以创建.env环境来切换。在config中可以常规设置development和production,使用哪个环境就在.env设置哪个
; This is a environment configuration file environment=development
当然也有一些公共的配置信息,可以在config文件里直接设置,这样就可以在哪个环境都可以使用。
// 支持使用.连接访问配置项,访问的是config/app.php中的config key
\Beauty\Core\App::config()->get("app.config");6)请求响应
因为不需要View,只需要返回json数据,所以在Header直接写死了text/json。 = =
其他实现了
memcache和redis采用一致性哈希访问不同的实例。
validator验证类
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
长按识别二维码并关注微信
更方便到期提醒、手机管理