热烈祝贺台州朗动科技的站长论坛隆重上线!(2012-05-28)    热烈庆祝伟大的祖国60周年生日 点击进来我们一起为她祝福吧(2009-09-26)    站长论坛禁止发布广告,一经发现立即删除。谢谢各位合作!.(2009-08-08)    热烈祝贺台州网址导航全面升级,全新版本上线!希望各位一如既往地支持台州网址导航的发展.(2009-03-28)    台州站长论坛恭祝各位新年快乐,牛年行大运!(2009-01-24)    台州Link正式更名为台州网址导航,专业做以台州网址为主的网址导航!(2008-05-23)    热烈祝贺台州Link资讯改名为中国站长资讯!希望在以后日子里得到大家的大力支持和帮助!(2008-04-10)    热烈祝贺台州Link论坛改名为台州站长论坛!希望大家继续支持和鼓励!(2008-04-10)    台州站长论坛原[社会琐碎]版块更名为[生活百科]版块!(2007-09-05)    特此通知:新台州站长论坛的数据信息全部升级成功!">特此通知:新台州站长论坛的数据信息全部升级成功!(2007-09-01)    台州站长论坛对未通过验证的会员进行合理的清除,请您谅解(2007-08-30)    台州网址导航|上网导航诚邀世界各地的网站友情链接和友谊联盟,共同引领网站导航、前进!(2007-08-30)    禁止发广告之类的帖,已发现立即删除!(2007-08-30)    希望各位上传与下载有用资源和最新信息(2007-08-30)    热烈祝贺台州站长论坛全面升级成功,全新上线!(2007-08-30)    
便民网址导航,轻松网上冲浪。
台州维博网络专业开发网站门户平台系统
您当前的位置: 首页 » PHP/Perl编程 » Dedecms综合应用讲座

Dedecms综合应用讲座

论坛链接
  • Dedecms综合应用讲座
  • 发布时间:2009-09-05 11:06:02    浏览数:6660    发布者:superadmin    设置字体【   
首先我简单的介绍下自己,我是织梦官方团队的天涯,接触织梦也有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的很多知识,需要有一定相关方面的基础才能够编写标签了,当然这里只是一个简单的标签开发例子,还有许多的东西可以去开发
娱乐休闲专区A 影视预告B 音乐咖啡C 英语阶梯D 生活百科
网页编程专区E AMPZF HTMLG CSSH JSI ASPJ PHPK JSPL MySQLM AJAX
Linux技术区 N 系统管理O 服务器架设P 网络/硬件Q 编程序开发R 内核/嵌入
管理中心专区S 发布网址T 版主议事U 事务处理