dedecms专题节点ID不能出现重复问题的解决方法


在做专题的时候发现个特别郁闷人的事情,5个节点,任意一个节点中出现ID重复均被过滤之后写入数据库;为此研究了一番,原来有去重复功能。

最后发现罪魁祸首就是以下代码:

if(is_array($ids))            {                foreach($ids as $mid)                {                    $mid = trim($mid);                    if($mid=="") continue;                    if(!isset($arcids[$mid]))                    {                        if($okids=="")                        {                            $okids .= $mid;                        }                        else                        {                            $okids .= ",".$mid;                        }                        $arcids[$mid] = 1;                    }                }            }

s其中foreach循环中,有个isset的判断,就是在此过滤了一些重复ID; 
不知道DEDE $arcids这个变量是如何设置的,经过foreach循环之后既然会赋予所有节点的ID均入到数组中。 
为此,我的解决方法是这样的: 
首先将$ids这个数组变量进行去重复处理:

$ids = array_unique($ids);

之后将isset改用is_array判断是否是数组 
完整的代码如下:

$ids = array_unique($ids);            if(is_array($ids))            {                foreach($ids as $mid)                {                    $mid = trim($mid);                    if($mid=="") continue;                    if(!is_array($arcids[$mid]))                    {                        if($okids=="")                        {                            $okids .= $mid;                        }                        else                        {                            $okids .= ",".$mid;                        }                        $arcids[$mid] = 1;                    }                }            }

不知道如此更改是否会有其他“副作用”!还望大家多多指教!

小编补充:重复你有特殊需求,否则不建议修改。

攻击者利用 Confluence 漏洞,入侵Jenkins项目服务器

Jenkins 服务器背后开发团队披露了一个安全漏洞,该漏洞是一个OGNL(对象导航图语言)注入问题。经过身份验证的攻击者可以利用该漏洞,在Confluence 服务器和数据中心执行任意代码,攻击者在一台服务器上部署了加密挖矿工具。Jenkins 服务器披露一...
服务器漏洞服务器安全JenkinsConfluence

4种开源云安全工具

查如果你的日常工作是开发者、系统管理员、全栈工程师或者是网站可靠性工程师(SRE),工作内容包括使用 Git 从 GitHub 上推送、提交和拉取,并部署到亚马逊 Web 服务上(AWS),安全性就是一个需要持续考虑的一个点。幸运的是,开源工具能帮助你的团队避...
服务器安全开源云安全工具

虚拟机使用PuTTY、SSH Secure Shell Client前的配置

虚拟机使用PuTTY、SSH Secure Shell Client前的配置1 仅主机模式 2 检查子网IP为192.168.154.0 3 进入虚拟机,检查IP地址?1ip addr show添加IP地址?1ip addr add dev eno167777...
虚拟机SSHPuttyShellClientSecure

Log4j漏洞可能需要数年时间才能解决

近日Log4j漏洞的出现引起了业内人士的广泛讨论,网络安全专家认为CVE-2021-44228的普遍性以及容易被利用,这个Log4j中的远程代码执行漏洞可能需要数月甚至数年时间才能得到妥善解决。McAfee Enterprise和FireEye的高级威胁研究主...
漏洞服务器安全网络安全log4j