互补网网专做高品质CMS教程,所有教程均为站长亲测有效后发布。
您当前所在位置:互补网首页 > DEDECMS > DEDE二次开发 >

DEDECMS后台增加文档复制功能(含详细步骤亲测可用)

发布时间:2019-08-22热度:0

互补网经常给客户做各种企业网站,由于要给站内添加一定的测试数据,以便于客户能够直接看到网站的整体效果,如果用采集的话还是比较麻烦的,并且采集的内容也不是那么规范,这里就想直接后台新增一个文档复制功能,添加的几篇文章进行复制,即可快速填充满一个网站,具体的操作方法:

本次开发牵扯的修改文件有三个分别是(修改前记得备份)

/dede/archives_do.php
dede/js/list.js
dede/templets/content_list.htm

首先打开/dede/archives_do.php文件(dede为后台目录),大约在430行下添加如下代码:

/*-----------------------------
//复制文档
------------------------------*/
elseif ($dopost == 'copyArchives') {
    CheckPurview('sys_ArcBatch');
    if (empty($totype)) {
        require_once(DEDEINC . '/typelink.class.php');
        if (!empty($aid) && empty($qstr)) $qstr = $aid;
 
        AjaxHead();
        $channelid = empty($channelid) ? 0 : $channelid;
        $tl = new TypeLink($aid);
        $typeOptions = $tl->GetOptionArray(0, $admin_catalogs, $channelid);
        $typeOptions = "<select name='totype' style='width:90%'>
        <option value='0'>请选择复制到的位置...</option>\r\n
        $typeOptions
        </select>";
 
        //输出AJAX可移动窗体
        $divname = 'copyArchives';
        echo "<div class='title' οnmοusemοve=\"DropMoveHand('{$divname}', 225);\" οnmοusedοwn=\"DropStartHand();\" οnmοuseup=\"DropStopHand();\">\r\n";
        echo "    <div class='titLeft'>复制文档</div>\r\n";
        echo "    <div class='titRight'><img src='images/ico-close.gif' style='cursor:pointer;' οnclick='HideObj(\"{$divname}\");ChangeFullDiv(\"hide\");' alt='关闭' title='关闭' /></div>\r\n";
        echo "</div>\r\n";
        echo "<form name='quickeditform' action='archives_do.php' method='post'>\r\n";
        echo "<input type='hidden' name='dopost' value='{$dopost}' />\r\n";
        echo "<input type='hidden' name='qstr' value='{$qstr}' />\r\n";
        echo "<table width='100%' style='margin-top:6px;z-index:9000;'>\r\n";
        ?>
        <tr height='28'>
            <td width="80" class='bline'> 目标栏目:</td>
            <td class='bline'>
                <?php echo $typeOptions; ?>
            </td>
        </tr>
        <tr height='32'>
            <td width="80" class='bline'> 文档ID:</td>
            <td class='bline'>
                <input type='text' name='tmpids' value="<?php echo $qstr; ?>" style='width:310px;overflow:hidden;'/>
                <br/>
                复制到的目标栏目必须和选定的文档频道类型一致,否则程序会自动勿略不符合的文档。
            </td>
        </tr>
        <tr height='32'>
            <td colspan='2' align='center' style='padding-top:12px'>
                <input name="imageField" type="image" src="images/button_ok.gif" width="60" height="22" class="np"
                       border="0" style="cursor:pointer"/>
                  
                <img src="images/button_back.gif" width="60" height="22" border="0"
                     οnclick='HideObj("<?php echo $divname; ?>");ChangeFullDiv("hide");' style="cursor:pointer"/>
            </td>
            </td>
        </tr>
        </table>
        </form>
        <?php
        //AJAX窗体结束
    } else {
        $totype = preg_replace("#[^0-9]#", '', $totype);
        $typeInfos = $dsql->GetOne("SELECT tp.channeltype,tp.ispart,tp.channeltype,ch.maintable,ch.addtable,ch.issystem FROM `hubuw_arctype` tp LEFT JOIN `hubuw_channeltype` ch on ch.id=tp.channeltype WHERE tp.id='$totype' ");
        $idtype = "id";
        if (!is_array($typeInfos)) {
            ShowMsg('参数错误!', '-1');
            exit();
        }
        if ($typeInfos['ispart'] != 0) {
            ShowMsg('文档保存的栏目必须为最终列表栏目!', '-1');
            exit();
        }
        if (empty($typeInfos['addtable'])) {
            $typeInfos['maintable'] = '`hubuw_archives`';
        }
        //增加单表模型判断
        if ($typeInfos['issystem'] == -1) {
            $typeInfos['maintable'] = $typeInfos['addtable'];
            $idtype = "aid";
        }
        $arcids = preg_replace("#[^0-9,]#", '', preg_replace("#`#", ',', $qstr));
        $arc = '';
        $j = 0;
        $okids = array();
        $dsql->SetQuery("SELECT {$idtype},typeid FROM `{$typeInfos['maintable']}` WHERE {$idtype} in($arcids) AND channel='{$typeInfos['channeltype']}' ");
        $dsql->Execute();
        while ($row = $dsql->GetArray()) {
            if ($row['typeid'] != $totype) {
                
                $dsql->ExecuteNoneQuery("insert into `hubuw_arctiny` (typeid,typeid2,arcrank,channel,senddate,sortrank,mid) select typeid,typeid2,arcrank,channel,senddate,sortrank,mid from `hubuw_arctiny` where id='{$row[$idtype]}'");
                
                $xid = $dsql->GetLastID();
                
                $dsql->ExecuteNoneQuery("insert into `{$typeInfos['maintable']}`(id,typeid,typeid2,sortrank,flag,ismake,channel,arcrank,click,money,title,shorttitle,color,writer,source,litpic,pubdate,senddate,mid,keywords,lastpost,scores,goodpost,badpost,voteid,notpost,description,filename,dutyadmin,tackid,mtype,weight) select case when id>'0' then '$xid'  else '' end, case when typeid>'0' then '$totype'  else '' end,typeid2,sortrank,flag,ismake,channel,arcrank,click,money,title,shorttitle,color,writer,source,litpic,pubdate,senddate,mid,keywords ,lastpost,scores,goodpost,badpost,voteid,notpost,description,filename,dutyadmin,tackid,mtype,weight from `{$typeInfos['maintable']}` WHERE id='{$row[$idtype]}' ");
                
                $dsql->ExecuteNoneQuery("insert into `{$typeInfos['addtable']}`(aid,typeid,body,redirecturl,templet,userip) select case when aid>'0' then '$xid'  else '' end,$totype,body,redirecturl,templet,userip from `{$typeInfos['addtable']}` WHERE aid='{$row[$idtype]}' ");
                
                $okids[] = $row[$idtype];
                $j++;
            }
        }
 
        
    UpDateCatCache();
    $sql = " TRUNCATE TABLE `hubuw_arctiny`";
    $dsql->ExecuteNoneQuery($sql);
    
    //导入普通模型微数据
    $sql = "INSERT INTO `hubuw_arctiny`(id, typeid, typeid2, arcrank, channel, senddate, sortrank, mid)  
            SELECT id, typeid, typeid2, arcrank, channel, senddate, sortrank, mid FROM `hubuw_archives` ";
    $dsql->ExecuteNoneQuery($sql);
    
    //导入单表模型微数据
    $dsql->SetQuery("SELECT id,addtable FROM `hubuw_channeltype` WHERE id < -1 ");
    $dsql->Execute();
    $doarray = array();
    while($row = $dsql->GetArray())
    {
        $tb = str_replace('hubuw_', $cfg_dbprefix, $row['addtable']);
        if(empty($tb) || isset($doarray[$tb]) )
        {
            continue;
        }
        else
        {
            $sql = "INSERT INTO `hubuw_arctiny`(id, typeid, typeid2, arcrank, channel, senddate, sortrank, mid)  
                    SELECT aid, typeid, 0, arcrank, channel, senddate, 0, mid FROM `$tb` ";
            $rs = $dsql->executenonequery($sql);
            $doarray[$tb]  = 1;
        }
    }
        //更新HTML
        foreach ($okids as $aid) {
            $arc = new Archives($aid);
            $arc->MakeHtml();
        }
        ShowMsg("成功复制 $j 个文档!", $ENV_GOBACK_URL);
        exit();
    }
}
打开dede/js/list.js文件搜索 function moveArc(e, obj, cid)下约35行添加以下代码:

function copyArc(e, obj, cid){
    var qstr=getCheckboxItem();
    if(qstr=='')
    {
        alert('必须选择一个或多个文档!');
        return;
    }
    LoadQuickDiv(e, 'archives_do.php?dopost=copyArchives&qstr='+qstr+'&channelid='+cid+'&rnd='+Math.random(), 'copyArchives', '450px', '180px');
    ChangeFullDiv('show');
}
打开dede/js/list.js 搜索  function ShowMenu(evt,obj,aid,atitle)里面的new ContextItem("推荐文档",function(){ adArc(aid); }),的下面添加:
new ContextItem("复制(<u>C</u>)",function(){ copyToClipboard(atitle); }),
打开dede/templets下的content_list.htm找到
<a href="javascript:;" onClick="moveArc(event,this,<?php echo (empty($channelid) ? 0 : $channelid); ?>)" class="layui-btn layui-btn-small">&nbsp;移动&nbsp;</a>
当前行的下方添加以下代码:
<a href="javascript:;" onClick="copyArc(event,this,<?php echo (empty($channelid) ? 0 : $channelid); ?>);" class="layui-btn layui-btn-small"> 复制 </a>
修改完成以上步骤后,然后在网站后台进入“所有档案列表”页面,即可看到复制功能。

温馨提示:修改前记得备份对应文件。

本文地址:http://www.25923.com/dedecms/kaifa/082271.html(转载请保留)