当前位置:首页 > 行业动态 > 正文

如何修复DedeCMS中添加变量时出现的Request var not allow!错误?

在织梦DedeCMS中,如果遇到添加变量报错”Request var not allow!“,可以尝试以下解决办法:,,1. 检查配置文件:打开 /include/config.base.php文件,确保 $dedecms{'db_safe_mode'}设置为 false。,,2. 修改代码:在需要添加变量的地方,使用 $this>GetOne('字段名')替换原来的 $_GET['字段名']或 $_POST['字段名']。,,3. 更新缓存:清理系统缓存,重新生成页面。

在织梦DedeCMS中添加变量时遇到“Request var not allow!”的报错,通常是因为系统默认的安全机制阻止了某些变量的添加,为了解决这个问题,可以通过修改系统的配置文件来实现。

如何修复DedeCMS中添加变量时出现的Request var not allow!错误?  第1张

解决办法步骤

1、连接FTP并定位文件:首先通过FTP工具连接到网站的根目录,找到include/common.inc.php文件,这个文件是DedeCMS的核心配置文件之一,用于检查和注册外部提交的变量。

2、编辑文件:下载并在本地编辑器中打开include/common.inc.php文件,查找以下代码段:

“`php

function CheckRequest(&$val) {

if (is_array($val)) {

foreach ($val as $_k=>$_v) {

CheckRequest($_k);

CheckRequest($val[$_k]);

}

} else {

if( strlen($val)>0 && preg_match(‘#^(cfg_|GLOBALS)#’,$val) ) {

exit(‘Request var not allow!’);

}

}

}

“`

3、添加条件判断:在上述代码中,找到if( strlen($val)>0 && preg_match('#^(cfg_|GLOBALS)#',$val) )这一行,在该行之前添加一个条件判断语句,允许特定的变量通过检查,如果你希望允许名为nvarname的变量通过检查,可以修改代码如下:

“`php

function CheckRequest(&$val) {

if (is_array($val)) {

foreach ($val as $_k=>$_v) {

if($_k == ‘nvarname’) continue; // 新增条件判断

CheckRequest($_k);

CheckRequest($val[$_k]);

}

} else {

if( strlen($val)>0 && preg_match(‘#^(cfg_|GLOBALS)#’,$val) ) {

exit(‘Request var not allow!’);

}

}

}

“`

4、保存并上传:完成修改后,保存文件并通过FTP工具上传回服务器,覆盖原有的include/common.inc.php文件。

5、测试添加变量:重新登录DedeCMS后台,尝试再次添加新变量,此时应该不再出现“Request var not allow!”的错误提示。

注意事项

在进行任何文件修改之前,建议先备份原文件,以防万一出现问题时能够快速恢复。

确保你对PHP有一定的了解,避免因错误修改导致系统无法正常运行。

如果不熟悉FTP操作或文件编辑,建议寻求专业人士的帮助。

FAQs

问题1:为什么会出现“Request var not allow!”的报错?

:这个报错通常发生在DedeCMS试图添加一个新变量,但该变量名与系统默认不允许的变量名冲突(如以cfg_、GLOBALS开头的变量),这是DedeCMS的一种安全机制,旨在防止潜在的安全风险。

问题2:除了修改include/common.inc.php文件外,还有其他解决方法吗?

:另一种可能的解决方案是检查你尝试添加的变量名是否合法,避免使用系统保留字或特殊字符作为变量名,如果必须使用特定名称,且该名称被系统限制,那么通过修改include/common.inc.php文件来绕过限制是一种可行的方法,不过,请注意这种做法可能会降低系统的安全性,因此需要谨慎操作。

织梦DedeCMS添加变量报错“Request var not allow!”的解决办法

问题

在使用织梦DedeCMS(简称DedeCMS)进行网站开发时,可能会遇到添加变量时出现“Request var not allow!”的错误,这个错误通常是由于DedeCMS的安全设置导致的。

解决步骤

1、检查安全设置

登录到DedeCMS的后台管理界面。

进入“系统设置”或者“安全设置”模块。

2、查找相关选项

在安全设置中寻找“请求变量过滤”或“请求变量检测”等相关选项。

3、调整设置

如果发现“请求变量过滤”或“请求变量检测”选项被勾选,将其取消勾选。

如果这些选项没有勾选,请检查是否有其他类似的安全设置被误操作导致。

4、确认更改

保存更改并退出设置界面。

5、测试验证

尝试再次添加变量,查看错误是否解决。

可能的原因

安全设置过于严格:DedeCMS的安全设置可能会过于严格,导致正常变量请求也被拦截。

配置文件错误:如果网站配置文件(如config.php)中的相关设置有误,也可能导致此类错误。

注意事项

在修改安全设置之前,请确保备份相关配置文件,以防万一需要恢复。

如果不熟悉DedeCMS的配置,建议在专业人士的指导下进行操作。

通过以上步骤,通常可以解决织梦DedeCMS中“Request var not allow!”的错误,如果问题依然存在,可能需要进一步检查网站配置或联系技术支持。

0