`
gstarwd
  • 浏览: 1488187 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

dedecms安全设置及标签调用讲座(全文)

    博客分类:
  • CMS
阅读更多
首先我简单的介绍下自己,我是织梦官方团队的天涯,接触织梦也有2年多时间了,之前一直在论坛上做斑竹,认识了很多喜爱织梦的朋友,后来便加入了织梦团队,发现这是一个充满朝气、有激情和学习力的地方,这次受站长网的邀请来给大家做一次DedeCMS程序方面的讲座。
首先我简单的介绍下自己,我是织梦官方团队的天涯,接触织梦也有 2 年多时间了,之前一直在论坛上做斑竹,认识了很多喜爱织梦的朋友,后来便加入了织梦团队,发现这是一个充满朝气、有激情和学习力的地方,这次受站长网的邀请来给大家做一次 DedeCMS 程序方面的讲座。
  因为这次主要是讲座,缺乏体系的培训内容,本次讲座我将织梦技术论坛较为常见的问题加以整理,并结合一些其他方面的应用内容进行补充,让大家更了解 DedeCMS 程序的使用。
  安全设置
  首先是程序安全问题,这里主要是一些拥有独立服务器的站长,如果自己在系统安全部署上面有些经验那应该没有什么问题,有部分站长没有系统安全部署的经验,加上现在挂马猖獗,所以许多人都在担心,官方在早些时候就发了一个关于《 DedeCms V5.3/V5.5 安全设置指南》的主题帖,地址为: http://bbs.dedecms.com/172474.html ,这里面说了如何在 Win Serv 环境配置服务器环境。
  不过文中提到了织梦的文件目录,这里我对整个系统文件目录进行一个说明: http://bbs.dedecms.com/178324.html ,当然,如果你安装个模块会相应的增加一些目录,例如模块 group ask 等。
   {dede:sql} 标签的用法
   sql 标签可以称得上是个万能标签了,查询数据库将其输出,这里介绍一些关于这个标签的用法:
   1. 用来输出统计内容,这个是不错的,举个例子,我们来统计下总共发了多少的文章,思路就是输出 dede_addonarticle 这个文章附加表内容总数就可以了。
   {dede:sql sql="SELECT COUNT(*) AS nums FROM dede_addonarticle"}
   [field:name = "nums"/]
   {/dede:sql}
   2. 使用 ~field~ 来进行特殊的查询,比如之前论坛上面很多会员需要做一个输出当前发布文章会员的相关内容,之前用 sql 或者 arclist 标签是没办法实现的,因为每篇内容是不同的,这里我们来用 5.5 sql 语句来做个示范。
  我们首先在文章模板中相应的位置加上下面的标签
   {dede:sql sql="SELECT * FROM dede_archives WHERE writer=~writer~"}
   [field:id/],
   {/dede:sql}
  这个放到 article_article.htm 页面,将会检索出当前会员发布的相关文章,这里的 ~ writer~ 会根据当前内容的环境变量进行替换后再执行查询。
  这里出现在 SQL 语句中条件查询的 ~ writer~ ,也就是 $refObj->Fields[$value] 这个里面的相关内容
  模板中使用 PHP
  许多人希望织梦的模板标签能够更加灵活,加入可以运行 PHP 的功能,这里在 DedeCMS V5.5 中就加入了一个可以执行 php 的特殊标签 {dede:php}{/dede:php} ,这个标签可以执行 PHP 语句了。
  我这里举几个常用的例子:
   1. 最简单的输出内容:
   {dede:php}
   $numA = 1;
   $numB = 2;
   echo $numA + $numB;
   {/dede:php}
  这个输出的内容是计算结果:
   3
   2. 结合 SQL 查询输出单条内容
   {dede:php}
   $row = $dsql->GetOne('select id,typename from dede_arctype where id=2');
   print_r($row);
   {/dede:php}
  这个输出的内容是
   Array
   (
   [id] => 2
   [typename] => 问答
   )
   3. 获取当前页面的变量
  比如我们这里进入系统后台的 [ 模板 ]-[ 全局标记测试 ] ,我们在代码中填入下面的内容:
   {dede:php}
   print_r($refObj->Fields);
   {/dede:php}
  如果环境变量保持默认,即 不使用环境 ID” ,我们会看到以下的结果:
   Array
   (
   [typeid] => 0
   [phpurl] => /plus
   [indexurl] => /
   [templeturl] => /templets
   [memberurl] => /member
   [specurl] => /special
   [indexname] => 主页
   [templetdef] => /templets/default
   )
  那我们再换个环境变量测试看看,这里以我本地的栏目为测试了:
   Array
   (
   [id] => 3
   [reid] => 0
   [topid] => 0
   [sortrank] => 1
   [typename] => 产品
   [typedir] => {cmspath}/product
   … …
   [indexname] => 主页
   [templetdef] => /templets/default
   [position] => 主页 > 产品 >
   [title] => 产品
   )
  这样一来就检索出当前页面的局部变量了,接下来我们可以来结合前面的 SQL 语句来实现根据不同环境 ID 调用内容不同栏目内容。
  例如:
   {dede:php}
   $thisid = $refObj->Fields['id'];
   $row = $dsql->GetOne('select id,typename from dede_arctype where id='.$thisid);
   print_r($row);
   {/dede:php}
  这样是来调用当前栏目的标题,这个标签功能类似于 {dede:field.typename/}
  写自己的标签,让别人说去吧
   DedeCMS V5.3 开始就支持自己扩展标签,不过许多新人很少用那个东西,今天我就来简单的介绍下如何编写自己的调用标签。
  我们需要知道下扩展标签的存放目录及文件名构成,首先,扩展的标签都是存放在 /include/taglib 这个目录,名称都是以 标签名 .lib.php” 格式,例如 {dede:channel/} 标签对应的是 channel.lib.php 文件。
  我们可以看一个示例标签: demotag.lib.php
  
   if(!defined('DEDEINC'))
   {
   exit("Request Error!");
   }
   function lib_demotag(&$ctag,&$refObj)
   {
   global $dsql,$envs;
   // 属性处理
   $attlist="row|12,titlelen|24";
   FillAttsDefault($ctag->CAttribute->Items,$attlist);
   extract($ctag->CAttribute->Items, EXTR_SKIP);
   $revalue = '';
   // 你需编写的代码,不能用 echo 之类语法,把最终返回值传给 $revalue
   //------------------------------------------------------
   $revalue = 'Hello Word!';
   //------------------------------------------------------
   return $revalue;
   }
   ?>
  我们登录系统后台的 [ 模板 ]-[ 全局标签测试 ] 中运行 {dede:demotag/}, 显示如下的结果:
 
  这里我们知道,其实标签生成的内容其实是这个函数的一个返回值,这里返回的内容都是字符串,也就是函数 return $revalue; 中的 $revalue 需要是经过处理后生成的字符串。
   $attlist="row|12,titlelen|24"; 这个是属性列表,这个经过函数处理后会直接生成变量并复制,我们可以测试下,做如下的修改:
   $revalue = 'Hello Word!';
   $revalue .="
Row:".$row.";TitleLen:".$titlelen;
 
  这样我们可以看到,这个属性已经被创建变量并且赋值了。
  接下来我们可以再进一步去修改这个标签。
  比如说我们需要写一个标签专门来查询文章内容页的那个相关文章,功能类似于上面 sql 标签中的那个 sql ,只是这里我们将其分装为一个标签。
  我们可以新建一个标签,例如叫 writerarc ,那我们就需要创建一个 writerarc.lib.php ,然后模仿 demotag 编写函数,注意需要修改为
   function lib_writerarc(&$ctag,&$refObj)
  接下来我们就可以编写查询语句及对底层模板处理的相关函数了
   $revalue = '';
   $innertext = $ctag->GetInnerText();
   $ctp = new DedeTagParse();
   $ctp->SetNameSpace('field', '[', ']');
   $sql = "SELECT * FROM dede_archives WHERE writer='{$refObj->Fields['writer']}' limit 0, $row";
   $innertext 这个是用来获取标签的底层模板的, $ctp 创建用于处理底层模板中的变量,并处理进行替换。我们根据获取的属性编写我们的 sql 语句,这里我们使用 limit 0, $row ,这样就可以根据 $row 来确定查询的内容数目。
  当然我们可以获取更多的属性以便我们这个标签更强大,例如我们可以增加类似于 arclist 中的相关属性,并在函数中进行处理,不过这个需要有一定的 PHP 基础。
  接下来我们通过执行查询对 sql 及输出变量进行处理:
   $dsql->Execute('me',$sql);
   while($rs = $dsql->GetArray('me'))
   {
   // 根据属性处理查询变量
   $rs['title'] = cn_substr($rs['title'], $titlelen);
   // 获取底层模板
   $ctp->LoadSource($innertext);
   foreach($ctp->CTags as $tagid=>$ctag) {
   if(!empty($rs[strtolower($ctag->GetName())])) {
   $ctp->Assign($tagid,$rs[$ctag->GetName()]);
   }
   }
   // 根据底层模板及查询变量得到处理结果
   $revalue .= $ctp->GetResult();
   }
  这样我们就将查询出来的结果同底层模板中出现的相关变量进行替换,然后生成输出字符串,将所有的字符串信息存储到 $revalue 中。
  最后返回这个值 return $revalue;
  整个文件内容如下:
  
   if(!defined('DEDEINC'))
   {
   exit("Request Error!");
   }
   function lib_writerarc(&$ctag,&$refObj)
   {
   global $dsql,$envs;
   // 属性处理
   $attlist="row|12,titlelen|24";
   FillAttsDefault($ctag->CAttribute->Items,$attlist);
   extract($ctag->CAttribute->Items, EXTR_SKIP);
   $revalue = '';
   $innertext = $ctag->GetInnerText();
   $ctp = new DedeTagParse();
   $ctp->SetNameSpace('field', '[', ']');
   $sql = "SELECT * FROM dede_archives WHERE writer='{$refObj->Fields['writer']}' limit 0, $row";
   $dsql->Execute('me',$sql);
   while($rs = $dsql->GetArray('me'))
   {
   // 根据属性处理查询变量
   $rs['title'] = cn_substr($rs['title'], $titlelen);
   // 获取底层模板
   $ctp->LoadSource($innertext);
   foreach($ctp->CTags as $tagid=>$ctag) {
   if(!empty($rs[strtolower($ctag->GetName())])) {
   $ctp->Assign($tagid,$rs[$ctag->GetName()]);
   }
   }
   // 根据底层模板及查询变量得到处理结果
   $revalue .= $ctp->GetResult();
   }
   return $revalue;
   }
   ?>
  接下来我们来测试我们这个标签,我们修改 article_article.htm 模板,在里面加入以下的标签代码:
   {dede:writerarc row='10' titlelen='6'}
   [field:title/]
   {/dede:writerarc}
  通过动态浏览页面进行查看调试 http://www.dedecms.com/plus/view.php?aid=3 ,我们会发现标签起作用了,输出了我们的内容。
  
 至此我们完成了标签的编写,这里面主要涉及到
PHP MySQL 的很多知识,需要有一定相关方面的基础才能够编写标签了,当然这里只是一个简单的标签开发例子,还有许多的东西可以去开发。
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics