Files
AtomicOld/api/Request.php

319 lines
9.6 KiB
PHP
Raw Permalink Normal View History

2026-02-14 19:34:54 +03:00
<?php
/**
* Класс-обертка для обращения к переменным _GET, _POST, _FILES
*
* @copyright 2011 Denis Pikusov
* @link http://simplacms.ru
* @author Denis Pikusov
*
*/
require_once('Simpla.php');
class Request extends Simpla
{
/**
* Конструктор, чистка слешей
*/
public function __construct()
{
parent::__construct();
$_POST = $this->stripslashes_recursive($_POST);
$_GET = $this->stripslashes_recursive($_GET);
}
/**
* Определение request-метода обращения к странице (GET, POST)
* Если задан аргумент функции (название метода, в любом регистре), возвращает true или false
* Если аргумент не задан, возвращает имя метода
* Пример:
*
* if($simpla->request->method('post'))
* print 'Request method is POST';
*
*/
public function method($method = null)
{
if(!empty($method))
return strtolower($_SERVER['REQUEST_METHOD']) == strtolower($method);
return $_SERVER['REQUEST_METHOD'];
}
/**
* Возвращает переменную _GET, отфильтрованную по заданному типу, если во втором параметре указан тип фильтра
* Второй параметр $type может иметь такие значения: integer, string, boolean
* Если $type не задан, возвращает переменную в чистом виде
*/
public function get($name, $type = null)
{
$val = null;
if(isset($_GET[$name]))
$val = $_GET[$name];
if(!empty($type) && is_array($val))
$val = reset($val);
if($type == 'string'){
$val = str_replace('/', '', $val);
return strval(preg_replace('/[^\p{L}\p{Nd}\d\s_\-\.\%\S]/ui', '', $val));
//return strval(preg_replace('/[^\p{L}\p{Nd}\d\s_\-\.\%\s]/ui', '', $val));
}
if($type == 'integer')
return intval($val);
if($type == 'boolean')
return !empty($val);
return $val;
}
/**
* Возвращает переменную _POST, отфильтрованную по заданному типу, если во втором параметре указан тип фильтра
* Второй параметр $type может иметь такие значения: integer, string, boolean
* Если $type не задан, возвращает переменную в чистом виде
*/
public function post($name = null, $type = null)
{
$val = null;
if(!empty($name) && isset($_POST[$name]))
$val = $_POST[$name];
elseif(empty($name))
$val = file_get_contents('php://input');
if($type == 'string')
return strval(preg_replace('/[^\p{L}\p{Nd}\d\s_\-\.\%\s]/ui', '', $val));
if($type == 'integer')
return intval($val);
if($type == 'boolean')
return !empty($val);
return $val;
}
/**
* Возвращает переменную _FILES
* Обычно переменные _FILES являются двухмерными массивами, поэтому можно указать второй параметр,
* например, чтобы получить имя загруженного файла: $filename = $simpla->request->files('myfile', 'name');
*/
public function files($name, $name2 = null)
{
if(!empty($name2) && !empty($_FILES[$name][$name2]))
return $_FILES[$name][$name2];
elseif(empty($name2) && !empty($_FILES[$name]))
return $_FILES[$name];
else
return null;
}
/**
* Рекурсивная чистка магических слешей
*/
private function stripslashes_recursive($var)
{
if(get_magic_quotes_gpc())
{
$res = null;
if(is_array($var))
foreach($var as $k=>$v)
$res[stripcslashes($k)] = $this->stripslashes_recursive($v);
else
$res = stripcslashes($var);
}
else
{
$res = $var;
}
return $res;
}
/**
* Проверка сессии
*/
public function check_session()
{
if(!empty($_POST))
{
if(empty($_POST['session_id']) || $_POST['session_id'] != session_id())
{
unset($_POST);
return false;
}
}
return true;
}
/**
* URL
*/
public function url($params = array())
{
$url = parse_url($_SERVER["REQUEST_URI"]);
parse_str($url['query'], $query);
if(0 && get_magic_quotes_gpc())
foreach($query as &$v)
{
if(!is_array($v))
$v = stripslashes(urldecode($v));
}
foreach($params as $name=>$value)
$query[$name] = $value;
$query_is_empty = true;
foreach($query as $name=>$value)
if($value!='' && $value!=null)
$query_is_empty = false;
if(!$query_is_empty)
$url['query'] = http_build_query($query);
else
$url['query'] = null;
$result = http_build_url(null, $url);
return $result;
}
}
if (!function_exists('http_build_url'))
{
define('HTTP_URL_REPLACE', 1); // Replace every part of the first URL when there's one of the second URL
define('HTTP_URL_JOIN_PATH', 2); // Join relative paths
define('HTTP_URL_JOIN_QUERY', 4); // Join query strings
define('HTTP_URL_STRIP_USER', 8); // Strip any user authentication information
define('HTTP_URL_STRIP_PASS', 16); // Strip any password authentication information
define('HTTP_URL_STRIP_AUTH', 32); // Strip any authentication information
define('HTTP_URL_STRIP_PORT', 64); // Strip explicit port numbers
define('HTTP_URL_STRIP_PATH', 128); // Strip complete path
define('HTTP_URL_STRIP_QUERY', 256); // Strip query string
define('HTTP_URL_STRIP_FRAGMENT', 512); // Strip any fragments (#identifier)
define('HTTP_URL_STRIP_ALL', 1024); // Strip anything but scheme and host
// Build an URL
// The parts of the second URL will be merged into the first according to the flags argument.
//
// @param mixed (Part(s) of) an URL in form of a string or associative array like parse_url() returns
// @param mixed Same as the first argument
// @param int A bitmask of binary or'ed HTTP_URL constants (Optional)HTTP_URL_REPLACE is the default
// @param array If set, it will be filled with the parts of the composed url like parse_url() would return
function http_build_url($url, $parts=array(), $flags=HTTP_URL_REPLACE, &$new_url=false)
{
$keys = array('user','pass','port','path','query','fragment');
// HTTP_URL_STRIP_ALL becomes all the HTTP_URL_STRIP_Xs
if ($flags & HTTP_URL_STRIP_ALL)
{
$flags |= HTTP_URL_STRIP_USER;
$flags |= HTTP_URL_STRIP_PASS;
$flags |= HTTP_URL_STRIP_PORT;
$flags |= HTTP_URL_STRIP_PATH;
$flags |= HTTP_URL_STRIP_QUERY;
$flags |= HTTP_URL_STRIP_FRAGMENT;
}
// HTTP_URL_STRIP_AUTH becomes HTTP_URL_STRIP_USER and HTTP_URL_STRIP_PASS
else if ($flags & HTTP_URL_STRIP_AUTH)
{
$flags |= HTTP_URL_STRIP_USER;
$flags |= HTTP_URL_STRIP_PASS;
}
// Parse the original URL
$parse_url = parse_url($url);
// Scheme and Host are always replaced
if (isset($parts['scheme']))
$parse_url['scheme'] = $parts['scheme'];
if (isset($parts['host']))
$parse_url['host'] = $parts['host'];
// (If applicable) Replace the original URL with it's new parts
if ($flags & HTTP_URL_REPLACE)
{
foreach ($keys as $key)
{
if (isset($parts[$key]))
$parse_url[$key] = $parts[$key];
}
}
else
{
// Join the original URL path with the new path
if (isset($parts['path']) && ($flags & HTTP_URL_JOIN_PATH))
{
if (isset($parse_url['path']))
$parse_url['path'] = rtrim(str_replace(basename($parse_url['path']), '', $parse_url['path']), '/') . '/' . ltrim($parts['path'], '/');
else
$parse_url['path'] = $parts['path'];
}
// Join the original query string with the new query string
if (isset($parts['query']) && ($flags & HTTP_URL_JOIN_QUERY))
{
if (isset($parse_url['query']))
$parse_url['query'] .= '&' . $parts['query'];
else
$parse_url['query'] = $parts['query'];
}
}
// Strips all the applicable sections of the URL
// Note: Scheme and Host are never stripped
foreach ($keys as $key)
{
if ($flags & (int)constant('HTTP_URL_STRIP_' . strtoupper($key)))
unset($parse_url[$key]);
}
$new_url = $parse_url;
return
((isset($parse_url['scheme'])) ? $parse_url['scheme'] . '://' : '')
.((isset($parse_url['user'])) ? $parse_url['user'] . ((isset($parse_url['pass'])) ? ':' . $parse_url['pass'] : '') .'@' : '')
.((isset($parse_url['host'])) ? $parse_url['host'] : '')
.((isset($parse_url['port'])) ? ':' . $parse_url['port'] : '')
.((isset($parse_url['path'])) ? $parse_url['path'] : '')
.((isset($parse_url['query'])) ? '?' . $parse_url['query'] : '')
.((isset($parse_url['fragment'])) ? '#' . $parse_url['fragment'] : '')
;
}
}
if(!function_exists('http_build_query')) {
function http_build_query($data,$prefix=null,$sep='',$key='') {
$ret = array();
foreach((array)$data as $k => $v) {
$k = urlencode($k);
if(is_int($k) && $prefix != null) {
$k = $prefix.$k;
};
if(!empty($key)) {
$k = $key."[".$k."]";
};
if(is_array($v) || is_object($v)) {
array_push($ret,http_build_query($v,"",$sep,$k));
}
else {
array_push($ret,$k."=".urlencode($v));
};
};
if(empty($sep)) {
$sep = ini_get("arg_separator.output");
};
return implode($sep, $ret);
};
};