【phpcms-v9】phpcms-v9数据源调用的控制器文件分析phpcms/modules/db
发布:smiling 来源: PHP粉丝网 添加日期:2014-10-24 09:59:27 浏览: 评论:0
【phpcms-v9】phpcms-v9数据源调用的控制器文件分析phpcms/modules/dbsource/call.php:
- <?php
- defined('IN_PHPCMS') or exit('No permission resources.');
- class call {
- private $db;
- public function __construct() {
- $this->db = pc_base::load_model('datacall_model');
- }
- /*
- * 数据源的调用:<script type="text/javascript" src="http://www.zhen.com/index.php?m=dbsource&c=call&a=get&id=2"></script>
- */
- public function get() {
- //数据源id:即zp_datacall数据表中自增id
- $id = isset($_GET['id']) && intval($_GET['id']) ? intval($_GET['id']) : exit();
- //获取当前数据源记录
- if ($data = $this->db->get_one(array('id'=>$id))) {
- //运算符的优先级搞清楚,1-先赋值 2-再进行非逻辑
- if (!$str = tpl_cache('dbsource_'.$id,$data['cache'])) {//如果没有生成缓存
- if ($data['type'] == 1) { //自定义SQL调用
- $get_db = pc_base::load_model("get_model");//不设置要查询的数据表,只执行查询操作
- //拼接sql语句
- $sql = $data['data'].(!emptyempty($data['num']) ? " LIMIT $data[num]" : '');
- $r= $get_db->query($sql);//执行查询sql语句,注意:sql语句中已经有表名
- while(($s = $get_db->fetch_next()) != false) {//查询sql语句中的数据表
- $str[] = $s;//将查询到的表记录置入$str[]二维数组
- }
- } else {//非自定义sql调用情况
- //寻找对应模块下的xxx_tag.class.php文件
- $filepath = PC_PATH.'modules'.DIRECTORY_SEPARATOR.$data['module'].DIRECTORY_SEPARATOR.'classes'.DIRECTORY_SEPARATOR.$data['module'].'_tag.class.php';
- if (file_exists($filepath)) {
- //如果存在,则引入pc标签类库文件
- $pc_tag = pc_base::load_app_class($data['module'].'_tag', $data['module']);
- //调用方法
- if (!method_exists($pc_tag, $data['action'])) {
- exit();
- }
- $sql = string2array($data['data']);//sql语句,如:select * from zp_block
- $sql['action'] = $data['action'];//方法
- $sql['limit'] = $data['num'];//数量
- unset($data['num']);
- $str = $pc_tag->$data['action']($sql);
- } else {
- exit();
- }
- }
- //如果缓存时间不为空,则缓存到caches/caches_template/dbsource/$id.php文件中
- //缓存的是编译后的文件
- if ($data['cache']) setcache('dbsource_'.$id, $str, 'tpl_data');
- }//没生成缓存的情况
- echo $this->_format($data['id'], $str, $data['dis_type']);//参数3-输出方法(1-json 2-xml 3-js)
- }
- }
- private function _format($id, $data, $type) {
- switch($type) {
- case '1'://json
- if (CHARSET == 'gbk') {
- $data = array_iconv($data, 'gbk', 'utf-8');
- }
- return json_encode($data);//将数据json化,再输出
- break;
- case '2'://xml
- $xml = pc_base::load_sys_class('xml');
- return $xml->xml_serialize($data);//将数据xml化,再输出
- break; //开源代码phpfensi.com
- case '3'://js js的情况没有使用到$data参数数据
- pc_base::load_app_func('global');//引入global.func.php公共函数库文件
- ob_start();//开启缓冲区
- include template_url($id);//生成缓存文件,应引入缓存文件中内容(编译后的内容),此函数主要用来编译template字段到缓存文件
- $html = ob_get_contents();//获取缓冲区中内容
- ob_clean();//清空缓存区
- return format_js($html);//将文本格式成适合js输出的字符串,注意:此函数主要通过 通过document.write()动态将编译后的代码输出到网页中
- break;
- }
- }
- }
- ?>
Tags: phpcms数据源 phpcms控制器文件
相关文章
- ·【phpcms-v9】phpcms-v9中通过数据源调用功能将碎片表中的代码(2014-10-23)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)