1. ThinkPHP后台代码一般放在哪几个文件夹
建议新建一个ThinkPHP项目作为后台开发用,入口文件admin.php;然后另起一个项目作为前台用,入口文件inde.php,会员中心也可独立建一个项目,入口文件user.php。
其他如果再需要扩展也可另起项目。这样各个项目独立运行,互不干扰,便于开发和调试管理。为了减少工作量和便于升级,你也可以让各个项目共用一些资源,比如model可以用D函数跨项目共用。
看我的构架图:
2. 什么是OneThink 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方法里添加新建数据库的语句,这样我们在安装插件的时候,就会新建数据库了,我的代码如下:
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
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;
}
我这里省略了很多细节判断,大家自己完善。
六、既然在安装插件的时候,新建了表,我们在卸载的插件的时候就要把表给删除,不然下次安装该插件的时候就会出问题。所以我们uninstall 方法代码如下:
?
1
2
3
4
5
6
7
8
9
public function uninstall(){ //卸载插件的方法
$model = D();
$db_prefix = C('DB_PREFIX');
$table_name = "{$db_prefix}links";
$sql="DROP TABLE IF EXISTS `".$table_name."`;";
$model -> execute($sql);//执行sql语句
return true;
}
好了,到这里就差不多了,保存一下LinksAddon.class.php 文件,应该可以正常显示了,我们来看看。进入插件列表,先把Links插件卸载,然后重新安装。点击左侧菜单“友情链接”,可以看到
之所以能正常显示这个列表,是因为系统有默认的模板,在\Application\Admin\View\Addons
文件夹里,有兴趣的同学可以研究一下这几个模板文件,其中这个列表的模板就是adminlist.html,那么我们要把封面、书名、描述等等这些字眼改掉,要去模板里改吗?细心的同学估计注意到了,在LinksAddon.class.php
文件 的$admin_list 数组里配置的,其他的看后面的注释就明白,这里详细说一下list_grid
关联的数组。我们刚才新建的links数据表有id、title、link等字段,你想在这个列表显示什么字段,都可以添加。我这里代码如下:
?
1
2
3
4
5
6
7
'list_grid'=>array( //这里定义的是除了id序号外的表格里字段显示的表头名和模型一样支持函数和链接
'title:网站名称',
'link:链接',
'summary:描述',
'create_time|time_format:添加时间', //time_format 是一个函数,把时间格式化,其他地方想使用什么函数也可以按照这种格式书写
'id:操作:[EDIT]|编辑,[DELETE]|删除'
),
保存,刷新后台友情链接列表
我们点击“新增” 来增加一个友情链接吧,你会发现,只有一个书名字段。我们打开Model/LinksModel.class.php 文件,我这里分别解释一下这两个自带的数组,具体看下面代码里的注释
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
class LinksModel extends Model{
public $model = array(
'title'=>'',//新增[title]、编辑[title]、删除[title]的提示
'template_add'=>'',//自定义新增模板自定义html edit.html 会读取插件根目录的模板
'template_edit'=>'',//自定义编辑模板html
'search_key'=>'',// 搜索的字段名,默认是title
'extend'=>1, //在后台列表是否显示 “增加”、“删除” 按钮,0-不显示 1-显示
);
public $_fields = array(
'id'=>array(
'name'=>'id',//字段名,与数据库的字段对应
'title'=>'ID',//显示标题
'type'=>'num',//字段类型:num、string、textarea、datetime、bool、select、radio、checkbox、editor、picture(封面)、file(附件)、
'remark'=>'',// 备注,相当于配置里的tip
'is_show'=>3,// 1-始终显示 2-新增显示 3-编辑显示 0-不显示
'value'=>0,//默认值
),
//下面演示一下 select字段怎么显示 radio、checkbox同理
'type'=>array(
'name'=>'type',
'title'=>'类型',
'type'=>'select',
'remark'=>'请选择所属类型',
'is_show'=>1,
'extra'=>'0:友情链接,1:合作站点',
'value'=>0,
'is_must'=>1,
),
);
}
ok,我最后的效果是这样的:
添加一条数据看看吧:
这里要显示具体类型、显示图片等,需要自定义adminlist.html模板了。关于自定义模板,我们下一篇文章再说。关于钩子,其实就是写一个函数从数据库读取数据,然后在前台需要的地方调用钩子就行。如果需要模板,则在钩子函数里解析模板。钩子调用格式一般:
{:hook("钩子名称"),"[参数]"} 没参数就不写。直接写成这样{:hook("钩子名称")}
到此为止就是用系统默认的模板,一步一步的建立自己的插件,是不是很简单,就像填空题一样,只要按照它的规则填空,就ok了。
3. ThinkPHP3.2开发的网站源码
何必呢,ThinkPHP官方出了套CMS系统叫oneThink,免费的
http://www.onethink.cn/
4. Lost connection to MySQL server at 'reading initial communication packet', system error
你检查一下,是否配置文件中链接的服务器还是localhost,如果链接网上空间,一般要改成数据库服务器的域名或IP
5. thinkphp 怎么把用户操作日志存到数据库
onethink里有这个功能,记录操作日志的,可以参考一下,需要先把所有需要记录的行为添加一下,这个工作量巨大,如果每个行为都要记录的话··· 所以一般都是把重要的记录就可以了。onethink 是 thinkphp开发的 可能跟你的存在版本差异,原理都是一样的,稍微修改就能用
6. onethink框架,怎么获取当前用户
Application/Common/Common/function.php /** * 检测用户是否登录 * @return integer 0-未登录,大于0-当前登录用户ID * @author 麦当苗儿 */ function is_login(){ $user = session('user_auth'); if (empty($user)) { return 0; } else { retu...
7. 插件钩子如何自定义,要些什么特别设置吗
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; } 我这里省略了很多细节判断,大家自己完善。 六、既然在安装插件的时候,新建了表,我们在卸载的插件的时候就要把表给删除,不然下次安装该插件的时候就会出问题。所以我们uninstall 方法代码如下: public function uninstall(){ //卸载插件的方法 $model = D(); $db_prefix = C('DB_PREFIX'); $table_name = "{$db_prefix}links"; $sql="DROP TABLE IF EXISTS `".$table_name."`;"; $model -> execute($sql);//执行sql语句 return true; } 好了,到这里就差不多了,保存一下LinksAddon.class.php 文件,应该可以正常显示了,我们来看看。进入插件列表,先把Links插件卸载,然后重新安装。点击左侧菜单“友情链接”,可以看到 之所以能正常显示这个列表,是因为系统有默认的模板,在\Application\Admin\View\Addons 文件夹里,有兴趣的同学可以研究一下这几个模板文件,其中这个列表的模板就是adminlist.html,那么我们要把封面、书名、描述等等这些字眼改掉,要去模板里改吗?细心的同学估计注意到了,在LinksAddon.class.php 文件 的$admin_list 数组里配置的,其他的看后面的注释就明白,这里详细说一下list_grid 关联的数组。我们刚才新建的links数据表有id、title、link等字段,你想在这个列表显示什么字段,都可以添加。我这里代码如下: 'list_grid'=>array( //这里定义的是除了id序号外的表格里字段显示的表头名和模型一样支持函数和链接 'title:网站名称', 'link:链接', 'summary:描述', 'create_timetime_format:添加时间', //time_format 是一个函数,把时间格式化,其他地方想使用什么函数也可以按照这种格式书写 'id:操作:[EDIT]编辑,[DELETE]删除' ), 保存,刷新后台友情链接列表 我们点击“新增” 来增加一个友情链接吧,你会发现,只有一个书名字段。我们打开Model/LinksModel.class.php 文件,我这里分别解释一下这两个自带的数组,具体看下面代码里的注释 class LinksModel extends Model{ public $model = array( 'title'=>'',//新增[title]、编辑[title]、删除[title]的提示 'template_add'=>'',//自定义新增模板自定义html edit.html 会读取插件根目录的模板 'template_edit'=>'',//自定义编辑模板html 'search_key'=>'',// 搜索的字段名,默认是title 'extend'=>1, //在后台列表是否显示 “增加”、“删除” 按钮,0-不显示 1-显示 ); public $_fields = array( 'id'=>array( 'name'=>'id',//字段名,与数据库的字段对应 'title'=>'ID',//显示标题 'type'=>'num',//字段类型:num、string、textarea、datetime、bool、select、radio、checkbox、editor、picture(封面)、file(附件)、 'remark'=>'',// 备注,相当于配置里的tip 'is_show'=>3,// 1-始终显示 2-新增显示 3-编辑显示 0-不显示 'value'=>0,//默认值 ), //下面演示一下 select字段怎么显示 radio、checkbox同理 'type'=>array( 'name'=>'type', 'title'=>'类型', 'type'=>'select', 'remark'=>'请选择所属类型', 'is_show'=>1, 'extra'=>'0:友情链接,1:合作站点', 'value'=>0, 'is_must'=>1, ), ); } ok,我最后的效果是这样的: 添加一条数据看看吧: 这里要显示具体类型、显示图片等,需要自定义adminlist.html模板了。关于自定义模板,我们下一篇文章再说。关于钩子,其实就是写一个函数从数据库读取数据,然后在前台需要的地方调用钩子就行。如果需要模板,则在钩子函数里解析模板。钩子调用格式一般: {:hook("钩子名称"),"[参数]"} 没参数就不写。直接写成这样{:hook("钩子名称")} 到此为止就是用系统默认的模板,一步一步的建立自己的插件,是不是很简单,就像填空题一样,只要按照它的规则填空,就ok了。 以上就是本文的全部内容,希望对大家学习PHP程序设计有所帮助。
8. onethink框架,怎么获取当前用户
Application/Common/Common/function.php
/** * 检测用户是否登录 * @return integer 0-未登录,大于0-当前登录用户ID * @author 麦当苗儿 <[email protected]> */ function is_login(){ $user = session('user_auth'); if (empty($user)) { return 0;
} else { return session('user_auth_sign') == data_auth_sign($user) ? $user['uid'] : 0;
}
}
9. onethink后台登陆怎样使用其他用户表登录(不使用默认安装的数据表),并成功进入后台
你的教务系统服务器肯定不会有问题,因为别人能进,问题就出现在你电脑这; 你应该是通过浏览器或是一个软件来登陆的; 如果是通过一个软件来登陆就将此软件卸载掉重装,可能是安装的软件出现了问题; 系统出现了问题,重装软件不行的话,那就将。
10. thinkphp如何实现用户登录信息保存本地
thinkphp中通过操作cookie来保存用户登录信息到本地。
cookie方法是ThinkPHP内置的函数,用于完成cookie的设置、获取和删除操作。
设置cookie:
cookie('name','value'); //设置cookie
cookie('name','value',3600); // 指定cookie保存时间为1小时
高级设置:
cookie('name','value',array('expire'=>3600,'prefix'=>'think_')); // 指定有效期和前缀
// 下面的代码和上面等效
cookie('name','value','expire=3600&prefix=think_')
获取cookie:
$value = cookie('name');