[更新]ThinkPHP版本回退

This commit is contained in:
Anyon 2018-04-12 19:16:53 +08:00
parent 564b2c27db
commit f207ac52eb
28 changed files with 480 additions and 571 deletions

View File

@ -18,7 +18,7 @@
"require": { "require": {
"php": ">=5.6.0", "php": ">=5.6.0",
"endroid/qr-code": "^1.9", "endroid/qr-code": "^1.9",
"topthink/framework": "5.1.*", "topthink/framework": "5.1.8",
"zoujingli/ip2region": "dev-master", "zoujingli/ip2region": "dev-master",
"aliyuncs/oss-sdk-php": "^2.2", "aliyuncs/oss-sdk-php": "^2.2",
"zoujingli/weopen-developer": "dev-master", "zoujingli/weopen-developer": "dev-master",

View File

@ -69,7 +69,6 @@ return [
'chunk not support order' => 'Chunk不支持调用order方法', 'chunk not support order' => 'Chunk不支持调用order方法',
'route pattern error' => '路由变量规则定义错误', 'route pattern error' => '路由变量规则定义错误',
'route behavior will not support' => '路由行为废弃(使用中间件替代)', 'route behavior will not support' => '路由行为废弃(使用中间件替代)',
'closure not support cache(true)' => '使用闭包查询不支持cache(true)请指定缓存Key',
// 上传错误信息 // 上传错误信息
'unknown upload error' => '未知上传错误!', 'unknown upload error' => '未知上传错误!',

View File

@ -20,7 +20,7 @@ use think\route\Dispatch;
*/ */
class App implements \ArrayAccess class App implements \ArrayAccess
{ {
const VERSION = '5.1.9'; const VERSION = '5.1.8';
/** /**
* 当前模块路径 * 当前模块路径
@ -126,7 +126,7 @@ class App implements \ArrayAccess
public function __construct($appPath = '') public function __construct($appPath = '')
{ {
$this->appPath = $appPath ? realpath($appPath) : $this->getAppPath(); $this->appPath = $appPath ?: $this->getAppPath();
$this->container = Container::getInstance(); $this->container = Container::getInstance();
} }
@ -164,7 +164,7 @@ class App implements \ArrayAccess
$this->beginTime = microtime(true); $this->beginTime = microtime(true);
$this->beginMem = memory_get_usage(); $this->beginMem = memory_get_usage();
$this->thinkPath = dirname(dirname(__DIR__)) . DIRECTORY_SEPARATOR; $this->thinkPath = dirname(dirname(__DIR__)) . DIRECTORY_SEPARATOR;
$this->rootPath = dirname($this->appPath) . DIRECTORY_SEPARATOR; $this->rootPath = dirname(realpath($this->appPath)) . DIRECTORY_SEPARATOR;
$this->runtimePath = $this->rootPath . 'runtime' . DIRECTORY_SEPARATOR; $this->runtimePath = $this->rootPath . 'runtime' . DIRECTORY_SEPARATOR;
$this->routePath = $this->rootPath . 'route' . DIRECTORY_SEPARATOR; $this->routePath = $this->rootPath . 'route' . DIRECTORY_SEPARATOR;
$this->configPath = $this->rootPath . 'config' . DIRECTORY_SEPARATOR; $this->configPath = $this->rootPath . 'config' . DIRECTORY_SEPARATOR;
@ -756,7 +756,9 @@ class App implements \ArrayAccess
public function getAppPath() public function getAppPath()
{ {
if (is_null($this->appPath)) { if (is_null($this->appPath)) {
$this->appPath = Loader::getRootPath() . 'application' . DIRECTORY_SEPARATOR; $scriptName = 'cli' == PHP_SAPI ? getcwd() . DIRECTORY_SEPARATOR . $_SERVER['argv'][0] : $_SERVER['SCRIPT_FILENAME'];
$this->appPath = realpath(dirname(dirname($scriptName)) . DIRECTORY_SEPARATOR . 'application') . DIRECTORY_SEPARATOR;
} }
return $this->appPath; return $this->appPath;

View File

@ -15,7 +15,6 @@ namespace think;
* Class Db * Class Db
* @package think * @package think
* @method \think\db\Query connect(array $config =[], mixed $name = false) static 连接/切换数据库连接 * @method \think\db\Query connect(array $config =[], mixed $name = false) static 连接/切换数据库连接
* @method \think\db\Query master() static 从主服务器读取数据
* @method \think\db\Query table(string $table) static 指定数据表(含前缀) * @method \think\db\Query table(string $table) static 指定数据表(含前缀)
* @method \think\db\Query name(string $name) static 指定数据表(不含前缀) * @method \think\db\Query name(string $name) static 指定数据表(不含前缀)
* @method \think\db\Query where(mixed $field, string $op = null, mixed $condition = null) static 查询条件 * @method \think\db\Query where(mixed $field, string $op = null, mixed $condition = null) static 查询条件

View File

@ -52,37 +52,21 @@ class Loader
*/ */
private static $composerPath; private static $composerPath;
// 获取应用根目录
public static function getRootPath()
{
if ('cli' == PHP_SAPI) {
$cwdPath = getcwd();
if (0 === strpos($_SERVER['argv'][0], $cwdPath)) {
$scriptName = $_SERVER['argv'][0];
} else {
$scriptName = $cwdPath . DIRECTORY_SEPARATOR . $_SERVER['argv'][0];
}
} else {
$scriptName = $_SERVER['SCRIPT_FILENAME'];
}
$path = realpath(dirname($scriptName));
if (!is_file($path . DIRECTORY_SEPARATOR . 'think')) {
$path = dirname($path);
}
return $path . DIRECTORY_SEPARATOR;
}
// 注册自动加载机制 // 注册自动加载机制
public static function register($autoload = '') public static function register($autoload = '')
{ {
// 注册系统自动加载 // 注册系统自动加载
spl_autoload_register($autoload ?: 'think\\Loader::autoload', true, true); spl_autoload_register($autoload ?: 'think\\Loader::autoload', true, true);
$rootPath = self::getRootPath(); $scriptName = 'cli' == PHP_SAPI ? getcwd() . DIRECTORY_SEPARATOR . $_SERVER['argv'][0] : $_SERVER['SCRIPT_FILENAME'];
$path = realpath(dirname($scriptName));
if ('cli-server' == PHP_SAPI || !is_file('./think')) {
$rootPath = dirname($path) . DIRECTORY_SEPARATOR;
} else {
$rootPath = $path . DIRECTORY_SEPARATOR;
}
self::$composerPath = $rootPath . 'vendor' . DIRECTORY_SEPARATOR . 'composer' . DIRECTORY_SEPARATOR; self::$composerPath = $rootPath . 'vendor' . DIRECTORY_SEPARATOR . 'composer' . DIRECTORY_SEPARATOR;
@ -354,10 +338,6 @@ class Loader
if (is_file(self::$composerPath . 'autoload_files.php')) { if (is_file(self::$composerPath . 'autoload_files.php')) {
$includeFiles = require self::$composerPath . 'autoload_files.php'; $includeFiles = require self::$composerPath . 'autoload_files.php';
foreach ($includeFiles as $fileIdentifier => $file) { foreach ($includeFiles as $fileIdentifier => $file) {
if (isset($GLOBALS['__composer_autoload_files'][$fileIdentifier])) {
continue;
}
if (empty(self::$autoloadFiles[$fileIdentifier])) { if (empty(self::$autoloadFiles[$fileIdentifier])) {
__require_file($file); __require_file($file);
self::$autoloadFiles[$fileIdentifier] = true; self::$autoloadFiles[$fileIdentifier] = true;

View File

@ -104,12 +104,6 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
*/ */
protected $error; protected $error;
/**
* 软删除字段默认值
* @var mixed
*/
protected $defaultSoftDelete;
/** /**
* 架构函数 * 架构函数
* @access public * @access public
@ -251,8 +245,11 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
if ($useBaseQuery) { if ($useBaseQuery) {
// 软删除 // 软删除
if (method_exists($this, 'withNoTrashed')) { if (method_exists($this, 'getDeleteTimeField')) {
$this->withNoTrashed($query); $field = $this->getDeleteTimeField(true);
if ($field) {
$query->useSoftDelete($field);
}
} }
// 全局作用域 // 全局作用域
@ -472,7 +469,7 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
foreach ((array) $pk as $key) { foreach ((array) $pk as $key) {
if (isset($data[$key])) { if (isset($data[$key])) {
$array[] = [$key, '=', $data[$key]]; $array[$key] = [$key, '=', $data[$key]];
unset($data[$key]); unset($data[$key]);
} }
} }
@ -577,10 +574,10 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
} }
/** /**
* 字段值(延迟)减少 * 字段值(延迟)增长
* @access public * @access public
* @param string $field 字段名 * @param string $field 字段名
* @param integer $step 减少 * @param integer $step 增长
* @param integer $lazyTime 延时时间(s) * @param integer $lazyTime 延时时间(s)
* @return integer|true * @return integer|true
* @throws Exception * @throws Exception

View File

@ -1588,18 +1588,9 @@ class Request
$ip = $_SERVER['REMOTE_ADDR']; $ip = $_SERVER['REMOTE_ADDR'];
} }
// IP地址类型
$ip_mode = (strpos($ip, ':') === false) ? 'ipv4' : 'ipv6';
// IP地址合法验证 // IP地址合法验证
if (filter_var($ip, FILTER_VALIDATE_IP) !== $ip) { $long = sprintf("%u", ip2long($ip));
$ip = ($ip_mode === 'ipv4') ? '0.0.0.0' : '::'; $ip = $long ? [$ip, $long] : ['0.0.0.0', 0];
}
// 如果是ipv4地址则直接使用ip2long返回int类型ip如果是ipv6地址暂时不支持直接返回0
$long_ip = ($ip_mode === 'ipv4') ? sprintf("%u", ip2long($ip)) : 0;
$ip = [$ip, $long_ip];
return $ip[$type]; return $ip[$type];
} }

View File

@ -749,7 +749,7 @@ class Validate
$result = in_array($value, [true, false, 0, 1, '0', '1'], true); $result = in_array($value, [true, false, 0, 1, '0', '1'], true);
break; break;
case 'number': case 'number':
$result = ctype_digit((string) $value); $result = ctype_digit($value);
break; break;
case 'array': case 'array':
// 是否为数组 // 是否为数组

View File

@ -113,7 +113,7 @@ abstract class Builder
$result = []; $result = [];
foreach ($data as $key => $val) { foreach ($data as $key => $val) {
$item = $this->parseKey($query, $key, true); $item = $this->parseKey($query, $key);
if ($val instanceof Expression) { if ($val instanceof Expression) {
$result[$item] = $val->getValue(); $result[$item] = $val->getValue();
@ -183,10 +183,9 @@ abstract class Builder
* @access public * @access public
* @param Query $query 查询对象 * @param Query $query 查询对象
* @param string $key 字段名 * @param string $key 字段名
* @param bool $strict 严格检测
* @return string * @return string
*/ */
public function parseKey(Query $query, $key, $strict = false) public function parseKey(Query $query, $key)
{ {
return $key; return $key;
} }
@ -210,7 +209,7 @@ abstract class Builder
if ($field instanceof Expression) { if ($field instanceof Expression) {
$array[] = $field->getValue(); $array[] = $field->getValue();
} elseif (!is_numeric($key)) { } elseif (!is_numeric($key)) {
$array[] = $this->parseKey($query, $key) . ' AS ' . $this->parseKey($query, $field, true); $array[] = $this->parseKey($query, $key) . ' AS ' . $this->parseKey($query, $field);
} else { } else {
$array[] = $this->parseKey($query, $field); $array[] = $this->parseKey($query, $field);
} }
@ -364,7 +363,7 @@ abstract class Builder
protected function parseWhereItem(Query $query, $field, $val, $rule = '', $binds = [], $bindName = null) protected function parseWhereItem(Query $query, $field, $val, $rule = '', $binds = [], $bindName = null)
{ {
// 字段分析 // 字段分析
$key = $field ? $this->parseKey($query, $field, true) : ''; $key = $field ? $this->parseKey($query, $field) : '';
// 查询规则和条件 // 查询规则和条件
if (!is_array($val)) { if (!is_array($val)) {
@ -809,42 +808,44 @@ abstract class Builder
return ''; return '';
} }
$array = []; if (is_array($order)) {
$array = [];
foreach ($order as $key => $val) { foreach ($order as $key => $val) {
if ($val instanceof Expression) { if ($val instanceof Expression) {
$array[] = $val->getValue(); $array[] = $val->getValue();
} elseif (is_array($val)) { } elseif (is_array($val)) {
if (isset($val['sort'])) { if (isset($val['sort'])) {
$sort = ' ' . $val['sort']; $sort = ' ' . $val['sort'];
unset($val['sort']); unset($val['sort']);
} else {
$sort = '';
}
$options = $query->getOptions();
$bind = $this->connection->getFieldsBind($options['table']);
foreach ($val as $k => $item) {
$val[$k] = $this->parseDataBind($query, $key, $item, $bind, $k);
}
$array[] = 'field(' . $this->parseKey($query, $key) . ',' . implode(',', $val) . ')' . $sort;
} elseif (is_numeric($key)) {
if ('[rand]' == $val) {
$array[] = $this->parseRand($query);
} elseif (false === strpos($val, '(')) {
$array[] = $this->parseKey($query, $val);
} else {
$array[] = $val;
}
} else { } else {
$sort = ''; $sort = in_array(strtolower(trim($val)), ['asc', 'desc']) ? ' ' . $val : '';
$array[] = $this->parseKey($query, $key) . ' ' . $sort;
} }
$options = $query->getOptions();
$bind = $this->connection->getFieldsBind($options['table']);
foreach ($val as $k => $item) {
$val[$k] = $this->parseDataBind($query, $key, $item, $bind, $k);
}
$array[] = 'field(' . $this->parseKey($query, $key, true) . ',' . implode(',', $val) . ')' . $sort;
} elseif ('[rand]' == $val) {
$array[] = $this->parseRand($query);
} else {
if (is_numeric($key)) {
list($key, $sort) = explode(' ', strpos($val, ' ') ? $val : $val . ' ');
} else {
$sort = $val;
}
$sort = in_array(strtolower($sort), ['asc', 'desc'], true) ? ' ' . $sort : '';
$array[] = $this->parseKey($query, $key, true) . $sort;
} }
}
$order = implode(',', $array); $order = implode(',', $array);
}
return ' ORDER BY ' . $order; return ' ORDER BY ' . $order;
} }
@ -949,7 +950,11 @@ abstract class Builder
return ''; return '';
} }
return sprintf(" FORCE INDEX ( %s ) ", is_array($index) ? implode(',', $index) : $index); if (is_array($index)) {
$index = join(",", $index);
}
return sprintf(" FORCE INDEX ( %s ) ", $index);
} }
/** /**
@ -1065,7 +1070,7 @@ abstract class Builder
$fields = []; $fields = [];
foreach ($insertFields as $field) { foreach ($insertFields as $field) {
$fields[] = $this->parseKey($query, $field, true); $fields[] = $this->parseKey($query, $field);
} }
return str_replace( return str_replace(
@ -1097,7 +1102,7 @@ abstract class Builder
} }
foreach ($fields as &$field) { foreach ($fields as &$field) {
$field = $this->parseKey($query, $field, true); $field = $this->parseKey($query, $field);
} }
return 'INSERT INTO ' . $this->parseTable($query, $table, $options) . ' (' . implode(',', $fields) . ') ' . $this->select($options); return 'INSERT INTO ' . $this->parseTable($query, $table, $options) . ' (' . implode(',', $fields) . ') ' . $this->select($options);

View File

@ -2076,7 +2076,7 @@ abstract class Connection
{ {
if (is_scalar($value)) { if (is_scalar($value)) {
$data = $value; $data = $value;
} elseif (is_array($value) && isset($value[1], $value[2]) && in_array($value[1], ['=', 'eq'], true) && is_scalar($value[2])) { } elseif (is_array($value) && isset($value[1], $value[2]) && in_array($value[1], ['=', 'eq'])) {
$data = $value[2]; $data = $value[2];
} }
@ -2089,7 +2089,7 @@ abstract class Connection
try { try {
return md5($prefix . serialize($query->getOptions()) . serialize($query->getBind(false))); return md5($prefix . serialize($query->getOptions()) . serialize($query->getBind(false)));
} catch (\Exception $e) { } catch (\Exception $e) {
throw new Exception('closure not support cache(true)'); return;
} }
} }

View File

@ -1357,7 +1357,7 @@ class Query
public function useSoftDelete($field, $condition = null) public function useSoftDelete($field, $condition = null)
{ {
if ($field) { if ($field) {
$this->options['soft_delete'] = [$field, $condition]; $this->options['soft_delete'] = [$field, $condition ?: ['null', '']];
} }
return $this; return $this;
@ -1447,6 +1447,7 @@ class Query
return $this->parseArrayWhereItems($field, $logic); return $this->parseArrayWhereItems($field, $logic);
} elseif ($field instanceof \Closure) { } elseif ($field instanceof \Closure) {
$where = $field; $where = $field;
$field = '';
} elseif (is_string($field)) { } elseif (is_string($field)) {
if (preg_match('/[,=\<\'\"\(\s]/', $field)) { if (preg_match('/[,=\<\'\"\(\s]/', $field)) {
return $this->whereRaw($field, $op); return $this->whereRaw($field, $op);
@ -1459,7 +1460,11 @@ class Query
} }
if (!empty($where)) { if (!empty($where)) {
$this->options['where'][$logic][] = $where; if (isset($this->options['where'][$logic][$field])) {
$this->options['where'][$logic][] = $where;
} else {
$this->options['where'][$logic][$field] = $where;
}
} }
return $this; return $this;
@ -1485,13 +1490,9 @@ class Query
if (in_array(strtoupper($op), ['NULL', 'NOTNULL', 'NOT NULL'], true)) { if (in_array(strtoupper($op), ['NULL', 'NOTNULL', 'NOT NULL'], true)) {
// null查询 // null查询
$where = [$field, $op, '']; $where = [$field, $op, ''];
} elseif (in_array(strtolower($op), ['=', 'eq', null], true)) {
$where = [$field, 'NULL', ''];
} elseif (in_array(strtolower($op), ['<>', 'neq'], true)) {
$where = [$field, 'NOTNULL', ''];
} else { } else {
// 字段相等查询 // 字段相等查询
$where = [$field, '=', $op]; $where = is_null($op) ? [$field, 'NULL', ''] : [$field, '=', $op];
} }
} else { } else {
$where = $field ? [$field, $op, $condition] : null; $where = $field ? [$field, $op, $condition] : null;
@ -1512,7 +1513,11 @@ class Query
if (key($field) !== 0) { if (key($field) !== 0) {
$where = []; $where = [];
foreach ($field as $key => $val) { foreach ($field as $key => $val) {
$where[] = is_null($val) ? [$key, 'NULL', ''] : [$key, '=', $val]; if (is_null($val)) {
$where[$key] = [$key, 'NULL', ''];
} else {
$where[$key] = !is_scalar($val) ? $val : [$key, '=', $val];
}
} }
} else { } else {
// 数组批量查询 // 数组批量查询
@ -1772,11 +1777,7 @@ class Query
$field = $this->options['via'] . '.' . $field; $field = $this->options['via'] . '.' . $field;
} }
if (strpos($field, ',')) { $field = empty($order) ? $field : [$field => $order];
$field = array_map('trim', explode(',', $field));
} else {
$field = empty($order) ? $field : [$field => $order];
}
} elseif (!empty($this->options['via'])) { } elseif (!empty($this->options['via'])) {
foreach ($field as $key => $val) { foreach ($field as $key => $val) {
if (is_numeric($key)) { if (is_numeric($key)) {

View File

@ -105,10 +105,9 @@ class Mysql extends Builder
* @access public * @access public
* @param Query $query 查询对象 * @param Query $query 查询对象
* @param string $key 字段名 * @param string $key 字段名
* @param bool $strict 严格检测
* @return string * @return string
*/ */
public function parseKey(Query $query, $key, $strict = false) public function parseKey(Query $query, $key)
{ {
if (is_int($key)) { if (is_int($key)) {
return $key; return $key;
@ -119,7 +118,7 @@ class Mysql extends Builder
// JSON字段支持 // JSON字段支持
list($field, $name) = explode('->', $key, 2); list($field, $name) = explode('->', $key, 2);
return 'json_extract(' . $this->parseKey($query, $field) . ', \'$.' . str_replace('->', '.', $name) . '\')'; $key = 'json_extract(' . $this->parseKey($query, $field) . ', \'$.' . str_replace('->', '.', $name) . '\')';
} elseif (strpos($key, '.') && !preg_match('/[,\'\"\(\)`\s]/', $key)) { } elseif (strpos($key, '.') && !preg_match('/[,\'\"\(\)`\s]/', $key)) {
list($table, $key) = explode('.', $key, 2); list($table, $key) = explode('.', $key, 2);
@ -135,7 +134,7 @@ class Mysql extends Builder
} }
} }
if ($strict || !preg_match('/[,\'\"\*\(\)`.\s]/', $key)) { if (!preg_match('/[,\'\"\*\(\)`.\s]/', $key)) {
$key = '`' . $key . '`'; $key = '`' . $key . '`';
} }

View File

@ -51,10 +51,9 @@ class Pgsql extends Builder
* @access public * @access public
* @param Query $query 查询对象 * @param Query $query 查询对象
* @param string $key 字段名 * @param string $key 字段名
* @param bool $strict 严格检测
* @return string * @return string
*/ */
public function parseKey(Query $query, $key, $strict = false) public function parseKey(Query $query, $key)
{ {
$key = trim($key); $key = trim($key);

View File

@ -59,10 +59,9 @@ class Sqlite extends Builder
* @access public * @access public
* @param Query $query 查询对象 * @param Query $query 查询对象
* @param string $key 字段名 * @param string $key 字段名
* @param bool $strict 严格检测
* @return string * @return string
*/ */
public function parseKey(Query $query, $key, $strict = false) public function parseKey(Query $query, $key)
{ {
$key = trim($key); $key = trim($key);
if (strpos($key, '.')) { if (strpos($key, '.')) {

View File

@ -12,7 +12,6 @@
namespace think\db\builder; namespace think\db\builder;
use think\db\Builder; use think\db\Builder;
use think\db\Expression;
use think\db\Query; use think\db\Query;
/** /**
@ -36,30 +35,28 @@ class Sqlsrv extends Builder
*/ */
protected function parseOrder(Query $query, $order) protected function parseOrder(Query $query, $order)
{ {
if (empty($order)) { if (is_array($order)) {
return ' ORDER BY rand()'; $array = [];
}
$array = []; foreach ($order as $key => $val) {
foreach ($order as $key => $val) {
if ($val instanceof Expression) {
$array[] = $val->getValue();
} elseif ('[rand]' == $val) {
$array[] = $this->parseRand($query);
} else {
if (is_numeric($key)) { if (is_numeric($key)) {
list($key, $sort) = explode(' ', strpos($val, ' ') ? $val : $val . ' '); if (false === strpos($val, '(')) {
$array[] = $this->parseKey($query, $val);
} elseif ('[rand]' == $val) {
$array[] = $this->parseRand($query);
} else {
$array[] = $val;
}
} else { } else {
$sort = $val; $sort = in_array(strtolower(trim($val)), ['asc', 'desc']) ? ' ' . $val : '';
$array[] = $this->parseKey($query, $key) . ' ' . $sort;
} }
$sort = in_array(strtolower($sort), ['asc', 'desc'], true) ? ' ' . $sort : '';
$array[] = $this->parseKey($query, $key, true) . $sort;
} }
$order = implode(',', $array);
} }
return ' ORDER BY ' . implode(',', $array); return !empty($order) ? ' ORDER BY ' . $order : ' ORDER BY rand()';
} }
/** /**
@ -78,15 +75,10 @@ class Sqlsrv extends Builder
* @access public * @access public
* @param Query $query 查询对象 * @param Query $query 查询对象
* @param string $key 字段名 * @param string $key 字段名
* @param bool $strict 严格检测
* @return string * @return string
*/ */
public function parseKey(Query $query, $key, $strict = false) public function parseKey(Query $query, $key)
{ {
if (is_int($key)) {
return $key;
}
$key = trim($key); $key = trim($key);
if (strpos($key, '.') && !preg_match('/[,\'\"\(\)\[\s]/', $key)) { if (strpos($key, '.') && !preg_match('/[,\'\"\(\)\[\s]/', $key)) {
@ -104,7 +96,7 @@ class Sqlsrv extends Builder
} }
} }
if ($strict || !preg_match('/[,\'\"\*\(\)\[.\s]/', $key)) { if (!is_numeric($key) && !preg_match('/[,\'\"\*\(\)\[.\s]/', $key)) {
$key = '[' . $key . ']'; $key = '[' . $key . ']';
} }

View File

@ -51,23 +51,11 @@ trait SoftDelete
if ($field) { if ($field) {
return $model return $model
->db(false) ->db(false)
->useSoftDelete($field, $model->getWithTrashedExp()); ->useSoftDelete($field, ['not null', '']);
} }
return $model->db(false); return $model->db(false);
} }
/**
* 获取软删除数据的查询条件
* @access protected
* @return array
*/
protected function getWithTrashedExp()
{
return is_null($this->defaultSoftDelete) ?
['notnull', ''] : ['<>', $this->defaultSoftDelete];
}
/** /**
* 删除当前的记录 * 删除当前的记录
* @access public * @access public
@ -155,17 +143,16 @@ trait SoftDelete
$name = $this->getDeleteTimeField(); $name = $this->getDeleteTimeField();
if (empty($where)) { if (empty($where)) {
$pk = $this->getPk(); $pk = $this->getPk();
$where[$pk] = [$pk, '=', $this->getData($pk)];
$where[] = [$pk, '=', $this->getData($pk)];
} }
if ($name) { if ($name) {
// 恢复删除 // 恢复删除
return $this->db(false) return $this->db(false)
->where($where) ->where($where)
->useSoftDelete($name, $this->getWithTrashedExp()) ->useSoftDelete($name, ['not null', ''])
->update([$name => $this->defaultSoftDelete]); ->update([$name => null]);
} }
return 0; return 0;
@ -196,19 +183,4 @@ trait SoftDelete
return $field; return $field;
} }
/**
* 查询的时候默认排除软删除数据
* @access protected
* @param Query $query
* @return void
*/
protected function withNoTrashed($query)
{
$field = $this->getDeleteTimeField(true);
if ($field) {
$query->useSoftDelete($field, $this->defaultSoftDelete);
}
}
} }

View File

@ -864,7 +864,7 @@ abstract class Rule
$request->route($var); $request->route($var);
// 路由到模块/控制器/操作 // 路由到模块/控制器/操作
return new ModuleDispatch([$module, $controller, $action], [], false); return (new ModuleDispatch([$module, $controller, $action]))->convert(false);
} }
/** /**

View File

@ -316,7 +316,7 @@ class RuleGroup extends Rule
} }
try { try {
if (!empty($regex) && preg_match('/^(?:' . implode('|', $regex) . ')/u', $url, $match)) { if (!empty($regex) && preg_match('/^(?:' . implode('|', $regex) . ')/', $url, $match)) {
$var = []; $var = [];
foreach ($match as $key => $val) { foreach ($match as $key => $val) {
if (is_string($key) && '' !== $val) { if (is_string($key) && '' !== $val) {

View File

@ -309,7 +309,7 @@ class RuleItem extends Rule
$regex = $this->buildRuleRegex($rule, $matches[0], $pattern, $option, $completeMatch); $regex = $this->buildRuleRegex($rule, $matches[0], $pattern, $option, $completeMatch);
try { try {
if (!preg_match('/^' . $regex . ($completeMatch ? '$' : '') . '/u', $url, $match)) { if (!preg_match('/^' . $regex . ($completeMatch ? '$' : '') . '/', $url, $match)) {
return false; return false;
} }
} catch (\Exception $e) { } catch (\Exception $e) {

View File

@ -23,15 +23,6 @@ class Module extends Dispatch
protected $controller; protected $controller;
protected $actionName; protected $actionName;
public function __construct($dispatch, $param = [], $convert = null)
{
$this->app = Container::get('app');
$this->dispatch = $dispatch;
$this->param = $param;
$this->convert = $convert;
$this->init();
}
protected function init() protected function init()
{ {
$result = $this->dispatch; $result = $this->dispatch;
@ -99,13 +90,13 @@ class Module extends Dispatch
// 设置当前请求的控制器、操作 // 设置当前请求的控制器、操作
$this->app['request']->controller(Loader::parseName($this->controller, 1))->action($this->actionName); $this->app['request']->controller(Loader::parseName($this->controller, 1))->action($this->actionName);
// 监听module_init
$this->app['hook']->listen('module_init');
} }
public function run() public function run()
{ {
// 监听module_init
$this->app['hook']->listen('module_init');
// 实例化控制器 // 实例化控制器
try { try {
$instance = $this->app->controller($this->controller, $instance = $this->app->controller($this->controller,

View File

@ -141,7 +141,7 @@ class Php
if ($controller) { if ($controller) {
if ('' == $template) { if ('' == $template) {
// 如果模板文件名为空 按照默认规则定位 // 如果模板文件名为空 按照默认规则定位
$template = str_replace('.', DIRECTORY_SEPARATOR, $controller) . $depr . $this->getActionTemplate($request); $template = str_replace('.', DIRECTORY_SEPARATOR, $controller) . $depr . (1 == $this->config['auto_rule'] ? Loader::parseName($request->action(true)) : $request->action());
} elseif (false === strpos($template, $depr)) { } elseif (false === strpos($template, $depr)) {
$template = str_replace('.', DIRECTORY_SEPARATOR, $controller) . $depr . $template; $template = str_replace('.', DIRECTORY_SEPARATOR, $controller) . $depr . $template;
} }
@ -153,14 +153,6 @@ class Php
return $path . ltrim($template, '/') . '.' . ltrim($this->config['view_suffix'], '.'); return $path . ltrim($template, '/') . '.' . ltrim($this->config['view_suffix'], '.');
} }
protected function getActionTemplate($request)
{
$rule = [$request->action(true), Loader::parseName($request->action(true)), $request->action()];
$type = $this->config['auto_rule'];
return isset($rule[$type]) ? $rule[$type] : $rule[0];
}
/** /**
* 配置模板引擎 * 配置模板引擎
* @access private * @access private

View File

@ -132,11 +132,10 @@ class Think
if (0 !== strpos($template, '/')) { if (0 !== strpos($template, '/')) {
$template = str_replace(['/', ':'], $depr, $template); $template = str_replace(['/', ':'], $depr, $template);
$controller = Loader::parseName($request->controller()); $controller = Loader::parseName($request->controller());
if ($controller) { if ($controller) {
if ('' == $template) { if ('' == $template) {
// 如果模板文件名为空 按照默认规则定位 // 如果模板文件名为空 按照默认规则定位
$template = str_replace('.', DIRECTORY_SEPARATOR, $controller) . $depr . $this->getActionTemplate($request); $template = str_replace('.', DIRECTORY_SEPARATOR, $controller) . $depr . (1 == $this->config['auto_rule'] ? Loader::parseName($request->action(true)) : $request->action());
} elseif (false === strpos($template, $depr)) { } elseif (false === strpos($template, $depr)) {
$template = str_replace('.', DIRECTORY_SEPARATOR, $controller) . $depr . $template; $template = str_replace('.', DIRECTORY_SEPARATOR, $controller) . $depr . $template;
} }
@ -148,14 +147,6 @@ class Think
return $path . ltrim($template, '/') . '.' . ltrim($this->config['view_suffix'], '.'); return $path . ltrim($template, '/') . '.' . ltrim($this->config['view_suffix'], '.');
} }
protected function getActionTemplate($request)
{
$rule = [$request->action(true), Loader::parseName($request->action(true)), $request->action()];
$type = $this->config['auto_rule'];
return isset($rule[$type]) ? $rule[$type] : $rule[0];
}
/** /**
* 配置或者获取模板引擎参数 * 配置或者获取模板引擎参数
* @access private * @access private

2
vendor/autoload.php vendored
View File

@ -4,4 +4,4 @@
require_once __DIR__ . '/composer/autoload_real.php'; require_once __DIR__ . '/composer/autoload_real.php';
return ComposerAutoloaderInitc20a6e9f7e4c957b608b8084ee731eb0::getLoader(); return ComposerAutoloaderInit2549c3dd10544eb5636e5209890b3eea::getLoader();

View File

@ -379,9 +379,9 @@ class ClassLoader
$subPath = substr($subPath, 0, $lastPos); $subPath = substr($subPath, 0, $lastPos);
$search = $subPath.'\\'; $search = $subPath.'\\';
if (isset($this->prefixDirsPsr4[$search])) { if (isset($this->prefixDirsPsr4[$search])) {
$pathEnd = DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $lastPos + 1);
foreach ($this->prefixDirsPsr4[$search] as $dir) { foreach ($this->prefixDirsPsr4[$search] as $dir) {
if (file_exists($file = $dir . $pathEnd)) { $length = $this->prefixLengthsPsr4[$first][$search];
if (file_exists($file = $dir . DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $length))) {
return $file; return $file;
} }
} }

View File

@ -6,6 +6,6 @@ $vendorDir = dirname(dirname(__FILE__));
$baseDir = dirname($vendorDir); $baseDir = dirname($vendorDir);
return array( return array(
'841780ea2e1d6545ea3a253239d59c05' => $vendorDir . '/qiniu/php-sdk/src/Qiniu/functions.php',
'1cfd2761b63b0a29ed23657ea394cb2d' => $vendorDir . '/topthink/think-captcha/src/helper.php', '1cfd2761b63b0a29ed23657ea394cb2d' => $vendorDir . '/topthink/think-captcha/src/helper.php',
'841780ea2e1d6545ea3a253239d59c05' => $vendorDir . '/qiniu/php-sdk/src/Qiniu/functions.php',
); );

View File

@ -2,7 +2,7 @@
// autoload_real.php @generated by Composer // autoload_real.php @generated by Composer
class ComposerAutoloaderInitc20a6e9f7e4c957b608b8084ee731eb0 class ComposerAutoloaderInit2549c3dd10544eb5636e5209890b3eea
{ {
private static $loader; private static $loader;
@ -19,15 +19,15 @@ class ComposerAutoloaderInitc20a6e9f7e4c957b608b8084ee731eb0
return self::$loader; return self::$loader;
} }
spl_autoload_register(array('ComposerAutoloaderInitc20a6e9f7e4c957b608b8084ee731eb0', 'loadClassLoader'), true, true); spl_autoload_register(array('ComposerAutoloaderInit2549c3dd10544eb5636e5209890b3eea', 'loadClassLoader'), true, true);
self::$loader = $loader = new \Composer\Autoload\ClassLoader(); self::$loader = $loader = new \Composer\Autoload\ClassLoader();
spl_autoload_unregister(array('ComposerAutoloaderInitc20a6e9f7e4c957b608b8084ee731eb0', 'loadClassLoader')); spl_autoload_unregister(array('ComposerAutoloaderInit2549c3dd10544eb5636e5209890b3eea', 'loadClassLoader'));
$useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded()); $useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded());
if ($useStaticLoader) { if ($useStaticLoader) {
require_once __DIR__ . '/autoload_static.php'; require_once __DIR__ . '/autoload_static.php';
call_user_func(\Composer\Autoload\ComposerStaticInitc20a6e9f7e4c957b608b8084ee731eb0::getInitializer($loader)); call_user_func(\Composer\Autoload\ComposerStaticInit2549c3dd10544eb5636e5209890b3eea::getInitializer($loader));
} else { } else {
$map = require __DIR__ . '/autoload_namespaces.php'; $map = require __DIR__ . '/autoload_namespaces.php';
foreach ($map as $namespace => $path) { foreach ($map as $namespace => $path) {
@ -48,19 +48,19 @@ class ComposerAutoloaderInitc20a6e9f7e4c957b608b8084ee731eb0
$loader->register(true); $loader->register(true);
if ($useStaticLoader) { if ($useStaticLoader) {
$includeFiles = Composer\Autoload\ComposerStaticInitc20a6e9f7e4c957b608b8084ee731eb0::$files; $includeFiles = Composer\Autoload\ComposerStaticInit2549c3dd10544eb5636e5209890b3eea::$files;
} else { } else {
$includeFiles = require __DIR__ . '/autoload_files.php'; $includeFiles = require __DIR__ . '/autoload_files.php';
} }
foreach ($includeFiles as $fileIdentifier => $file) { foreach ($includeFiles as $fileIdentifier => $file) {
composerRequirec20a6e9f7e4c957b608b8084ee731eb0($fileIdentifier, $file); composerRequire2549c3dd10544eb5636e5209890b3eea($fileIdentifier, $file);
} }
return $loader; return $loader;
} }
} }
function composerRequirec20a6e9f7e4c957b608b8084ee731eb0($fileIdentifier, $file) function composerRequire2549c3dd10544eb5636e5209890b3eea($fileIdentifier, $file)
{ {
if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) { if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) {
require $file; require $file;

View File

@ -4,11 +4,11 @@
namespace Composer\Autoload; namespace Composer\Autoload;
class ComposerStaticInitc20a6e9f7e4c957b608b8084ee731eb0 class ComposerStaticInit2549c3dd10544eb5636e5209890b3eea
{ {
public static $files = array ( public static $files = array (
'841780ea2e1d6545ea3a253239d59c05' => __DIR__ . '/..' . '/qiniu/php-sdk/src/Qiniu/functions.php',
'1cfd2761b63b0a29ed23657ea394cb2d' => __DIR__ . '/..' . '/topthink/think-captcha/src/helper.php', '1cfd2761b63b0a29ed23657ea394cb2d' => __DIR__ . '/..' . '/topthink/think-captcha/src/helper.php',
'841780ea2e1d6545ea3a253239d59c05' => __DIR__ . '/..' . '/qiniu/php-sdk/src/Qiniu/functions.php',
); );
public static $prefixLengthsPsr4 = array ( public static $prefixLengthsPsr4 = array (
@ -258,9 +258,9 @@ class ComposerStaticInitc20a6e9f7e4c957b608b8084ee731eb0
public static function getInitializer(ClassLoader $loader) public static function getInitializer(ClassLoader $loader)
{ {
return \Closure::bind(function () use ($loader) { return \Closure::bind(function () use ($loader) {
$loader->prefixLengthsPsr4 = ComposerStaticInitc20a6e9f7e4c957b608b8084ee731eb0::$prefixLengthsPsr4; $loader->prefixLengthsPsr4 = ComposerStaticInit2549c3dd10544eb5636e5209890b3eea::$prefixLengthsPsr4;
$loader->prefixDirsPsr4 = ComposerStaticInitc20a6e9f7e4c957b608b8084ee731eb0::$prefixDirsPsr4; $loader->prefixDirsPsr4 = ComposerStaticInit2549c3dd10544eb5636e5209890b3eea::$prefixDirsPsr4;
$loader->classMap = ComposerStaticInitc20a6e9f7e4c957b608b8084ee731eb0::$classMap; $loader->classMap = ComposerStaticInit2549c3dd10544eb5636e5209890b3eea::$classMap;
}, null, ClassLoader::class); }, null, ClassLoader::class);
} }

View File

@ -1,32 +1,109 @@
[ [
{ {
"name": "aliyuncs/oss-sdk-php", "name": "topthink/think-installer",
"version": "v2.3.0", "version": "v1.0.12",
"version_normalized": "2.3.0.0", "version_normalized": "1.0.12.0",
"source": { "source": {
"type": "git", "type": "git",
"url": "https://github.com/aliyun/aliyun-oss-php-sdk.git", "url": "https://github.com/top-think/think-installer.git",
"reference": "e69f57916678458642ac9d2fd341ae78a56996c8" "reference": "1be326e68f63de4e95977ed50f46ae75f017556d"
}, },
"dist": { "dist": {
"type": "zip", "type": "zip",
"url": "https://api.github.com/repos/aliyun/aliyun-oss-php-sdk/zipball/e69f57916678458642ac9d2fd341ae78a56996c8", "url": "https://files.phpcomposer.com/files/top-think/think-installer/1be326e68f63de4e95977ed50f46ae75f017556d.zip",
"reference": "e69f57916678458642ac9d2fd341ae78a56996c8", "reference": "1be326e68f63de4e95977ed50f46ae75f017556d",
"shasum": "" "shasum": ""
}, },
"require": { "require": {
"php": ">=5.3" "composer-plugin-api": "^1.0"
}, },
"require-dev": { "require-dev": {
"phpunit/phpunit": "~4.0", "composer/composer": "1.0.*@dev"
"satooshi/php-coveralls": "~1.0"
}, },
"time": "2018-01-08T06:59:35+00:00", "time": "2017-05-27T06:58:09+00:00",
"type": "composer-plugin",
"extra": {
"class": "think\\composer\\Plugin"
},
"installation-source": "dist",
"autoload": {
"psr-4": {
"think\\composer\\": "src"
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"Apache-2.0"
],
"authors": [
{
"name": "yunwuxin",
"email": "448901948@qq.com"
}
]
},
{
"name": "zoujingli/ip2region",
"version": "dev-master",
"version_normalized": "9999999-dev",
"source": {
"type": "git",
"url": "https://github.com/zoujingli/ip2region.git",
"reference": "5d981fbf3b574bad7fe9652e7aecba0920f54325"
},
"dist": {
"type": "zip",
"url": "https://files.phpcomposer.com/files/zoujingli/ip2region/5d981fbf3b574bad7fe9652e7aecba0920f54325.zip",
"reference": "5d981fbf3b574bad7fe9652e7aecba0920f54325",
"shasum": ""
},
"require": {
"php": ">=5.3.3"
},
"time": "2017-11-09T03:36:17+00:00",
"type": "library",
"installation-source": "dist",
"autoload": {
"classmap": [
"Ip2Region.php"
]
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"Apache 2.0"
],
"description": "Ip2Region",
"homepage": "https://github.com/zoujingli/Ip2Region",
"keywords": [
"Ip2Region"
]
},
{
"name": "zoujingli/wechat-developer",
"version": "v1.0.5",
"version_normalized": "1.0.5.0",
"source": {
"type": "git",
"url": "https://github.com/zoujingli/WeChatDeveloper.git",
"reference": "e05fe6bb24438d15259a6af4915bd0638dc3914a"
},
"dist": {
"type": "zip",
"url": "https://files.phpcomposer.com/files/zoujingli/WeChatDeveloper/e05fe6bb24438d15259a6af4915bd0638dc3914a.zip",
"reference": "e05fe6bb24438d15259a6af4915bd0638dc3914a",
"shasum": ""
},
"require": {
"ext-curl": "*",
"ext-openssl": "*",
"php": ">=5.4"
},
"time": "2018-04-09T11:07:00+00:00",
"type": "library", "type": "library",
"installation-source": "dist", "installation-source": "dist",
"autoload": { "autoload": {
"psr-4": { "psr-4": {
"OSS\\": "src/OSS" "WeChat\\": "WeChat"
} }
}, },
"notification-url": "https://packagist.org/downloads/", "notification-url": "https://packagist.org/downloads/",
@ -35,12 +112,216 @@
], ],
"authors": [ "authors": [
{ {
"name": "Aliyuncs", "name": "Anyon",
"homepage": "http://www.aliyun.com" "email": "zoujingli@qq.com",
"homepage": "http://ctolog.com"
} }
], ],
"description": "Aliyun OSS SDK for PHP", "description": "WeChat platform and WeChat payment development tools",
"homepage": "http://www.aliyun.com/product/oss/" "homepage": "https://github.com/zoujingli/WeChatDeveloper",
"keywords": [
"WeChatDeveloper",
"wechat",
"wechatpay"
]
},
{
"name": "zoujingli/weopen-developer",
"version": "dev-master",
"version_normalized": "9999999-dev",
"source": {
"type": "git",
"url": "https://github.com/zoujingli/WeOpenDeveloper.git",
"reference": "8bb75bc08488a43964c00f027b21b93ed58e8d5a"
},
"dist": {
"type": "zip",
"url": "https://files.phpcomposer.com/files/zoujingli/WeOpenDeveloper/8bb75bc08488a43964c00f027b21b93ed58e8d5a.zip",
"reference": "8bb75bc08488a43964c00f027b21b93ed58e8d5a",
"shasum": ""
},
"require": {
"ext-curl": "*",
"ext-openssl": "*",
"php": ">=5.4",
"zoujingli/wechat-developer": "^1.0.0"
},
"time": "2018-03-21T05:06:35+00:00",
"type": "library",
"installation-source": "dist",
"autoload": {
"psr-4": {
"WeOpen\\": "WeOpen"
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Anyon",
"email": "zoujingli@qq.com",
"homepage": "http://ctolog.com"
}
],
"description": "WeChat Open development of SDK",
"homepage": "https://github.com/zoujingli/WeOpenDeveloper",
"keywords": [
"WeChatOpen",
"WeChatOpenDeveloper",
"wechat"
]
},
{
"name": "topthink/framework",
"version": "v5.1.8",
"version_normalized": "5.1.8.0",
"source": {
"type": "git",
"url": "https://github.com/top-think/framework.git",
"reference": "8f6c84abd9e2f9db5a071168c0153724b54b083c"
},
"dist": {
"type": "zip",
"url": "https://files.phpcomposer.com/files/top-think/framework/8f6c84abd9e2f9db5a071168c0153724b54b083c.zip",
"reference": "8f6c84abd9e2f9db5a071168c0153724b54b083c",
"shasum": ""
},
"require": {
"php": ">=5.6.0",
"topthink/think-installer": "~1.0"
},
"require-dev": {
"johnkary/phpunit-speedtrap": "^1.0",
"mikey179/vfsstream": "~1.6",
"phpdocumentor/reflection-docblock": "^2.0",
"phploc/phploc": "2.*",
"phpunit/phpunit": "^5.0|^6.0",
"sebastian/phpcpd": "2.*",
"squizlabs/php_codesniffer": "2.*"
},
"time": "2018-04-06T05:28:49+00:00",
"type": "think-framework",
"installation-source": "dist",
"notification-url": "https://packagist.org/downloads/",
"license": [
"Apache-2.0"
],
"authors": [
{
"name": "liu21st",
"email": "liu21st@gmail.com"
},
{
"name": "yunwuxin",
"email": "448901948@qq.com"
}
],
"description": "the new thinkphp framework",
"homepage": "http://thinkphp.cn/",
"keywords": [
"framework",
"orm",
"thinkphp"
]
},
{
"name": "topthink/think-captcha",
"version": "v2.0.2",
"version_normalized": "2.0.2.0",
"source": {
"type": "git",
"url": "https://github.com/top-think/think-captcha.git",
"reference": "54c8a51552f99ff9ea89ea9c272383a8f738ceee"
},
"dist": {
"type": "zip",
"url": "https://files.phpcomposer.com/files/top-think/think-captcha/54c8a51552f99ff9ea89ea9c272383a8f738ceee.zip",
"reference": "54c8a51552f99ff9ea89ea9c272383a8f738ceee",
"shasum": ""
},
"require": {
"topthink/framework": "5.1.*"
},
"time": "2017-12-31T16:37:49+00:00",
"type": "library",
"installation-source": "dist",
"autoload": {
"psr-4": {
"think\\captcha\\": "src/"
},
"files": [
"src/helper.php"
]
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"Apache-2.0"
],
"authors": [
{
"name": "yunwuxin",
"email": "448901948@qq.com"
}
],
"description": "captcha package for thinkphp5"
},
{
"name": "symfony/options-resolver",
"version": "v3.4.8",
"version_normalized": "3.4.8.0",
"source": {
"type": "git",
"url": "https://github.com/symfony/options-resolver.git",
"reference": "f3109a6aedd20e35c3a33190e932c2b063b7b50e"
},
"dist": {
"type": "zip",
"url": "https://files.phpcomposer.com/files/symfony/options-resolver/f3109a6aedd20e35c3a33190e932c2b063b7b50e.zip",
"reference": "f3109a6aedd20e35c3a33190e932c2b063b7b50e",
"shasum": ""
},
"require": {
"php": "^5.5.9|>=7.0.8"
},
"time": "2018-01-11T07:56:07+00:00",
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "3.4-dev"
}
},
"installation-source": "dist",
"autoload": {
"psr-4": {
"Symfony\\Component\\OptionsResolver\\": ""
},
"exclude-from-classmap": [
"/Tests/"
]
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Fabien Potencier",
"email": "fabien@symfony.com"
},
{
"name": "Symfony Community",
"homepage": "https://symfony.com/contributors"
}
],
"description": "Symfony OptionsResolver Component",
"homepage": "https://symfony.com",
"keywords": [
"config",
"configuration",
"options"
]
}, },
{ {
"name": "endroid/qr-code", "name": "endroid/qr-code",
@ -53,7 +334,7 @@
}, },
"dist": { "dist": {
"type": "zip", "type": "zip",
"url": "https://api.github.com/repos/endroid/qr-code/zipball/c9644bec2a9cc9318e98d1437de3c628dcd1ef93", "url": "https://files.phpcomposer.com/files/endroid/qr-code/c9644bec2a9cc9318e98d1437de3c628dcd1ef93.zip",
"reference": "c9644bec2a9cc9318e98d1437de3c628dcd1ef93", "reference": "c9644bec2a9cc9318e98d1437de3c628dcd1ef93",
"shasum": "" "shasum": ""
}, },
@ -104,6 +385,49 @@
"symfony" "symfony"
] ]
}, },
{
"name": "aliyuncs/oss-sdk-php",
"version": "v2.3.0",
"version_normalized": "2.3.0.0",
"source": {
"type": "git",
"url": "https://github.com/aliyun/aliyun-oss-php-sdk.git",
"reference": "e69f57916678458642ac9d2fd341ae78a56996c8"
},
"dist": {
"type": "zip",
"url": "https://files.phpcomposer.com/files/aliyun/aliyun-oss-php-sdk/e69f57916678458642ac9d2fd341ae78a56996c8.zip",
"reference": "e69f57916678458642ac9d2fd341ae78a56996c8",
"shasum": ""
},
"require": {
"php": ">=5.3"
},
"require-dev": {
"phpunit/phpunit": "~4.0",
"satooshi/php-coveralls": "~1.0"
},
"time": "2018-01-08T06:59:35+00:00",
"type": "library",
"installation-source": "dist",
"autoload": {
"psr-4": {
"OSS\\": "src/OSS"
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Aliyuncs",
"homepage": "http://www.aliyun.com"
}
],
"description": "Aliyun OSS SDK for PHP",
"homepage": "http://www.aliyun.com/product/oss/"
},
{ {
"name": "qiniu/php-sdk", "name": "qiniu/php-sdk",
"version": "v7.2.3", "version": "v7.2.3",
@ -115,7 +439,7 @@
}, },
"dist": { "dist": {
"type": "zip", "type": "zip",
"url": "https://api.github.com/repos/qiniu/php-sdk/zipball/67852ba9cdd7f48e0e080961abebafee134fb329", "url": "https://files.phpcomposer.com/files/qiniu/php-sdk/67852ba9cdd7f48e0e080961abebafee134fb329.zip",
"reference": "67852ba9cdd7f48e0e080961abebafee134fb329", "reference": "67852ba9cdd7f48e0e080961abebafee134fb329",
"shasum": "" "shasum": ""
}, },
@ -156,329 +480,5 @@
"sdk", "sdk",
"storage" "storage"
] ]
},
{
"name": "symfony/options-resolver",
"version": "v3.4.8",
"version_normalized": "3.4.8.0",
"source": {
"type": "git",
"url": "https://github.com/symfony/options-resolver.git",
"reference": "f3109a6aedd20e35c3a33190e932c2b063b7b50e"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/symfony/options-resolver/zipball/f3109a6aedd20e35c3a33190e932c2b063b7b50e",
"reference": "f3109a6aedd20e35c3a33190e932c2b063b7b50e",
"shasum": ""
},
"require": {
"php": "^5.5.9|>=7.0.8"
},
"time": "2018-01-11T07:56:07+00:00",
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "3.4-dev"
}
},
"installation-source": "dist",
"autoload": {
"psr-4": {
"Symfony\\Component\\OptionsResolver\\": ""
},
"exclude-from-classmap": [
"/Tests/"
]
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Fabien Potencier",
"email": "fabien@symfony.com"
},
{
"name": "Symfony Community",
"homepage": "https://symfony.com/contributors"
}
],
"description": "Symfony OptionsResolver Component",
"homepage": "https://symfony.com",
"keywords": [
"config",
"configuration",
"options"
]
},
{
"name": "topthink/framework",
"version": "v5.1.9",
"version_normalized": "5.1.9.0",
"source": {
"type": "git",
"url": "https://github.com/top-think/framework.git",
"reference": "fff4acf5727d7f83f059026098c681042db75bb7"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/top-think/framework/zipball/fff4acf5727d7f83f059026098c681042db75bb7",
"reference": "fff4acf5727d7f83f059026098c681042db75bb7",
"shasum": ""
},
"require": {
"php": ">=5.6.0",
"topthink/think-installer": "~1.0"
},
"require-dev": {
"johnkary/phpunit-speedtrap": "^1.0",
"mikey179/vfsstream": "~1.6",
"phpdocumentor/reflection-docblock": "^2.0",
"phploc/phploc": "2.*",
"phpunit/phpunit": "^5.0|^6.0",
"sebastian/phpcpd": "2.*",
"squizlabs/php_codesniffer": "2.*"
},
"time": "2018-04-12T08:33:20+00:00",
"type": "think-framework",
"installation-source": "dist",
"notification-url": "https://packagist.org/downloads/",
"license": [
"Apache-2.0"
],
"authors": [
{
"name": "liu21st",
"email": "liu21st@gmail.com"
},
{
"name": "yunwuxin",
"email": "448901948@qq.com"
}
],
"description": "the new thinkphp framework",
"homepage": "http://thinkphp.cn/",
"keywords": [
"framework",
"orm",
"thinkphp"
]
},
{
"name": "topthink/think-captcha",
"version": "v2.0.2",
"version_normalized": "2.0.2.0",
"source": {
"type": "git",
"url": "https://github.com/top-think/think-captcha.git",
"reference": "54c8a51552f99ff9ea89ea9c272383a8f738ceee"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/top-think/think-captcha/zipball/54c8a51552f99ff9ea89ea9c272383a8f738ceee",
"reference": "54c8a51552f99ff9ea89ea9c272383a8f738ceee",
"shasum": ""
},
"require": {
"topthink/framework": "5.1.*"
},
"time": "2017-12-31T16:37:49+00:00",
"type": "library",
"installation-source": "dist",
"autoload": {
"psr-4": {
"think\\captcha\\": "src/"
},
"files": [
"src/helper.php"
]
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"Apache-2.0"
],
"authors": [
{
"name": "yunwuxin",
"email": "448901948@qq.com"
}
],
"description": "captcha package for thinkphp5"
},
{
"name": "topthink/think-installer",
"version": "v1.0.12",
"version_normalized": "1.0.12.0",
"source": {
"type": "git",
"url": "https://github.com/top-think/think-installer.git",
"reference": "1be326e68f63de4e95977ed50f46ae75f017556d"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/top-think/think-installer/zipball/1be326e68f63de4e95977ed50f46ae75f017556d",
"reference": "1be326e68f63de4e95977ed50f46ae75f017556d",
"shasum": ""
},
"require": {
"composer-plugin-api": "^1.0"
},
"require-dev": {
"composer/composer": "1.0.*@dev"
},
"time": "2017-05-27T06:58:09+00:00",
"type": "composer-plugin",
"extra": {
"class": "think\\composer\\Plugin"
},
"installation-source": "dist",
"autoload": {
"psr-4": {
"think\\composer\\": "src"
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"Apache-2.0"
],
"authors": [
{
"name": "yunwuxin",
"email": "448901948@qq.com"
}
]
},
{
"name": "zoujingli/ip2region",
"version": "dev-master",
"version_normalized": "9999999-dev",
"source": {
"type": "git",
"url": "https://github.com/zoujingli/ip2region.git",
"reference": "5d981fbf3b574bad7fe9652e7aecba0920f54325"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/zoujingli/ip2region/zipball/5d981fbf3b574bad7fe9652e7aecba0920f54325",
"reference": "5d981fbf3b574bad7fe9652e7aecba0920f54325",
"shasum": ""
},
"require": {
"php": ">=5.3.3"
},
"time": "2017-11-09T03:36:17+00:00",
"type": "library",
"installation-source": "dist",
"autoload": {
"classmap": [
"Ip2Region.php"
]
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"Apache 2.0"
],
"description": "Ip2Region",
"homepage": "https://github.com/zoujingli/Ip2Region",
"keywords": [
"Ip2Region"
]
},
{
"name": "zoujingli/wechat-developer",
"version": "v1.0.5",
"version_normalized": "1.0.5.0",
"source": {
"type": "git",
"url": "https://github.com/zoujingli/WeChatDeveloper.git",
"reference": "e05fe6bb24438d15259a6af4915bd0638dc3914a"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/zoujingli/WeChatDeveloper/zipball/e05fe6bb24438d15259a6af4915bd0638dc3914a",
"reference": "e05fe6bb24438d15259a6af4915bd0638dc3914a",
"shasum": ""
},
"require": {
"ext-curl": "*",
"ext-openssl": "*",
"php": ">=5.4"
},
"time": "2018-04-09T11:07:00+00:00",
"type": "library",
"installation-source": "dist",
"autoload": {
"psr-4": {
"WeChat\\": "WeChat"
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Anyon",
"email": "zoujingli@qq.com",
"homepage": "http://ctolog.com"
}
],
"description": "WeChat platform and WeChat payment development tools",
"homepage": "https://github.com/zoujingli/WeChatDeveloper",
"keywords": [
"WeChatDeveloper",
"wechat",
"wechatpay"
]
},
{
"name": "zoujingli/weopen-developer",
"version": "dev-master",
"version_normalized": "9999999-dev",
"source": {
"type": "git",
"url": "https://github.com/zoujingli/WeOpenDeveloper.git",
"reference": "8bb75bc08488a43964c00f027b21b93ed58e8d5a"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/zoujingli/WeOpenDeveloper/zipball/8bb75bc08488a43964c00f027b21b93ed58e8d5a",
"reference": "8bb75bc08488a43964c00f027b21b93ed58e8d5a",
"shasum": ""
},
"require": {
"ext-curl": "*",
"ext-openssl": "*",
"php": ">=5.4",
"zoujingli/wechat-developer": "^1.0.0"
},
"time": "2018-03-21T05:06:35+00:00",
"type": "library",
"installation-source": "dist",
"autoload": {
"psr-4": {
"WeOpen\\": "WeOpen"
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Anyon",
"email": "zoujingli@qq.com",
"homepage": "http://ctolog.com"
}
],
"description": "WeChat Open development of SDK",
"homepage": "https://github.com/zoujingli/WeOpenDeveloper",
"keywords": [
"WeChatOpen",
"WeChatOpenDeveloper",
"wechat"
]
} }
] ]