OneThink以其便捷的建站、丰富的扩展、灵活的二次开发,以及云服务的支持,为广大个人和企业建站带来新的契机和机遇,即将成为互联网新的弄潮儿。
OneThink特性介绍:
1. 基于ThinkPHP最新版本Thinkphp3.2。
2. 模块化:全新的架构和模块化的开发机制,便于灵活扩展和二次开发。
3. 文档模型/分类体系:通过和文档模型绑定,以及不同的文档类型,不同分类可以实现差异化的功能,轻松实现诸如资讯、下载、讨论和图片等功能。
4. 开源免费:OneThink遵循Apache2开源协议,免费提供使用。
5. 用户行为:支持自定义用户行为,可以对单个用户或者群体用户的行为进行记录及分享,为您的运营决策提供有效参考数据。
6. 云端部署:通过驱动的方式可以轻松支持平台的部署,让您的网站无缝迁移,内置已经支持SAE。
7. 云服务支持:即将启动支持云存储、云安全、云过滤和云统计等服务,更多贴心的服务让您的网站更安心。
8. 安全稳健:提供稳健的安全策略,包括备份恢复、容错、防止恶意攻击登录,网页防篡改等多项安全管理功能,保证系统安全,可靠、稳定的运行。
9. 应用仓库:官方应用仓库拥有大量来自第三方插件和应用模块、模板主题,有众多来自开源社区的贡献,让您的网站“One”美无缺。
oneThink后台添加插件步骤:
版本:V1.1.141212 (注:v1.1也有很多版本,一不小心就下到V1.1.140202 去了,还有其他版本,建议去代码托管平台下载最新版本)
我也不偷懒,把每一步步骤都记录下来。
一、进入后台,创建插件
这里的钩子我新建了一个indexFooter,因为我只需在前台首页底部显示友情链接即可。我们把上面所有要勾的地方都勾上,至于有什么区别,大家可以自己建几个例子区分一下,生成的文件是否一样。OK!到这里 我们的友情链接插件就创建好了!点击“确定”。(这里的自定义模板什么的,通通不填,我会在下篇文章演示添加自定义模板的效果)
二、点击“安装” 即可,找到我们刚安装好的Links插件,点击“设置”,你会看到它有个默认的“是否开启随机”的选项,这里我们不管它,因为我们用不上,等下要删掉的。安装后,我们可以在左侧导航“已安装插件后台”看到我们新建的“友情链接”
三、当我们点击左侧导航的“友情链接”,你会发现报错,大概就是说的某个表不存在。是的,我们刚才只是建了插件,如果涉及到数据存储到数据库, 还需要建表。这里不直接去数据库里建,因为这样做,是很不人性化的。那我们就找到安装插件的函数,在安装插件的时候建立数据库,这样就好了。首先系统的插件全部存放在 根目录/Addons/ 文件夹下面,打开此文件夹,我们看到有个Links文件夹,这就是我们刚创建的插件,一个插件对应一个文件夹。打开Links文件夹,里面有2个文件和2个文件夹。
四、其实现在oneThink做的越来越简洁了,不懂PHP的人照样创建插件,之后你就会发现。当然,如果你有自己的想法,不想局限于官方的限制,那还是要把php学好的。
五、打开插件入口文件:LinksAddon.class.php 里面有个类LinksAddon,先来分析一下这个文件吧
我这里把$admin_list 数组的model 值改成links了,为了与插件对应。接下来我们在install方法里添加新建数据库的语句,这样我们在安装插件的时候,就会新建数据库了,我的代码如下:
public function install(){ //安装插件的方法 //1、添加数据表 $model = D(); $db_prefix = C('DB_PREFIX'); $table_name = "{$db_prefix}links"; $sql=<<<SQL CREATE TABLE IF NOT EXISTS `$table_name` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键', `title` varchar(80) NOT NULL DEFAULT '' COMMENT '站点名称', `link` varchar(140) NOT NULL DEFAULT '' COMMENT '链接地址', `summary` varchar(255) NOT NULL DEFAULT '' COMMENT '站点描述', `mailto` varchar(100) NOT NULL DEFAULT '' COMMENT '站长联系方式', `sort` int(3) unsigned NOT NULL DEFAULT 0 COMMENT '优先级', `nofollow` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '是否追踪', `type` tinyint(3) unsigned NOT NULL DEFAULT 1 COMMENT '类型分组', `cover_id` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '封面图片', `status` tinyint(2) NOT NULL DEFAULT 1 COMMENT '状态(0:禁用,1:正常)', `create_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '添加时间', PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='友情连接表'; SQL; $model -> execute($sql);//执行sql语句 //2、返回true,表示插件安装成功 return true; }
我这里省略了很多细节判断,大家自己完善。