// +---------------------------------------------------------------------- namespace app; use Spatie\Macroable\Macroable; /** * Class Request * @package app * @method tokenData() 获取token信息 * @method user(string $key = null) 获取用户信息 * @method uid() 获取用户uid * @method isAdminLogin() 后台登陆状态 * @method adminId() 后台管理员id * @method adminInfo() 后台管理信息 * @method kefuId() 客服id * @method kefuInfo() 客服信息 */ class Request extends \think\Request { use Macroable; /** * 不过滤变量名 * @var array */ protected $except = ['menu_path', 'api_url', 'unique_auth', 'description', 'custom_form', 'content', 'tableField', 'url']; /** * 获取请求的数据 * @param array $params * @param bool $suffix * @param bool $filter * @return array */ public function more(array $params, bool $suffix = false, bool $filter = true): array { $p = []; $i = 0; foreach ($params as $param) { if (!is_array($param)) { $p[$suffix == true ? $i++ : $param] = $this->filterWord(is_string($this->param($param)) ? trim($this->param($param)) : $this->param($param), $filter && !in_array($param, $this->except)); } else { if (!isset($param[1])) $param[1] = null; if (!isset($param[2])) $param[2] = ''; if (is_array($param[0])) { $name = is_array($param[1]) ? $param[0][0] . '/a' : $param[0][0] . '/' . $param[0][1]; $keyName = $param[0][0]; } else { $name = is_array($param[1]) ? $param[0] . '/a' : $param[0]; $keyName = $param[0]; } $p[$suffix == true ? $i++ : ($param[3] ?? $keyName)] = $this->filterWord( is_string($this->param($name, $param[1], $param[2])) ? trim($this->param($name, $param[1], $param[2])) : $this->param($name, $param[1], $param[2]), $filter && !in_array($keyName, $this->except)); } } return $p; } /** * 过滤接受的参数 * @param $str * @param bool $filter * @return array|mixed|string|string[] */ public function filterWord($str, bool $filter = true) { if (!$str || !$filter) return $str; // 把数据过滤 $farr = [ "/<(\\/?)(script|i?frame|style|html|body|title|link|meta|object|\\?|\\%)([^>]*?)>/isU", "/(<[^>]*)on[a-zA-Z]+\s*=([^>]*>)/isU", '/phar/is', "/select|join|where|drop|like|modify|rename|insert|update|table|database|alter|truncate|\'|\/\*|\.\.\/|\.\/|union|into|load_file|outfile/is" ]; if (is_array($str)) { foreach ($str as &$v) { if (is_array($v)) { foreach ($v as &$vv) { if (!is_array($vv)) { $vv = $this->replaceWord($farr, $vv); } } } else { $v = $this->replaceWord($farr, $v); } } } else { $str = $this->replaceWord($farr, $str); } return $str; } /** * 替换 * @param $farr * @param $str * @return array|string|string[]|null * @author: 吴汐 * @email: 442384644@qq.com * @date: 2023/9/19 */ public function replaceWord($farr, $str) { if (filter_var($str, FILTER_VALIDATE_URL)) { $url = parse_url($str); if (!isset($url['scheme'])) return $str; $host = $url['scheme'] . '://' . $url['host']; $str = $host . preg_replace($farr, '', str_replace($host, '', $str)); } else { $str = preg_replace($farr, '', $str); } return $str; } /** * 获取get参数 * @param array $params * @param bool $suffix * @param bool $filter * @return array */ public function getMore(array $params, bool $suffix = false, bool $filter = true): array { return $this->more($params, $suffix, $filter); } /** * 获取post参数 * @param array $params * @param bool $suffix * @param bool $filter * @return array */ public function postMore(array $params, bool $suffix = false, bool $filter = true): array { return $this->more($params, $suffix, $filter); } /** * 获取用户访问端 * @return array|string|null */ public function getFromType() { return $this->header('Form-type', ''); } /** * 当前访问端 * @param string $terminal * @return bool */ public function isTerminal(string $terminal) { return strtolower($this->getFromType()) === $terminal; } /** * 是否是H5端 * @return bool */ public function isH5() { return $this->isTerminal('h5'); } /** * 是否是微信端 * @return bool */ public function isWechat() { return $this->isTerminal('wechat'); } /** * 是否是小程序端 * @return bool */ public function isRoutine() { return $this->isTerminal('routine'); } /** * 是否是app端 * @return bool */ public function isApp() { return $this->isTerminal('app'); } /** * 是否是app端 * @return bool */ public function isPc() { return $this->isTerminal('pc'); } }