我试图找出最好的消毒方式,并在某种程度上验证发送到我的应用程序的 POST 数据。
我制作了这个驻留在路由器中的函数,并在if($_POST)
存在的 __constructor 中调用:
private function validatePost()
{
foreach($_POST as $key => $value) {
if(preg_match('/[^a-zA-Z]/', $key))
{
$this->throwError('POST Error', 'Invalid index name.');
return;
}
if(strlen($value) > $this->postLimit && $this->postLimit != -1)
{
$this->throwError('POST Error', 'Posted value to large.');
return;
}
if(substr($key, -2, 2) == 'id' && !is_numeric($value))
{
$this->throwError('POST Error', 'Expected a number, didn\'t get one.');
return;
}
else
{
//$value = urlencode($value);
}
$_POST[$key] = $value;
}
}
故意有点严格,但如果我坚持我在整个框架中制定的规则,这并不重要。
我已经读过限制 $_POST 的大小确实有助于阻止某些攻击,在这种情况下,我将 -1 设置为无/默认限制(但如果需要在我的配置文件中将其设置为更少)。
我注释掉了 urlencoding,因为我目前不确定在达到预期功能时解码它的最佳方式。我应该对它进行编码吗?最好的解码方法是什么?也许在Controller
我所有课程都延伸的大师中?
欢迎任何其他建议。