-
DedeCMS中HTML自定义字段字符过滤问题解决方案
- 时间:2025-03-30 09:48:32 来源: 人气:0
在使用Dedecms后台频道模型时,增加自定义字段是一个常见的需求。通常,HTML文字编辑器可以很好地解决用户编辑问题,包括单行或多行文本的编辑。然而,在实际操作中,我们可能会遇到一些问题,比如Dedecms会自动过滤掉某些敏感字符,如style样式或百度地图的JS调用代码。本文将围绕这两个问题分享一些个人经验。
HTML文字样式编辑乱码问题
在Dedecms中,默认的文本编辑器虽然功能简单,但非常实用。我也尝试过使用百度的UEditor,它的功能确实强大,能够满足大多数用户的编辑需求。不过,替换默认编辑器需要进行二次开发,例如解决上传图集时无法点击本地上传按钮的问题。因此,我仍然选择使用默认的文本编辑器。自定义HTML编辑器虽然功能丰富,但在数据安全性方面,Dedecms会对某些敏感词或非法代码进行过滤,例如在评论区域中使用的代码。这种过滤机制是通过`include/helpers/filter.helper.php`文件实现的。被过滤的字段包括:
$ra1 = array('javascript', 'vbscript', 'expression', 'applet', 'meta', 'xml', 'blink', 'link', 'style', 'script', 'embed', 'object', 'iframe', 'frame', 'frameset', 'ilayer', 'layer', 'bgsound', 'title', 'base');
百度地图JS失效问题
百度地图生成器地址可以帮助我们快速生成地图代码(请自行申请开发密钥)。设置完成后,只需复制``之间的代码即可。其他代码可以根据实际情况直接写入内容页模板中。显示地图的区域代码如下所示:
<!--百度地图容器,样式根据实际情况修改,id默认为map-->
<p style="width:700px;height:550px;border:#ccc solid 1px;font-size:12px" id="map"></p>
在前台查看时,一切正常。但再次进入编辑页面时,可能会发现某些字符被过滤,如`title`、`script`等,导致地图显示失效。同样地,我们需要修改上述提到的过滤字段列表:
$ra1 = array('javascript', 'vbscript', 'expression', 'applet', 'meta', 'xml', 'blink', 'link', 'style', 'script', 'embed', 'object', 'iframe', 'frame', 'frameset', 'ilayer', 'layer', 'bgsound', 'title', 'base');
$val = preg_replace('/([-,-,-])/', '', $val);
$val = preg_replace('/([-|-|-])/', '', $val);
总结来说,对于样式乱码问题,修改`include/helpers/filter.helper.php`文件中的过滤字段即可;对于百度地图JS失效问题,除了删除相关字段外,还需要注意逗号的过滤问题。希望这篇文章能帮助您更好地理解和解决Dedecms中的这些问题。
相关文章
-
在网站建设与维护的过程中,优化代码结构和功能是提升网站性能的重要步骤。本文将介绍如何通过自定义函数实现文章删除时自动清理相关资源的功能,从而提高系统的整洁性和存储效率。以下是具体的操作步骤及代码实现。首先, 在 `/include` 目录下创建一个名为 `extend.func.php` 的文件...2025-03-31
-
在进行图片上传操作时,用户可能会遇到302错误以及带有ERROR提示的图片上传失败问题。这些问题可能由多种原因引发,因此本文将对这些情况进行整理,以帮助大家更有效地定位并解决问题。 第一种情况:图片文件本身损坏。 这种情况会导致系统返回ERROR错误提示,不过发生概率较低。如果怀疑是图片损坏导致的...2025-03-31
-
如果您正在寻找一种高效的方法来使用Dedecms模板搭建网站或论坛,那么本文将为您提供详尽的指导。从模板解压到最终完成配置,每一步都将清晰呈现,帮助您快速掌握整个流程。 第一步:解压Dedecms模板 将下载的Dedecms模板文件解压出来,确保所有文件完整无误。如下图所示: 第二步:获取D...2025-03-31
-
Dedecms Dede 附加表自定义字段与主表文章关联方法
在使用DedeCMS开发装修网站时,设计师和设计作品之间的关联是一个重要的功能需求。通常情况下,文章(作品)的内容部分存储在主表dede_addonarticle中,而自定义字段则存储在附加表dede_archives中。为了实现这一功能,可以采用以下两种方法。 ① 根据发布人调用相关文章; ...2025-03-31