Input类增加path、file、data方法,支持.语法取多维数组的值。

path方法在CI中测试报错,此方法的测试先关闭。
This commit is contained in:
oldrind
2016-01-21 14:39:22 +08:00
parent 4f511dc3e9
commit b8bbf61fb4
3 changed files with 183 additions and 118 deletions

View File

@@ -21,11 +21,12 @@ class Input
* @param string $name 数据名称
* @param string $default 默认值
* @param string $filter 过滤方法
* @param boolean $merge 是否与默认的过虑方法合并
* @return mixed
*/
public static function get($name = '', $default = null, $filter = null)
public static function get($name = '', $default = null, $filter = null, $merge = false)
{
return self::getData($name, $_GET, $filter, $default);
return self::data($name, $default, $filter, $merge, $_GET);
}
/**
@@ -33,11 +34,12 @@ class Input
* @param string $name 数据名称
* @param string $default 默认值
* @param string $filter 过滤方法
* @param boolean $merge 是否与默认的过虑方法合并
* @return mixed
*/
public static function post($name = '', $default = null, $filter = null)
public static function post($name = '', $default = null, $filter = null, $merge = false)
{
return self::getData($name, $_POST, $filter, $default);
return self::data($name, $default, $filter, $merge, $_POST);
}
/**
@@ -45,15 +47,16 @@ class Input
* @param string $name 数据名称
* @param string $default 默认值
* @param string $filter 过滤方法
* @param boolean $merge 是否与默认的过虑方法合并
* @return mixed
*/
public static function put($name = '', $default = null, $filter = null)
public static function put($name = '', $default = null, $filter = null, $merge = false)
{
static $_PUT = null;
if (is_null($_PUT)) {
parse_str(file_get_contents('php://input'), $_PUT);
}
return self::getData($name, $_PUT, $filter, $default);
return self::data($name, $default, $filter, $merge, $_PUT);
}
/**
@@ -61,21 +64,22 @@ class Input
* @param string $name 数据名称
* @param string $default 默认值
* @param string $filter 过滤方法
* @param boolean $merge 是否与默认的过虑方法合并
* @return mixed
*/
public static function param($name = '', $default = null, $filter = null)
public static function param($name = '', $default = null, $filter = null, $merge = false)
{
switch ($_SERVER['REQUEST_METHOD']) {
case 'POST':
$result = self::post($name, $default, $filter);
$method = 'post';
break;
case 'PUT':
$result = self::put($name, $default, $filter);
$method = 'put';
break;
default:
$result = self::get($name, $default, $filter);
$method = 'get';
}
return $result;
return self::$method($name, $default, $filter, $merge);
}
/**
@@ -83,11 +87,12 @@ class Input
* @param string $name 数据名称
* @param string $default 默认值
* @param string $filter 过滤方法
* @param boolean $merge 是否与默认的过虑方法合并
* @return mixed
*/
public static function request($name = '', $default = null, $filter = null)
public static function request($name = '', $default = null, $filter = null, $merge = false)
{
return self::getData($name, $_REQUEST, $filter, $default);
return self::data($name, $default, $filter, $merge, $_REQUEST);
}
/**
@@ -95,11 +100,12 @@ class Input
* @param string $name 数据名称
* @param string $default 默认值
* @param string $filter 过滤方法
* @param boolean $merge 是否与默认的过虑方法合并
* @return mixed
*/
public static function session($name = '', $default = null, $filter = null)
public static function session($name = '', $default = null, $filter = null, $merge = false)
{
return self::getData($name, $_SESSION, $filter, $default);
return self::data($name, $default, $filter, $merge, $_SESSION);
}
/**
@@ -107,11 +113,12 @@ class Input
* @param string $name 数据名称
* @param string $default 默认值
* @param string $filter 过滤方法
* @param boolean $merge 是否与默认的过虑方法合并
* @return mixed
*/
public static function cookie($name = '', $default = null, $filter = null)
public static function cookie($name = '', $default = null, $filter = null, $merge = false)
{
return self::getData($name, $_COOKIE, $filter, $default);
return self::data($name, $default, $filter, $merge, $_COOKIE);
}
/**
@@ -119,11 +126,12 @@ class Input
* @param string $name 数据名称
* @param string $default 默认值
* @param string $filter 过滤方法
* @param boolean $merge 是否与默认的过虑方法合并
* @return mixed
*/
public static function server($name = '', $default = null, $filter = null)
public static function server($name = '', $default = null, $filter = null, $merge = false)
{
return self::getData(strtoupper($name), $_SERVER, $filter, $default);
return self::data(strtoupper($name), $default, $filter, $merge, $_SERVER);
}
/**
@@ -131,11 +139,12 @@ class Input
* @param string $name 数据名称
* @param string $default 默认值
* @param string $filter 过滤方法
* @param boolean $merge 是否与默认的过虑方法合并
* @return mixed
*/
public static function globals($name = '', $default = null, $filter = null)
public static function globals($name = '', $default = null, $filter = null, $merge = false)
{
return self::getData($name, $GLOBALS, $filter, $default);
return self::data($name, $default, $filter, $merge, $GLOBALS);
}
/**
@@ -143,51 +152,93 @@ class Input
* @param string $name 数据名称
* @param string $default 默认值
* @param string $filter 过滤方法
* @param boolean $merge 是否与默认的过虑方法合并
* @return mixed
*/
public static function env($name = '', $default = null, $filter = null)
public static function env($name = '', $default = null, $filter = null, $merge = false)
{
return self::getData(strtoupper($name), $_ENV, $filter, $default);
return self::data(strtoupper($name), $default, $filter, $merge, $_ENV);
}
/**
* 获取PATH_INFO
* @param string $name 数据名称
* @param string $default 默认值
* @param string $filter 过滤方法
* @param boolean $merge 是否与默认的过虑方法合并
* @return mixed
*/
public static function path($name = '', $default = null, $filter = null, $merge = false)
{
if (!empty($_SERVER['PATH_INFO'])) {
$depr = \think\Config::get('pathinfo_depr');
$input = explode($depr, trim($_SERVER['PATH_INFO'], $depr));
return self::data($name, $default, $filter, $merge, $input);
} else {
return $default;
}
}
/**
* 获取$_FILES
* @param string $name 数据名称
* @param string $default 默认值
* @param string $filter 过滤方法
* @param boolean $merge 是否与默认的过虑方法合并
* @return mixed
*/
public static function file($name = '', $default = null, $filter = null, $merge = false)
{
return self::data($name, $default, $filter, $merge, $_FILES);
}
/**
* 获取系统变量 支持过滤和默认值
* @param string $name
* @param array $input
* @param mixed $filter
* @param mixed $default
* @param string $name 字段名
* @param mixed $default 默认值
* @param mixed $filter 过滤函数
* @param boolean $merge 是否与默认的过虑方法合并
* @param array $input 数据源
* @return mixed
*/
public static function getData($name, $input = [], $filter = null, $default = null)
public static function data($name, $default = null, $filter = null, $merge = false, $input = null)
{
// 解析过滤器
$filters = static::parseFilter($filter);
// 为方便传参把默认值附加在过滤器后面
$filters[] = $default;
if (!is_array($input)) {
$data = $default;
} elseif (empty($name)) {
if (is_null($input) && !empty($name)) {
$input = $name;
$name = '';
}
if (!empty($input)) {
$data = $input;
array_walk_recursive($data, 'self::filter', $filters);
} else {
// 解析name
list($name, $type) = static::parseName($name);
if (isset($input[$name])) {
// 过滤name指定的输入
$data = $input[$name];
if (is_array($data)) {
array_walk_recursive($data, 'self::filter', $filters);
} else {
self::filter($data, $name, $filters);
$name = (string) $name;
if ('' != $name) {
// 解析name
list($name, $type) = static::parseName($name);
// 按.拆分成多维数组进行判断
foreach (explode('.', $name) as $val) {
if (isset($data[$val])) {
$data = $data[$val];
} else {
// 无输入数据,返回默认值
return $default;
}
}
if ($data !== $default) {
// 强制类型转换
static::typeCast($data, $type);
}
} else {
// 无输入数据
$data = $default;
}
// 解析过滤器
$filters = static::parseFilter($filter, $merge);
// 为方便传参把默认值附加在过滤器后面
$filters[] = $default;
if (is_array($data)) {
array_walk_recursive($data, 'self::filter', $filters);
} else {
self::filter($data, $name?:0, $filters);
}
if (isset($type) && $data !== $default) {
// 强制类型转换
static::typeCast($data, $type);
}
} else {
$data = $default;
}
return $data;
}
@@ -210,7 +261,7 @@ class Input
* @param string $value
* @return void
*/
protected static function filterExp(&$value)
public static function filterExp(&$value)
{
// TODO 其他安全过滤
@@ -229,36 +280,34 @@ class Input
*/
private static function filter(&$value, $key, $filters)
{
if (!empty($value)) {
// 分离出默认值
$default = array_pop($filters);
foreach ($filters as $filter) {
if (is_callable($filter)) {
// 调用函数过滤
$value = call_user_func($filter, $value);
// 分离出默认值
$default = array_pop($filters);
foreach ($filters as $filter) {
if (is_callable($filter)) {
// 调用函数过滤
$value = call_user_func($filter, $value);
} else {
$begin = substr($filter, 0, 1);
if (in_array($begin, ['/','#','~']) && $begin == $end = substr($filter, -1)) {
// 正则过滤
if (!preg_match($filter, $value)) {
// 匹配不成功返回默认值
$value = $default;
break;
}
} else {
$begin = substr($filter, 0, 1);
if (in_array($begin, ['/','#','~']) && $begin == $end = substr($filter, -1)) {
// 正则过滤
if (!preg_match($filter, $value)) {
// 匹配不成功返回默认值
$value = $default;
break;
}
} else {
// filter函数不存在时, 则使用filter_var进行过滤
// filter为非整形值时, 调用filter_id取得过滤id
$value = filter_var($value, is_int($filter) ? $filter : filter_id($filter));
if (false === $value) {
// 不通过过滤器则返回默认值
$value = $default;
break;
}
// filter函数不存在时, 则使用filter_var进行过滤
// filter为非整形值时, 调用filter_id取得过滤id
$value = filter_var($value, is_int($filter) ? $filter : filter_id($filter));
if (false === $value) {
// 不通过过滤器则返回默认值
$value = $default;
break;
}
}
}
self::filterExp($value);
}
self::filterExp($value);
}
/**
@@ -276,7 +325,7 @@ class Input
* @param mixed $filter
* @return array
*/
private static function parseFilter($filter)
private static function parseFilter($filter, $merge = false)
{
if (is_null($filter)) {
$result = self::getFilter();
@@ -290,10 +339,8 @@ class Input
} else {
$result = [$filter];
}
// 如果最后一项为0或false表示覆盖默认的过滤函数否则为叠加
if (!end($result)) {
array_pop($result);
} else {
if ($merge) {
// 与默认的过滤函数合并
$result = array_merge(self::getFilter(), array_diff($result, self::getFilter()));
}
}