Dedecms提示“数据校验不对”是因为我们在进行隐藏表单值进行比较时出现的md5验证错误所提示了,这个做法也是安全所需要了,下文我们不考虑安全问题直接删除指定文件中检测代码,具体如下
单的解决办法:
打开/plus/diy.php,修改第42行到第49行的内容注释掉或删去即可。
代码如下 | |
if(!empty($dede_fields)) { if($dede_fieldshash != md5($dede_fields.$cfg_cookie_encode)) { showMsg('数据校验不对,程序返回', '-1'); exit(); } } |
删掉后,织梦就不会对隐藏表单的值进行验证了 如果我们没用到表单就不会有这问题
如果我们希望做得安全又好,还是把后台的隐藏表单的值与后台自定义表单处织梦给的值改成一致就可以了,提供一些参考排除方法
1:/plus/diy.php 文件是否存在,是否对应。
2::<input name='sex' id='sex' type="text" /> name,id,type,是否和后台自定义表单对应。
3:
value值是否和后台自定义表单一直,如果不一直,就复制前台预览中的代码。
4:
这段代码后面的value值是唯一,每个网站有单独的value值,所以也需要复制前台预览的网址代码值
临时处理方法:
查找
代码如下 | |
function PrintAutoFieldsEdit(&$fieldset, &$fieldValues, $loadtype='all') 在 $dtp = new DedeTagParse(); 之前加入 global $cfg_cookie_encode; 查找 echo "<input type='hidden' name='dede_addonfields' value=\"".$dede_addonfields."\">\r\n"; 在其之后另行一行加入 echo "<input type=\"hidden\" name=\"dede_fieldshash\" value=\"".md5($dede_addonfields.$cfg_cookie_encode)."\" />"; |