找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1188|回复: 0

[分享] DedeCMS借助function扩展实现特殊调用

[复制链接]
发表于 2018-7-5 11:08:14 | 显示全部楼层 |阅读模式 来自 中国–河南–新乡
下面是一篇很老的DedeCMS+function扩展功能教程,有些内容DedeCMS v5.1版本甚至其之前,贴上来给大家看看以参考学习。dedecms模板可以向模板插入PHP或类似PHP的代码,以达到特殊调用效果。dedecms允许对标记使用 function 进行扩展,function所使用的函数可以是系统函数,也可以是自定义的函数:

1、模板标记:
如:{dede:field name='pubdate' function=GetDateTimeMk('@me')/}
这个标记实际返回的结果是执行了GetDateTimeMk函数后的结果

一般情况下,模板标记的自定义扩展函数放在:
include/inc_functions.php

include/inc_functions.php
include/inc_channel_unit_functions.php

2、采集配置字段:
如:{dede:note field='title' value='[var:内容]' function=test('@me')}
{dede:match}<title>[var:内容]</title>{/dede:match}
{/dede:note}
这个采集节点返回的结果是执行了函数test后返回的结果

一般情况下,采集扩展的自定义扩展函数放在:
include/pub_collection_functions.php

在上面例子中 @me 表示这个标记本身的原始值,如果为int或浮点型,可以不加引号,字符串则必须加引号
灵活使用扩展函数,可以做出很多随意的功能,但又不用改动系统的源码,对于采集扩展,更加是可以更灵活处理采集到的原始内容。

织梦标记允许有限的编程扩展。
当前系统时间
  1. {dede:tagname runphp='yes'}@me = date("Y");{/dede:tagname}
复制代码

格式为:
  1. {dede:tagname runphp='yes'}
  2. $aaa = @me;
  3. @me = "123456";
  4. {/dede:tagname}
复制代码

@me 表示这个标记本身的值,因此标记内编程是不能使用echo之类的语句的,只能把所有返回值传递给@me。
此外由于程序代码占用了底层模板InnerText的内容,因此需编程的标记只能使用默认的InnerText。

过滤掉HTML代码
{dede:arclist sort='hot' titlelen=40 row=8}
<LI><A title="[field:title function='html2text(@me)'/]" href="[field:arcurl/]">[field:title/]</A></LI>
{/dede:arclist}

{dede:field name='description' function='html2text(@me)'/}
{dede:list imgwidth='*' imgheight='*'}
<img src='{dede:field name='litpic' /}' width="*" height="*">
修改 includeinc_channel_unit_functions.php
里面的 <img src='".$imgsrc."' width=80 align=left>
可以改变缩略图尺寸(版本过时,仅供学习参考)
5.1以前缩略图地址是
120U10ML014147_lit.gif
5.1变成了lit_120U10ML014147.gif
把[field:picname function='str_replace("_lit","",@me)'/]
换成[field:picname function='str_replace("lit_","",@me)'/]
function='str_replace("主页","",Html2Text("@me"))'
在产品列表中,一个值经过函数处理,通常一个变量的情况下是这样的:
  1. [field:typeid function='get_linkshangpin(@me,3)'/]
  2. [field:pubdate function='strftime("%m-%d",@me)'/]
  3. [field:litpic function="CkLitImageView(@me,80)"/]
复制代码

修改 includeinc_channel_unit_functions.php
里面的 <img src='".$imgsrc."' width=80 align=left>
function='cn_substr("@me",2). 取的是这个字段左边的截取.
想从右边开始截取,用什么函数呢..
我在用DEDE调用supersite blog 里面的博客之星图片.
它的图片地址是UID号对应的目录.
比如UID是176 可能对就的会员图片是/
76/photo_176.gif
可如果我用function='cn_substr("@me",2). 截取的UID变成了17...
如何才能截右边呢.变成76 ,
function=substr("@me",-2)
利用DEDE的runphp功能为评论加入验证码(可选开关)
首先在include/config_base.php中加入以下代码:
  1. //评论是否启用验证码(0否1是)如果更改了这里,必须重新生成文章HTML
  2. $feedback_validate = 1;
复制代码

然后在/templets/default/article_article.htm,/templets/plus/feedback_templet.htm等有评论表单的地方的相应位置加入以下代码:
  1. {dede:php runphp='yes'}
  2. if($feedback_validate) {
  3. @me = "<tr>
  4. <td>验证码:</td>
  5. <td><input name="validate" type="text" id="validate网上开店教程 <img src="/include/validateimg.php" alt="看不清楚可点击这里更换!" border="0" align="absmiddle" onclick="this.src=this.src;网上开店教程</td>
  6. </tr>";
  7. }
  8. {/dede:php}
  9. 在/plus/feedback.php中找到如下代码:
  10. else if($action=="send")
  11. {
复制代码

在下面加入:

  1. session_start();
  2. if( empty($_SESSION["s_validate"]) ) $svali = "";
  3. else $svali = $_SESSION["s_validate"];
  4. if($feedback_validate && strtolower($vdcode)!=$svali && $svali!=""){
  5. ShowMsg("验证码错误!","-1");
  6. exit();
复制代码


这样就可以实现评论验证码的功能了,并且可选开关。另外,评论还可以加入时间限制,IP限制等
  1. {dede:field name='keywords' runphp='yes' }
  2. if(!empty(@me)){
  3. $kws = explode(' ',@me);
  4. @me = "";
  5. foreach($kws as $k){
  6. @me .= "<a class='tags' HREF='javascript:void(null)' onclick='var ajax=new AJAXRequest;document.getElementById("relatedlinks").innerHTML="< img src=http://www.joohe.com/images/indicator.gif>数据加载中,请稍候..."; ajax.get("/plus/searchtag.php?keyword=".urlencode($k)."","relatedlinks");'>$k</a> ";
  7. }
  8. //@me= str_replace('+', ' ',trim(@me));
  9. }
  10. {/dede:field}
复制代码

发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;

如何回报帮助你解决问题的坛友,好办法就是点击帖子下方的评分按钮给对方加【金币】不会扣除自己的积分,做一个热心并受欢迎的人!

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则 需要先绑定手机号

关闭

站长推荐上一条 /1 下一条

QQ|侵权投诉|广告报价|手机版|小黑屋|西部数码代理|飘仙建站论坛 ( 豫ICP备2022021143号-1 )

GMT+8, 2024-11-19 07:40 , Processed in 0.044063 second(s), 8 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表