组保留的标签 余下为需要删除的标签 unset($oldtag[$key]); } } } if (!empty($oldtag)) { $tagids = array(); foreach ($oldtag as $tagid => $tagname) { $tagids[] = $tagid; } well_oldtag_delete($tagids, $tid); } $r = well_tag_process($tid, $fid, $create_tag, $tagarr); return $r; } // 删除标签和绑定的主题 function well_oldtag_delete($tagids, $tid) { $pagesize = count($tagids); $arrlist = well_tag_find_by_tagids($tagids, 1, $pagesize); $delete_tagids = array(); // 删除 $tagids = array(); $n = 0; foreach ($arrlist as $val) { ++$n; if (1 == $val['count']) { // 只有一个主题 $delete_tagids[] = $val['tagid']; } else { $tagids[] = $val['tagid']; } } !empty($delete_tagids) and well_tag_delete($delete_tagids); $arlist = well_tag_thread_find_by_tid($tid, 1, $n); if ($arlist) { $ids = array(); foreach ($arlist as $val) $ids[] = $val['id']; well_tag_thread_delete($ids); } !empty($tagids) and well_tag_update($tagids, array('count-' => 1)); } // 标签数据处理 $arr=新提交的数组 $tagarr=保留的旧标签 function well_tag_process($tid, $fid, $new_tags = array(), $tagarr = array()) { if (empty($tid)) return ''; // 新标签处理入库 if ($new_tags) { $threadarr = array(); $tagids = array(); $i = 0; $size = 5; $n = count($tagarr); $n = $n > $size ? $size : $size - $n; foreach ($new_tags as $name) { ++$i; $name = trim($name); $name = stripslashes($name); $name = strip_tags($name); $name = str_replace(array(' ', '#', "@", "$", "%", "^", '&', '·', '<', '>', ';', '`', '~', '!', '¥', '……', ';', '?', '?', '-', '—', '_', '=', '+', '.', '{', '}', '|', ':', ':', '、', '/', '。', '[', ']', '【', '】', '‘', ' ', ' ', ' ', ' ', ' '), '', $name); $name = htmlspecialchars($name, ENT_QUOTES); if ($name && $i <= $n) { // 查询标签 $read = well_tag_read_name($name); if ($read) { // 存在 count+1 $tagids[] = $read['tagid']; } else { // 入库 $arr = array('name' => $name, 'count' => 1); $tagid = well_tag_create($arr); FALSE === $tagid and message(-1, lang('create_failed')); $read = array('tagid' => $tagid, 'name' => $name); } $tag_thread = array('tagid' => $read['tagid'], 'tid' => $tid); $threadarr[] = $tag_thread; $tagarr[$read['tagid']] = $read['name']; } } !empty($threadarr) and tag_thread_big_insert($threadarr); !empty($tagids) and well_tag_update($tagids, array('count+' => 1)); } $json = empty($tagarr) ? '' : xn_json_encode($tagarr); return $json; } ?> $v = implode(",", $v); $temp[] = $v; } // 去掉重复的字符串,也就是重复的一维数组 $temp = array_unique($temp); // 再将拆开的数组重新组装 $output = array(); foreach ($temp as $k => $v) { if ($stkeep) $k = $starr[$k]; if ($ndformat) { $temparr = explode(",", $v); foreach ($temparr as $ndkey => $ndval) $output[$k][$ndarr[$ndkey]] = $ndval; } else $output[$k] = explode(",", $v); } return $output; } // 合并二维数组 如重复 值以第一个数组值为准 function array2_merge($array1, $array2, $key = '') { if (empty($array1) || empty($array2)) return NULL; $arr = array(); foreach ($array1 as $k => $v) { isset($v[$key]) ? $arr[$v[$key]] = array_merge($v, $array2[$k]) : $arr[] = array_merge($v, $array2[$k]); } return $arr; } /* * 对二维数组排序 两个数组必须有一个相同的键值 * $array1 需要排序数组 * $array2 按照该数组key排序 * */ function array2_sort_key($array1, $array2, $key = '') { if (empty($array1) || empty($array2)) return NULL; $arr = array(); foreach ($array2 as $k => $v) { if (isset($v[$key]) && $v[$key] == $array1[$v[$key]][$key]) { $arr[$v[$key]] = $array1[$v[$key]]; } else { $arr[] = $v; } } return $arr; } ?>网络安全

警惕新型威胁!ESET NOD32的账号密码自动获取器暗藏危险

简介:ESET NOD32是一款高效的反病毒软件,但相关工具如账号密码自动获取器可能涉及非法行为。这些工具可能通过不正当手段获取用户的私密账号信息,存在盗版、侵犯版权和网络安全的风险。本文强调了使用官方渠道获取和激活软件的重要性,以及

17天前30

ESET NOD32账号密码危机四伏,安全措施不能少!

简介:ESET NOD32是一款高效的反病毒软件,但相关工具如账号密码自动获取器可能涉及非法行为。这些工具可能通过不正当手段获取用户的私密账号信息,存在盗版、侵犯版权和网络安全的风险。本文强调了使用官方渠道获取和激活软件的重要性,以及

17天前50

ESET NOD32用户:注意了!账号密码可能被自动获取!

简介:ESET NOD32是一款高效的反病毒软件,但相关工具如账号密码自动获取器可能涉及非法行为。这些工具可能通过不正当手段获取用户的私密账号信息,存在盗版、侵犯版权和网络安全的风险。本文强调了使用官方渠道获取和激活软件的重要性,以及

18天前110

ESET NOD32账号安全预警:密码自动获取是陷阱,增强防护意识!

简介:ESET NOD32是一款高效的反病毒软件,但相关工具如账号密码自动获取器可能涉及非法行为。这些工具可能通过不正当手段获取用户的私密账号信息,存在盗版、侵犯版权和网络安全的风险。本文强调了使用官方渠道获取和激活软件的重要性,以及

18天前40

Flash中心大揭秘:黑客们怎么用它绕过门禁

卧槽!黑客圈子里都在偷偷用的神兵利器,你竟然还不知道?友情提示:本文仅用于提升自身安全技能,切勿用于不正当用途哦!在网络安全的世界里,各种奇奇怪怪的硬件设备层出不穷,它们就像黑客手中的“倚天剑”和“屠龙刀”,威

29天前60

小白必学:五种方法让您的电脑瞬间恢复与互联网的连接!

网络故障排查全攻略+网络安全学习资源包 | 程序员必藏,小白必备 文章分为两部分:一是详细介绍电脑网络连接问题的排查与解决方法,从硬件检查(路由器、网线、Wi-Fi)到软件设置(网络适配器、IP配置),再到高级操作(网络重置、

1月前80

零代码基础到精通:2025年计算机就业市场实战攻略

计算机就业现状可以从以下几个关键方面进行概述: 行业需求分化 热门领域需求旺盛:人工智能、大数据、云计算、网络安全、芯片设计、自动驾驶等领域技术迭代快,高端人才缺口大。传统互联网岗位饱和:前端、后端开发等基

1月前110

电脑网络卡顿像豆腐?掌握这五大方法让速度恢复如初

网络故障排查全攻略+网络安全学习资源包 | 程序员必藏,小白必备 文章分为两部分:一是详细介绍电脑网络连接问题的排查与解决方法,从硬件检查(路由器、网线、Wi-Fi)到软件设置(网络适配器、IP配置),再到高级操作(网络重置、

1月前170

“别慌!详解手机上出现的网站安全证书过期警示及应对方法”

过期证书网络安全手机能用吗手机上网安全证书过期-新手渗透笔记 当我们平常上网购物的时候,或者打开浏览器上网的时候,经常会碰到提示网页证书过期。浏览器打开网页提示安全证书过期,总是提示,让人很头痛。而且还耽误上网购物,那我们如

1月前90

手机上的网站安全证书到期,你会怎么办呢?

过期证书网络安全手机能用吗手机上网安全证书过期-新手渗透笔记 当我们平常上网购物的时候,或者打开浏览器上网的时候,经常会碰到提示网页证书过期。浏览器打开网页提示安全证书过期,总是提示,让人很头痛。而且还耽误上网购物,那我们如

1月前90

2025版计算机领域新挑战与机遇,零基础也能逆袭

计算机就业现状可以从以下几个关键方面进行概述: 行业需求分化 热门领域需求旺盛:人工智能、大数据、云计算、网络安全、芯片设计、自动驾驶等领域技术迭代快,高端人才缺口大。传统互联网岗位饱和:前端、后端开发等基

1月前100

青海计算机学子必读:全面解读从入门到精通的完整路径

计算机就业现状可以从以下几个关键方面进行概述: 行业需求分化 热门领域需求旺盛:人工智能、大数据、云计算、网络安全、芯片设计、自动驾驶等领域技术迭代快,高端人才缺口大。传统互联网岗位饱和:前端、后端开发等基

1月前60