You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
218 lines
6.1 KiB
218 lines
6.1 KiB
6 months ago
|
<?php
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Copyright (c) 2016~2023 https://www.crmeb.com All rights reserved.
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Author: CRMEB Team <admin@crmeb.com>
|
||
|
// +----------------------------------------------------------------------
|
||
|
|
||
|
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');
|
||
|
}
|
||
|
}
|