标签归档:ecms

帝国ECMS 评论 自动生成HTML【转】

修改e/enews/plfun.php文件,找到:
//设置最后发表时间

在下面加上这个
 $usql=$empire->query(“update {$dbtbpre}_”.$class_r[$classid][tbname].” set havehtml=0 where id=’$id'”);

然后发表评论的地址返回地址改下就成
 <input type=”hidden” name=”ecmsfrom” value=”http://www.abc3210.com/e/action/ShowInfo?classid=26&id=321″ />

Ecms伪静态规则

RewriteEngine On
RewriteBase /

RewriteRule ^([0-9]+).([0-9]+)/$ e/action/ShowInfo.php?classid=$1&id=$2 [L]
RewriteRule ^([0-9]+).([0-9]+)$ $1.$2/ [L,R=301]

RewriteRule ^([0-9]+)/$ e/action/ListInfo/?classid=$1 [L]
RewriteRule ^([0-9]+)$ $1/ [L,R=301]

RewriteRule ^list([0-9]+).([0-9]+)/$ e/action/ListInfo/index.php?page=$1&classid=$2 [L]
RewriteRule ^list([0-9]+).([0-9]+)$ list$1.$2/ [L,R=301]

RewriteRule ^archive([0-9]+).([0-9]+)-([0-9]+)-([0-9]+)/$ e/action/ListInfo.php?classid=$1&mid=1&tempid=9&starttime=$2-$3-$4&endtime=$2-$3-$4 [L]
RewriteRule ^archive([0-9]+).([0-9]+)-([0-9]+)-([0-9]+)$ ^archive([0-9]+).([0-9]+)-([0-9]+)-([0-9]+)/ [L,R=301]

帝国 ECMs,调用最新注册会员

[ecmsinfo]”select u.username as title,u.userid,ui.userpic as titlepic from phome_enewsmember u LEFT JOIN phome_enewsmemberadd ui ON u.userid=ui.userid order by u.userid desc”,6,18,0,24,16,0[/ecmsinfo]

[ecmsinfo]”select u.username as title,u.userid,ui.userpic as titlepic from phome_enewsmember u LEFT JOIN phome_enewsmemberadd ui ON u.userid=ui.userid order by u.userid desc”,6,18,0,24,16,0[/ecmsinfo]

管理标签模板  增加一个会员列表标签,把[!–empirenews.listtemp–]<!–list.var1–>[!–empirenews.listtemp–]和<a href=”e/space/?userid=[!–userid–]”> [!–title–]  </a>

帝国下载页,增加验证码的方法。

严重码那个生成部分的源码是网上找的,就整到了帝国里面去,其实可能用帝国自生的验证码生成,也可以。

<?
Header("Content-type:image/png");
//定义header,声明图片文件,最好是png,无版权之扰;
//生成新的四位整数验证码
session_start();//开启session;
$authnum_session = ”;
$str = ‘abcdefghijkmnpqrstuvwxyz1234567890’;
//定义用来显示在图片上的数字和字母;
$l = strlen($str); //得到字串的长度;
//循环随机抽取四位前面定义的字母和数字;
for($i=1;$i<=4;$i++)
{
$num=rand(0,$l-1);
//每次随机抽取一位数字;从第一个字到该字串最大长度,
//减1是因为截取字符是从0开始起算;这样34字符任意都有可能排在其中;
$authnum_session.= $str[$num];
//将通过数字得来的字符连起来一共是四位;
}
session_register("authnum_session");
//用session来做验证也不错;注册session,名称为authnum_session,
//其它页面只要包含了该图片
//即可以通过$_SESSION["authnum_session"]来调用

//生成验证码图片,
srand((double)microtime()*1000000);
$im = imagecreate(50,20);//图片宽与高;
//主要用到黑白灰三种色;
$black = ImageColorAllocate($im, 0,0,0);
$white = ImageColorAllocate($im, 255,255,255);
$gray = ImageColorAllocate($im, 200,200,200);
//将四位整数验证码绘入图片
imagefill($im,68,30,$gray);
//如不用干扰线,注释就行了;
$li = ImageColorAllocate($im, 220,220,220);
for($i=0;$i<3;$i++)
{//加入3条干扰线;也可以不要;视情况而定,因为可能影响用户输入;
imageline($im,rand(0,30),rand(0,21),rand(20,40),rand(0,21),$li);
}
//字符在图片的位置;
imagestring($im, 5, 8, 2, $authnum_session, $white);
for($i=0;$i<90;$i++)
{//加入干扰象素
imagesetpixel($im, rand()%70 , rand()%30 , $gray);
}
ImagePNG($im);
ImageDestroy($im);
?>

上面的代码保存为 checkNum_session.php

 
下面的加入到帝国的下载页面文件中

<?php
session_start();
//在页首先要开启session,
//error_reporting(2047);
session_destroy();
//将session去掉,以每次都能取新的session值;
//用seesion 效果不错,也很方便
?>

 

验证码输入框

<form action="" method="post">
验证码:<input type="text" name="validate" value="" size=10> <img src="checkNum_session.php"><br>
<input type="submit">
</form>

 

验证码判断代码

<?php
//打印上一个session;
echo "上一个session:<b>".$_SESSION["authnum_session"]."</b><br>";
$validate="";
if(isset($_POST["validate"])){
$validate=$_POST["validate"];
echo "您刚才输入的是:".$_POST["validate"]."<br>状态:";
if($validate!=$_SESSION["authnum_session"]){
//判断session值与用户输入的验证码是否一致;
echo "<font color=red>输入有误</font>";
}else{
echo "<font color=green>通过验证</font> 验证成功输出下载地址, 这里直接放上帝国的下载地址显示的连接,HTML代码中,有双引号之类的需要加上\转移符,

还要帝国的下载地址 直接用变量 $url即可如 <a href=$url>普通电信下载</a>";
}
}
/*
//打印全部session;
PrintArr($_SESSION);
function PrintArr($aArray){
echo ‘<xmp>’;
print_r($aArray);
echo ‘</xmp>’;
}
*/
?>

 

帝国 下载不采用弹出窗口式

下载不采用弹出窗口式说明
如果不采用弹出式下载的话,可依以下步骤完成:

1.修改下载地址模板("公共模板" -> "修改下载地址模板"):
将:
[ <a href=#edown onclick="window.open(‘[!–down.url–]’,”,’width=300,height=300′);">[!–down.name–]</a> ]
改成:
[ <a href="/e/DownSys/GetDown?classid=[!–classid–]&id=[!–id–]&pathid=[!–pathid–]">[!–down.name–]</a> ]
(如果发现不支持[!–classid–]与[!–id–]标签,重新下载安装程序,把里面的e/class/functions.php复制到本地即可支持)

2.开启直接下载开关:
修改e/DownSys/GetDown/index.php文件,把
-------------------
//———-开启自动链接
$openthisdown=1;//1为关闭,0为开启
-------------------
设置一下

3.重新刷新下载表的页面即可(记得选择重复刷新)

此方案缺点:起不到防盗链作用,如果你服务器本身就有防盗效果,才推荐使用此方式.
 

帝国ECMS 月排行周排行SQL调用标签

开启标签支持SQL语句方法:
修改e/class/connect.php
然后找到:
$do_openbqquery=0; //开启标签支持sql语句查询(0为不支持,1为开启)
设置成:
$do_openbqquery=1; //开启标签支持sql语句查询(0为不支持,1为开启)
已带模版的标签为例:
[ecmsinfo]"select * from phome__news
where newstime > SUBDATE(NOW(),INTERVAL 30 DAY) order by onclick desc limit 10",10,30,0,24,7,0[/ecmsinfo]

news 为表名, 30  是单位(天,当然你也可以修改单位为hour(小时),month(月)等…),自己修改合适的时间。 后面24是 开启SQL 标签需要用24

帝国 ECMS随机调用SQL标签写法

[ecmsinfo]"select * from phome__news where classid in (id1,id2……) order by rand() desc limit 6 ",6,18,1,24,11,1[/ecmsinfo]

(id1,id2……)   这个值得是栏目ID

phome_ecms_news 表名

limit 6 6为调用的条数

24 SQL标签这里放24

万能标签为

[ecmsinfo]栏目ID/专题ID,显示条数,标题截取数,是否显示栏目名,操作类型,模板ID,只显示有标题图片[/ecmsinfo] 

关于帝国CMS 的按栏目搜索的写法

<input type="hidden" name="show" value="title,picsay,smalltext">  这个是隐藏属性,后面是要搜索的的字段

             搜索&nbsp;<select name="classid">
               <option value="32">搜索主题</option>
               <option value="43">手机图片</option>
               <option value="60">文章</option>

这个是一个下拉单的形式的,再加上自己的FORM  栏目ID 和字段改下 就可以了,这个是比较简洁的写法,帝国的自定义搜索 很强大哦。。呵呵 这个按栏目的好处就可以 同一个提交可以 夸不同的模型,和表

当然也只能搜索,父栏目ID 下 同一个模型的栏目。

帝国论坛上也有相关自己定义搜索的教材,如果就按 栏目搜索应该我这个 是比较简单实用的了

修改小蜜蜂采集器 导库入 帝国ECMS 的时间

enews=AddNews,classid=38,bclassid=0,id=0,newspath=,oldztid=,filepass=1151301453,title=[title],isgood=0,checked=1,istop=0,newstempid=1,fh=0,groupid=0,userfen=0,newstime=2007-8-22,keyboard=[keyword],titlepic=,writer=[author],befrom=[sourse],newstext=[content],dokey=1,autopage=1,autosize=10000

上面这个是模拟提交 到帝国ECMS 的小蜜蜂倒库规则, 上面的 newstime=  已经改为时间了,如果想导入自己喜欢的时候 newstime=2007-8-22 后面改成你自己的时间就可以了。这个主要是方便为了,采集的数据 都采集了好久,而不是一次性导入程序的,这样的话 后来导库的时间都是采集时候的时候,如果同一个站的数据都是同一天采集,而分天倒库的话,也显示文章同一天发布了。这样可以使得,看上去,站在不同时间 经常更新。。。