• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Tolowan: 基于phalcon开发的内容管理系统

原作者: [db:作者] 来自: 网络 收藏 邀请

开源软件名称:

Tolowan

开源软件地址:

https://gitee.com/itdashu/Tolowan

开源软件介绍:

欢迎使用Tolowan


是基于Phalcon开发的内容管理系统。特性:

  • 继承Phalcon框架全功能
  • 多网站支持,异站点用户文件、同网站私有/共有网站隔离
  • 强大的个性化环境,每个用户可以对网站内容和表现形式进行个性化设置
  • 基于用户角色、模块、角色的权限控制系统,当然,您也可以通过回调函数进行更精细控制
  • 提供的站内搜索系统原生支持全文搜索。
  • 使用volt编写主题模板,类twig语法,单比twig更高效
  • Tolowan提供的实体管理、字段管理、表单管理、模型管理等机制,可以大大缩减二次开发的难度和所需时间

安装部署教程

注:其中上文中siteroot为程序目录所在地址,加入QQ交流群:574199144


特性

实体(siteroot/Modules/Entity)

是具有相同功能的对象,在Tolowan中内置了三种实体类型:

  • 基于数据库模型的常规实体
  • 基于配置的配置实体
  • 基于配置列表的配置列表实体

例如,原生模块中,node、comment、user等模块是基于数据库模型的常规实体的实体对象;config是基于配置实体的实体对象;区域(region)、菜单(menu)是基于配置列表实体的实体对象。

不同的实体类型,决定了实体的保存、读取方式,但是所有实体都拥有统一的API,而定义实体,我们只需要完成实体声明数组文件和集成相应的基本实体模型即可,而实体的增、改、删、读等常规操作并不需要重新编写。

下面以node模块中的node实体为例:

  1. 在模块配置目录定义实体声明文件(siteroot/Modules/Node/config/entitys.php)
  2. 建立实体管理模型(集成基础实体管理模型类):siteroot/Modules/Node/Entity/NodeManager.php
  3. 建立实体模型(集成基础实体模型类):siteroot/Modules/Node/Entity/Node.php

2、3步的类文件可以随意在实体声明文件中制定

接下来就可以使用 adminEntity* 系列路由进行相关管理操作,当然你也可以替换/禁用这些默认操作(在此不详述)

字段

字段系统可以算是实体系统的一部分,通过它我们可以灵活的对实体进行无限制的模型扩充和灵活访问。

依旧以node实体进行操作示例:

$nodeEntity = $this->entityManager->get('node');//获取node实体$node = $nodeEntity->findFirst(5, true);//获取ID为5的文章$nodeUser = $node->uid->user //获取文章作者的user实体$node -> delete(); //删除文章和相关所有字段$nodeUser->delete(); //删除文章作者

配置(siteroot/Core/Config)

Tolowan直接以数组保存配置信息,当然使用前您需要通过命名空间引入该文件

Config::get('config') //获取config配置Config::set('config',array())//设置配置内容

模块和主题下config目录为其配置目录,我们可以通过Config::cache()来获取某个配置的合集

Config::cache('entitys');//合并所有已启用模块、主题config目录下entitys.php文件内容,这个合并操作在您清除配置缓存前只会进行一次


表单

Tolowan直接通过数组来声明表单,我们也可以把数组保存在配置文件中,通过配置名来生成表单。

例如:siteroot/Modules/Search/config/searchForm.php 是声明的搜索表单,配置名为:search.searchForm (模块名+文件名),在模板中我们可以这么使用。

{{ form.create('search.searchForm') }} //在模板中就可以直接生成基于bootstarp的表单html(当然也可以替换成自己的模板,此处不详谈)

模型

Tolowan中,你可以通过数组的方式来构建查询,简单距离:

 <?php$query = array(    'from' => 'node',    'andWhere' => array(        array(            'conditions' => 'node.id < :id:',            'bind' => array('id' => 50),        ),    ),    'limit' => 15,    'page' => 1,    'paginator' => true,);Core\Db\Query::find($query);

上面的含义:查询node表中id字段值小于50的数据,且采用分页查询,每页获取15条记录,获取第一页数据


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap