dede织梦_高级功能function扩展-dede @me

为了使用模板标记不破坏文档的可读性,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或浮点型,可以不加引号,字符串则必须加引号

灵活使用扩展函数,可以做出很多随意的功能,但又不用改动系统的源码,对于采集扩展,更加是可以更灵活处理采集到的原始内容。

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

格式为:
{dede:tagname runphp=‘yes‘}
$aaa = @me;
@me = "123456";
{/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"))‘

在产品列表中,有个值经过函数处理,通常一个变量的情况下是这样的:

[field:typeid function=‘get_linkshangpin(@me,3)‘/]

[field:pubdate function=‘strftime("%m-%d",@me)‘/]

[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中加入以下代码:

Copy code 
//评论是否启用验证码(0否1是)如果更改了这里,必须重新生成文章HTML
$feedback_validate = 1;

然后在/templets/default/article_article.htm,/templets/plus/feedback_templet.htm等有评论表单的地方的相应位置加入以下代码:

{dede:php runphp=‘yes‘}
if($feedback_validate) {
@me = "<tr>
<td>验证码:</td>
<td><input
name=\"validate\" type=\"text\" id=\"validate\"> <img
src=\"/include/validateimg.php\" alt=\"看不清楚可点击这里更换!\" border=\"0\"
align=\"absmiddle\" onclick=\"this.src=this.src;\"></td>
</tr>";
}
{/dede:php}

在/plus/feedback.php中找到如下代码:

else if($action=="send")
{
在下面加入:
session_start();
if( empty($_SESSION["s_validate"]) ) $svali = "";
else $svali = $_SESSION["s_validate"];
if($feedback_validate && strtolower($vdcode)!=$svali && $svali!=""){
ShowMsg("验证码错误!","-1");
exit();

这样就可以实现评论验证码的功能了,并且可选开关。另外,评论还可以加入时间限制,IP限制等

{dede:field name=‘keywords‘ runphp=‘yes‘ }
if(!empty(@me)){
$kws = explode(‘ ‘,@me);
@me = "";
foreach($kws as $k){
@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>
";
}
//@me= str_replace(‘+‘, ‘ ‘,trim(@me));
}
{/dede:field}

时间: 2024-07-29 14:48:57

dede织梦_高级功能function扩展-dede @me的相关文章

dede织梦联动筛选 功能

这种需求:下图 第一步: 首先需要说明的是这个功能需要在模板里面用到php标签,所以需要在后台模板引擎禁用标签里面解除这个标签的禁用,具体方法: 后台--系统--系统基本参数--其它选项--模板引擎禁用标签:php 将这个PHP去掉后保存就可以了! 第二步: 需要修改2个PHP文件,都是include目录下面的.分别是  arc.listview.class.php 和 extend.func.php两个文件 由于这两个文件改动大,为防止出错,请点击下载修改过的覆盖到include目录下面. 点

DEDE织梦常用的调用方法

DEDE织梦常用的调用常规调用: 网站名称调用:<title>{dede:global.cfg_webname/}</title> 网站关键词调用:<meta name="keywords" content="{dede:global.cfg_keywords/}" />网站描述调用:<meta name="description" content="{dede:global.cfg_descr

dede织梦5.7的安全防护设置

dede安全是一直令人堪忧的,但是其用来建网站很方便,如果我们使用dede来建站,一定要做好安全防护工作. 下面总结一下dede织梦5.7的安全防护设置 1.更改管理员名称和密码,尽可能设置的复杂一下,一般是大小写字母数字和特殊符号12位以上 2.强烈建议data/common.inc.php文件属性设置为644(Linux/Unix)或只读(NT): 3.管理目录改名,最好是改成MD5形式的,最好长点,我一般改成20位大小子字母数字. 4.如果是使用HTML可以把plus下的相应文件和根目录下

dede织梦后台如何修改?如何增加删除菜单?(

织梦后台的模板存放在dede/templets下面, 登陆首页模板login.htm, 进入首页模板index_body.htm, 左侧菜单模板index_menu2.htm. 修改左侧菜单dede/inc/inc_menu.php 这个文件. 要添加一个菜单找到dede/templets/index_menu2.htm增加: <a id='link9' class='mm'><div onClick="ShowMainMenu(9)">其他</div&g

dede织梦如何防止被黑客入侵渗透?

dede精简设置篇:避免被hack注射挂马 精简设置篇:不需要的功能统统删除.比如不需要会员就将member文件夹删除.删除多余组件是避免被hack注射的最佳办法.将每个目录添加空的index.html,防止目录被访问.织梦可删除目录列表:member会员功能 special专题功能 install安装程序(必删) company企业模块 plus\guestbook留言板 以及其他模块一般用不上的都可以不安装或删除. 密码设置篇:管理员密码一定要长,而且字母与数字混合,尽量不要用admin,初

如何有效防止DEDE织梦系统被挂木马安全设置(仅供参考)

尊敬的客户,您好!     感谢广大客户对我司工作的信任和支持!      我司在最近的一个多月内陆续发现多起因 DedeCMS 安全漏洞造成网站被上传恶意脚本的事件,入侵者可利用恶意脚本对外发送大量数据包,严重占用CPU资源与服务器带宽,影响极为恶劣.为保证服务稳定,即日起一旦发现网站存在此类恶意脚本,我们将立即暂停该网站的服务直到问题修复.如果您正在使用 DedeCMS,请立即检查是否已经存在恶意脚本,并更新程序到最新版本或应用相关补丁.     迄今为止,我们发现的恶意脚本文件有    

dede织梦怎样导出文章的URL和标题

如何用织梦cms批量查询并导出网站文章的url链接和标题. 工具/原料 dede织梦CMS网站后台 登陆dede织梦cms网站后台. 如图所示,点击[模板]-[全局标记] 如图,输入代码,调用链接和标题,并提交测试. {dede:arclist row="100"} [field:fulltitle/]******这里输入你的域名*******[field:arcurl/] {/dede:arclist} 程序运行完毕时就可以复制你想要的链接和标题了.

记一次DEDE织梦网站恢复的经历

前言:一个处于瘫痪的网站,之前使用DEDE织梦搭建,由于之前被挂马,被迫关停,好在程序有备份,数据库已经恢复并清理,DEDE系统升级之后,显示主页为空白内容. 解决过程: 1.拿到管理员用户密码之后,登陆dede后台发现,栏目信息为空白,刚开始怀疑是数据库信息被清理,后来排查发现数据库有两个栏目表,只是前缀不同,后来通过查找网上信息发现,dede可以在安装过程中进行自定义,默认是dede_开头的表,所以怀疑可能是数据库连接表错误: 2.查找dede的数据库连接配置文件data/common.in

dede织梦data目录正确迁移及引起的问题解决方法

关于将dede织梦data目录迁移出web目录织梦官方提供了一个教程,但是如果你是按照他们提供的教程做的话会出现很多问题.比如验证码问题, 图片显示问题等等一大堆.织梦官方这种是很不负责任的,因为那个教程有很大缺陷.这里跟大家提供一个完整版本的如何将dede织梦data目录正确迁移, 以及按照官方版本教程迁移出现问题的解决办法.这里先看看官方的吧,然后我再补充. 1.将data目录转移到非Web目录 我们这里举例“D:\dedecms\v57”为我们系统的根目录,我们需要将目录下的data文件夹