Filtering and Sanitizing
========================
对用户输入的数据进行过滤/消毒是软件开发的重要组成部分。过分信任或忽略过滤用户输入,可能导致用户访问到未经授权的页面,主要是用户数据,甚至是你应用程序的服务器托管的所有内容。
.. figure:: ../_static/img/sql.png
:align: center
Full image (from xkcd)
:doc:`Phalcon\\Filter <../api/Phalcon_Filter>` 组件提供了一组常用的用于过滤以及处理用户输入数据的助手工具。它提供了一种面像对象的方式来包装PHP filter扩展。
Sanitizing data
---------------
Sanitizing 处理从字符串中移除指定字符,这并不是必须的,需要开发者明确指定。sanitizing后的用户输入数据,能确保应用程序的完整和安全。
.. code-block:: php
sanitize("some(one)@exa\mple.com", "email");
// returns "hello"
$filter->sanitize("hello<<", "string");
// returns "100019"
$filter->sanitize("!100a019", "int");
// returns "100019.01"
$filter->sanitize("!100a019.01a", "float");
Sanitizing from Controllers
---------------------------
你可以在控制器中访问 :doc:`Phalcon\\Filter <../api/Phalcon_Filter>` 对象,当需要访问GET或POST输入数据时(通过request对象)。第一个参数是变量的名称,第二个参数是filter类型。
.. code-block:: php
request->getPost("price", "double");
// Sanitizing email from input
$email = $this->request->getPost("customerEmail", "email");
}
}
Filtering Action Parameters
---------------------------
下面的示例将向你展示如何在controller/action中 sanitize Action的参数:
.. code-block:: php
filter->sanitize($productId, "int");
}
}
Filtering data
--------------
除了sanitizing功能,:doc:`Phalcon\\Filter <../api/Phalcon_Filter>` 还提供了删除或修改输入数据的过滤功能,以生成我们想要的数据。
.. code-block:: php
filter("
Hello
", "striptags");
// returns "Hello"
$filter->filter(" Hello ", "trim");
Filters内置类型
-------------------------
The following are the built-in filters provided by this component:
+-----------+---------------------------------------------------------------------------+
| Name | Description |
+===========+===========================================================================+
| string | Strip tags |
+-----------+---------------------------------------------------------------------------+
| email | Remove all characters except letters, digits and !#$%&*+-/=?^_`{|}~@.[]. |
+-----------+---------------------------------------------------------------------------+
| int | Remove all characters except digits, plus and minus sign. |
+-----------+---------------------------------------------------------------------------+
| float | Remove all characters except digits, dot, plus and minus sign. |
+-----------+---------------------------------------------------------------------------+
| alphanum | Remove all characters except [a-zA-Z0-9] |
+-----------+---------------------------------------------------------------------------+
| striptags | Applies the strip_tags_ function |
+-----------+---------------------------------------------------------------------------+
| trim | Applies the trim_ function |
+-----------+---------------------------------------------------------------------------+
| lower | Applies the strtolower_ function |
+-----------+---------------------------------------------------------------------------+
| upper | Applies the strtoupper_ function |
+-----------+---------------------------------------------------------------------------+
自定义Filters
-------------------------
你可以创建自定义过滤器添加到 :doc:`Phalcon\\Filter <../api/Phalcon_Filter>`。过滤函数可以使用匿名函数的形式:
.. code-block:: php
add('md5', function($value) {
return preg_replace('/[^0-9a-f]/', '', $value);
});
//Sanitize with the "md5" filter
$filtered = $filter->sanitize($possibleMd5, "md5");
或者,如果你愿意,你也可以实现一个过滤器类:
.. code-block:: php
add('ipv4', new IPv4Filter());
//Sanitize with the "ipv4" filter
$filteredIp = $filter->sanitize("127.0.0.1", "ipv4");
Complex Sanitizing and Filtering
--------------------------------
PHP本身也提供了一个极好的filter扩展,查阅文档:`Data Filtering at PHP Documentation`_
Implementing your own Filter
----------------------------
The :doc:`Phalcon\\FilterInterface <../api/Phalcon_FilterInterface>` interface must be implemented to create your own filtering service replacing the one providing by Phalcon.
.. _Data Filtering at PHP Documentation: http://www.php.net/manual/en/book.filter.php
.. _strip_tags: http://www.php.net/manual/en/function.strip-tags.php
.. _trim: http://www.php.net/manual/en/function.trim.php
.. _strtolower: http://www.php.net/manual/en/function.strtolower.php
.. _strtoupper: http://www.php.net/manual/en/function.strtoupper.php