DedeCMS自定义表单出现“数据校验证不对,程序返回”的解决方案
我们在用DedeCMS自定义表单功能的时候,一般都是在本地测试,成功后再上传到空间实测,织梦铺说过如何为DedeCMS的自定义表单添加验证码之后,把自定义表单备份在空间还原之后,在提交表单的时候却提示“数据校验不对,程序返回 ”,在自定义表单中点击发布信息却并没有这个问题,一切正常。
织梦铺排查一番,终于找出原因,原来自定义表单中中有一个dede_fieldshash值,它的value值是唯一的,每个网站都有单独的value值,这里报错就是因为这个问题,比如如下代码:
<input type="hidden" name="dede_fields" value="bt,text;xgsm,multitext;lxr,text;xb,radio;dwmc,textchar;xxdz,textchar;yzbm,text;lxdh,text;czhm,text;sjhm,text;dzxx,text"/>
<input type="hidden" name="dede_fieldshash" value="497900ecbac58b031af0c80e589e7649"/>
value值为:497900ecbac58b031af0c80e589e7649,网站转移之后这个值也会变化,织梦铺并没有及时修改这个值,导致出错,那么怎么找到这个值呢?
很简单,打开后台-核心-频道模型-自定义表单
找到自己设置好的自定义表单,点击“前台预览”
如果提示前台预览关闭,则点击“修改”,将“前台列表和内容也公开”选项勾选为“完全公开”。
在预览自定义表单界面点击右上角的“发布信息”
即可到信息发布的页面,查看源代码,找到“ dede_fieldshash”,后面的value值即为我们需要的新的值,放到自己的模版中即可解决“数据校验不对”的报错问题,再去提交表单则提示成功。
dedecms数据校验不对,程序返回解决方法
根据提示去检查一下几个程序文件:
1:/plus/diy.php 文件是否存在,是否对应。
2::<input name=’sex’ id=’sex’ type=”text” /> name,id,type,是否和后台自定义表单对应。
3:value值是否和后台自定义表单一致,如果不一直,就复制前台预览中的代码。
4:代码后面的value值是唯一,每个网站有单独的value值,所以也需要复制前台预览的网址代码值。
解决办法:
1:<form action=”/plus/diy.php” enctype=”multipart/form-data” method=”post”>
plus/diy.php文件是否存在,是否对应。
2:<input name=’sex’ id=’sex’ type=”text” class=”ipt”/>
name,id,type,是否和后台自定义表单对应。
3:<input type=”hidden” name=”dede_fields” value=”name,text;sex,radio;tel,text;pro,select;dizhi,text;note,htmltext;mail,text” />
value值是否和后台自定义表单一致,如果不一致,就复制前台预览的网址代码。
4: <input type=”hidden” name=”dede_fieldshash” value=”5b6ddc6659f6278add0ebd009229f7cb” />
这段代码后面的value值是唯一,每个网站有单独的value值,所以也需要复制前台预览的网址代码值。
value值查找办法:
<input type=”hidden” name=”dede_fieldshash” value=”33a0260e10c5209c22d60e6cb3e8befa” />
就是里面的那个value=”33a0260e10c5209c22d60e6cb3e8befa”,这个值有问题。
在自定义表单增加网所有字段后,点击“前台预览”——>点“发布信息”——>查看页面源文件,就能看到一个完整的form表单,将它拷贝出来。
这里面就有那个value值,这里便是正确的了,覆盖掉代码里的那个就可以了,在提交表单就再也没有错误提示了,成功提交预订了。
而且这个字,你如果修改了自定义表单中的字段类型或者增加字段什么的,都会发生变化。那你就都要到前台预览中获取源码中的这个hash值。
Dedecms提示“数据校验不对”错误解决方法
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)."\" />"; |
网友评论条