但是通过js来控制并不能从根本上杜绝伪造表单攻击等网络安全问题,服务器端也应该对此采取相应措施。
同时,服务器端再次处理,去重处理接收的json数据
$res_json = $_POST['postJson']; $res_json = str_replace('\\', '', $res_json); $array = json_decode($res_json, true); //if($id == 8261){debug(self :: unique_arr($array));} $array = self :: unique_arr($array);
public function unique_arr($array2D,$stkeep=false,$ndformat=true) { // 判断是否保留一级数组键 (一级数组键可以为非数字) if($stkeep) $stArr = array_keys($array2D); // 判断是否保留二级数组键 (所有二级数组键必须相同) if($ndformat) $ndArr = array_keys(end($array2D)); //降维,也可以用implode,将一维数组转换为用逗号连接的字符串 foreach ($array2D as $v){ $v = join(",",$v); $temp[] = $v; } //去掉重复的字符串,也就是重复的一维数组 $temp = array_unique($temp); //再将拆开的数组重新组装 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; }