Sfoglia il codice sorgente

添加商城数据管理

Anyon 4 anni fa
parent
commit
47aa0d27b9
47 ha cambiato i file con 1809 aggiunte e 277 eliminazioni
  1. 22 0
      app/data/controller/ShopGoods.php
  2. 130 0
      app/data/controller/ShopGoodsCate.php
  3. 89 0
      app/data/controller/ShopGoodsMark.php
  4. 20 0
      app/data/controller/ShopGoodsSpec.php
  5. 19 0
      app/data/controller/ShopGoodsStock.php
  6. 10 0
      app/data/controller/ShopOrder.php
  7. 24 0
      app/data/service/GoodsService.php
  8. 10 0
      app/data/view/shop_goods/form.html
  9. 10 0
      app/data/view/shop_goods/index.html
  10. 44 0
      app/data/view/shop_goods_cate/form.html
  11. 74 0
      app/data/view/shop_goods_cate/index.html
  12. 30 0
      app/data/view/shop_goods_mark/form.html
  13. 68 0
      app/data/view/shop_goods_mark/index.html
  14. 40 0
      app/data/view/shop_goods_mark/select.html
  15. 10 0
      app/data/view/shop_goods_spec/form.html
  16. 10 0
      app/data/view/shop_goods_spec/index.html
  17. 10 0
      app/data/view/shop_goods_stock/form.html
  18. 10 0
      app/data/view/shop_goods_stock/index.html
  19. 1 1
      composer.json
  20. 501 0
      vendor/composer/autoload_classmap.php
  21. 501 0
      vendor/composer/autoload_static.php
  22. 6 6
      vendor/composer/installed.json
  23. 1 1
      vendor/services.php
  24. 2 2
      vendor/zoujingli/think-library/src/Command.php
  25. 4 4
      vendor/zoujingli/think-library/src/Helper.php
  26. 1 1
      vendor/zoujingli/think-library/src/Library.php
  27. 6 6
      vendor/zoujingli/think-library/src/Storage.php
  28. 1 1
      vendor/zoujingli/think-library/src/common.php
  29. 3 3
      vendor/zoujingli/think-library/src/extend/CodeExtend.php
  30. 6 6
      vendor/zoujingli/think-library/src/extend/DataExtend.php
  31. 5 5
      vendor/zoujingli/think-library/src/extend/HttpExtend.php
  32. 1 1
      vendor/zoujingli/think-library/src/extend/JsonRpcClient.php
  33. 16 28
      vendor/zoujingli/think-library/src/helper/DeleteHelper.php
  34. 15 46
      vendor/zoujingli/think-library/src/helper/FormHelper.php
  35. 10 37
      vendor/zoujingli/think-library/src/helper/PageHelper.php
  36. 12 36
      vendor/zoujingli/think-library/src/helper/SaveHelper.php
  37. 2 2
      vendor/zoujingli/think-library/src/helper/TokenHelper.php
  38. 3 3
      vendor/zoujingli/think-library/src/helper/ValidateHelper.php
  39. 6 6
      vendor/zoujingli/think-library/src/service/AdminService.php
  40. 5 5
      vendor/zoujingli/think-library/src/service/CaptchaService.php
  41. 2 2
      vendor/zoujingli/think-library/src/service/ExpressService.php
  42. 40 44
      vendor/zoujingli/think-library/src/service/ModuleService.php
  43. 14 16
      vendor/zoujingli/think-library/src/service/NodeService.php
  44. 7 7
      vendor/zoujingli/think-library/src/service/ProcessService.php
  45. 1 1
      vendor/zoujingli/think-library/src/service/QueueService.php
  46. 3 3
      vendor/zoujingli/think-library/src/service/SystemService.php
  47. 4 4
      vendor/zoujingli/think-library/src/service/TokenService.php

+ 22 - 0
app/data/controller/ShopGoods.php

@@ -0,0 +1,22 @@
+<?php
+
+namespace app\data\controller;
+
+use think\admin\Controller;
+
+/**
+ * 商品数据管理
+ * Class ShopGoods
+ * @package app\data\controller
+ */
+class ShopGoods extends Controller
+{
+    /**
+     * 绑定数据表
+     * @var string
+     */
+    private $table = 'ShopGoods';
+
+
+
+}

+ 130 - 0
app/data/controller/ShopGoodsCate.php

@@ -0,0 +1,130 @@
+<?php
+
+namespace app\data\controller;
+
+use app\data\service\GoodsService;
+use think\admin\Controller;
+use think\admin\extend\DataExtend;
+
+/**
+ * 商品分类管理
+ * Class ShopGoodsCate
+ * @package app\data\controller
+ */
+class ShopGoodsCate extends Controller
+{
+    /**
+     * 绑定数据表
+     * @var string
+     */
+    private $table = 'ShopGoodsCate';
+
+    /**
+     * 最大分类级别
+     * @var integer
+     */
+    protected $cateLevel;
+
+    /**
+     * 控制器初始化
+     */
+    protected function initialize()
+    {
+        $this->cateLevel = GoodsService::instance()->getCateLevel();
+    }
+
+    /**
+     * 商品分类管理
+     * @auth true
+     * @menu true
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function index()
+    {
+        $this->title = "商品分类管理(最大{$this->cateLevel}级)";
+        $query = $this->_query($this->table);
+        $query->like('name')->equal('status')->dateBetween('create_at');
+        $query->where(['deleted' => 0])->order('sort desc,id desc')->page();
+    }
+
+    /**
+     * 列表数据处理
+     * @param array $data
+     */
+    protected function _index_page_filter(&$data)
+    {
+        foreach ($data as &$vo) {
+            $vo['ids'] = join(',', DataExtend::getArrSubIds($data, $vo['id']));
+        }
+        $data = DataExtend::arr2table($data);
+    }
+
+    /**
+     * 添加商品分类
+     * @auth true
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function add()
+    {
+        $this->_form($this->table, 'form');
+    }
+
+    /**
+     * 编辑商品分类
+     * @auth true
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function edit()
+    {
+        $this->_form($this->table, 'form');
+    }
+
+    /**
+     * 表单数据处理
+     * @param array $data
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    protected function _form_filter(&$data)
+    {
+        if ($this->request->isGet()) {
+            $data['pid'] = intval($data['pid'] ?? input('pid', '0'));
+            $cates = $this->app->db->name($this->table)->where(['deleted' => 0])->order('sort desc,id desc')->select()->toArray();
+            $this->cates = DataExtend::arr2table(array_merge($cates, [['id' => '0', 'pid' => '-1', 'name' => '顶部分类']]));
+            if (isset($data['id'])) foreach ($this->cates as $key => $cate) if ($cate['id'] === $data['id']) $data = $cate;
+            foreach ($this->cates as $key => $cate) if ($cate['spt'] >= $this->cateLevel || (isset($data['spt']) && $data['spt'] <= $cate['spt'])) {
+                unset($this->cates[$key]);
+            }
+        }
+    }
+
+    /**
+     * 修改商品分类状态
+     * @auth true
+     * @throws \think\db\exception\DbException
+     */
+    public function state()
+    {
+        $this->_save($this->table, $this->_vali([
+            'status.in:0,1'  => '状态值范围异常!',
+            'status.require' => '状态值不能为空!',
+        ]));
+    }
+
+    /**
+     * 删除商品分类
+     * @auth true
+     * @throws \think\db\exception\DbException
+     */
+    public function remove()
+    {
+        $this->_delete($this->table);
+    }
+}

+ 89 - 0
app/data/controller/ShopGoodsMark.php

@@ -0,0 +1,89 @@
+<?php
+
+namespace app\data\controller;
+
+use think\admin\Controller;
+
+/**
+ * 商品标签管理
+ * Class ShopGoodsMark
+ * @package app\data\controller
+ */
+class ShopGoodsMark extends Controller
+{
+    /**
+     * 绑定数据表
+     * @var string
+     */
+    private $table = 'ShopGoodsMark';
+
+    /**
+     * 商品标签管理
+     * @auth true
+     * @menu true
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function index()
+    {
+        $this->title = '商品标签管理';
+        $this->_query($this->table)->order('sort desc,id desc')->page();
+    }
+
+    /**
+     * 商品标签选择
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function select()
+    {
+        $this->_query($this->table)->order('sort desc,id desc')->page();
+    }
+
+    /**
+     * 添加商品标签
+     * @auth true
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function add()
+    {
+        $this->_form($this->table, 'form');
+    }
+
+    /**
+     * 编辑商品标签
+     * @auth true
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function edit()
+    {
+        $this->_form($this->table, 'form');
+    }
+
+    /**
+     * 修改商品标签状态
+     * @auth true
+     * @throws \think\db\exception\DbException
+     */
+    public function state()
+    {
+        $this->_save($this->table);
+    }
+
+    /**
+     * 删除商品标签
+     * @auth true
+     * @throws \think\db\exception\DbException
+     */
+    public function remove()
+    {
+        $this->_delete($this->table);
+    }
+
+}

+ 20 - 0
app/data/controller/ShopGoodsSpec.php

@@ -0,0 +1,20 @@
+<?php
+
+namespace app\data\controller;
+
+use think\admin\Controller;
+
+/**
+ * 商品规格管理
+ * Class ShopGoodsSpec
+ * @package app\data\controller
+ */
+class ShopGoodsSpec extends Controller
+{
+    /**
+     * 绑定数据表
+     * @var string
+     */
+    private $table = 'ShopGoodsSpec';
+
+}

+ 19 - 0
app/data/controller/ShopGoodsStock.php

@@ -0,0 +1,19 @@
+<?php
+
+namespace app\data\controller;
+
+use think\admin\Controller;
+
+/**
+ * 商品库存管理
+ * Class ShopGoodsStock
+ * @package app\data\controller
+ */
+class ShopGoodsStock extends Controller
+{
+    /**
+     * 绑定数据表
+     * @var string
+     */
+    private $table = 'ShopGoodsStock';
+}

+ 10 - 0
app/data/controller/ShopOrder.php

@@ -0,0 +1,10 @@
+<?php
+
+namespace app\data\controller;
+
+use think\admin\Controller;
+
+class ShopOrder extends Controller
+{
+
+}

+ 24 - 0
app/data/service/GoodsService.php

@@ -0,0 +1,24 @@
+<?php
+
+namespace app\data\service;
+
+use think\admin\Service;
+
+/**
+ * 商品数据服务
+ * Class GoodsService
+ * @package app\data\service
+ */
+class GoodsService extends Service
+{
+
+    /**
+     * 最大分类级别
+     * @return integer
+     */
+    public function getCateLevel(): int
+    {
+        return 3;
+    }
+
+}

+ 10 - 0
app/data/view/shop_goods/form.html

@@ -0,0 +1,10 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+    <meta charset="UTF-8">
+    <title>Title</title>
+</head>
+<body>
+
+</body>
+</html>

+ 10 - 0
app/data/view/shop_goods/index.html

@@ -0,0 +1,10 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+    <meta charset="UTF-8">
+    <title>Title</title>
+</head>
+<body>
+
+</body>
+</html>

+ 44 - 0
app/data/view/shop_goods_cate/form.html

@@ -0,0 +1,44 @@
+<form class="layui-form layui-card" action="{:request()->url()}" data-auto="true" method="post" autocomplete="off">
+
+    <div class="layui-card-body padding-left-40">
+
+        <label class="layui-form-item relative block">
+            <span class="color-green font-w7 label-required-prev">绑定上级分类</span>
+            <span class="color-desc margin-left-5">Category Parent</span>
+            <select name='pid' class='layui-select' lay-search>
+                {foreach $cates as $cate}
+                {eq name='cate.id' value='$vo.pid|default=0'}
+                <option selected value='{$cate.id}'>{$cate.spl|raw}{$cate.name}</option>
+                {else}
+                <option value='{$cate.id}'>{$cate.spl|raw}{$cate.name}</option>
+                {/eq}{/foreach}
+            </select>
+            <span class="help-block"><b>必选,</b>请选择上级分类或顶级分类(目前最多支持二级分类)</span>
+        </label>
+
+        <label class="layui-form-item relative block">
+            <span class="color-green font-w7 label-required-prev">商品分类名称</span>
+            <span class="color-desc margin-left-5">Category Name</span>
+            <input name="name" value='{$vo.name|default=""}' required placeholder="请输入分类名称" class="layui-input">
+            <span class="help-block"><b>必填,</b>请填写分类名称,建议字符不要太长,一般4-6个汉字(如:系统管理)</span>
+        </label>
+
+        <label class="layui-form-item relative block">
+            <span class="color-green font-w7 label-required-prev">商品分类描述</span>
+            <span class="color-desc margin-left-5">Category Remark</span>
+            <textarea class="layui-textarea" name="remark" placeholder="请输入分类描述">{$vo.remark|default=''}</textarea>
+        </label>
+
+    </div>
+
+    <div class="hr-line-dashed"></div>
+    {notempty name='vo.id'}<input type='hidden' value='{$vo.id}' name='id'>{/notempty}
+
+    <div class="layui-form-item text-center">
+        <button class="layui-btn" type='submit'>保存数据</button>
+        <button class="layui-btn layui-btn-danger" type='button' data-confirm="确定要取消编辑吗?" data-close>取消编辑</button>
+    </div>
+
+    <script>form.render()</script>
+
+</form>

+ 74 - 0
app/data/view/shop_goods_cate/index.html

@@ -0,0 +1,74 @@
+{extend name="../../admin/view/main"}
+
+{block name="button"}
+<!--{if auth("add")}-->
+<button data-modal='{:url("add")}' data-title="添加分类" class='layui-btn layui-btn-sm layui-btn-primary'>添加分类</button>
+<!--{/if}-->
+<!--{if auth("remove")}-->
+<button data-action='{:url("remove")}' data-rule="id#{key}" class='layui-btn layui-btn-sm layui-btn-primary'>删除分类</button>
+<!--{/if}-->
+{/block}
+
+{block name="content"}
+<div class="think-box-shadow table-block">
+    {empty name='list'}
+    <blockquote class="layui-elem-quote">没 有 记 录 哦!</blockquote>
+    {else}
+    <table class="layui-table" lay-skin="line">
+        <thead>
+        <tr>
+            <th class='list-table-check-td think-checkbox'>
+                <label><input data-auto-none data-check-target='.list-check-box' type='checkbox'></label>
+            </th>
+            <th class='list-table-sort-td'>
+                <button type="button" data-reload class="layui-btn layui-btn-xs">刷 新</button>
+            </th>
+            <th class='text-center'></th>
+            <th></th>
+            <th colspan="2"></th>
+        </tr>
+        </thead>
+        <tbody>
+        {foreach $list as $key=>$vo}
+        <tr data-dbclick>
+            <td class='list-table-check-td think-checkbox'>
+                <label><input class="list-check-box" value='{$vo.ids}' type='checkbox'></label>
+            </td>
+            <td class='list-table-sort-td'>
+                <label><input data-action-blur="{:request()->url()}" data-value="id#{$vo.id};action#sort;sort#{value}" data-loading="false" value="{$vo.sort}" class="list-sort-input"></label>
+            </td>
+            <td class="nowrap"><span class="color-desc notselect">{$vo.spl|raw}</span>{$vo.name}</td>
+            <td class="color-desc">{$vo.remark|default=''}</td>
+            <td class='text-center nowrap'>{eq name='vo.status' value='0'}<span class="color-red">已禁用</span>{else}<span class="color-green">使用中</span>{/eq}</td>
+            <td class='text-center nowrap notselect'>
+
+                {if auth("add")}
+                <!--{if $vo.spt < $cateLevel-1}-->
+                <a class="layui-btn layui-btn-xs layui-btn-primary" data-title="添加子分类" data-modal='{:url("add")}?pid={$vo.id}'>添 加</a>
+                <!--{else}-->
+                <a class="layui-btn layui-btn-xs layui-btn-disabled">添 加</a>
+                <!--{/if}-->
+                {/if}
+
+                {if auth("edit")}
+                <a data-dbclick class="layui-btn layui-btn-xs" data-title="编辑分类" data-modal='{:url("edit")}?id={$vo.id}'>编 辑</a>
+                {/if}
+
+                {if $vo.status eq 1 and auth("state")}
+                <a class="layui-btn layui-btn-warm layui-btn-xs" data-confirm="确定要禁用分类吗?" data-action="{:url('state')}" data-value="id#{$vo.ids};status#0" data-csrf="{:systoken('state')}">禁 用</a>
+                {elseif auth("state")}
+                <a class="layui-btn layui-btn-warm layui-btn-xs" data-action="{:url('state')}" data-value="id#{$vo.ids};status#1" data-csrf="{:systoken('state')}">启 用</a>
+                {/if}
+
+                {if auth("remove")}
+                <a class="layui-btn layui-btn-danger layui-btn-xs" data-confirm="确定要删除数据吗?" data-action="{:url('remove')}" data-value="id#{$vo.ids}" data-csrf="{:systoken('remove')}">删 除</a>
+                {/if}
+
+            </td>
+        </tr>
+        {/foreach}
+        </tbody>
+    </table>
+    {/empty}
+</div>
+{/block}

+ 30 - 0
app/data/view/shop_goods_mark/form.html

@@ -0,0 +1,30 @@
+<form class="layui-form layui-card" action="{:request()->url()}" data-auto="true" method="post" autocomplete="off">
+
+    <div class="layui-card-body padding-left-40">
+
+        <label class="layui-form-item relative block">
+            <span class="color-green font-w7">标签名称</span>
+            <span class="color-desc margin-left-5">Label Name</span>
+            <input class="layui-input" required placeholder="请输入标签名称" name="name" value="{$vo.name|default=''}">
+            <span class="help-block"><b>必填,</b>请填写分类名称(如:系统管理),建议字符不要太长,一般4-6个汉字</span>
+        </label>
+
+        <div class="layui-form-item relative block">
+            <span class="color-green font-w7">标签描述</span>
+            <span class="color-desc margin-left-5">Label Remark</span>
+            <label class="relative block">
+                <textarea class="layui-textarea" placeholder="请输入标签描述" name="remark">{$vo.remark|default=''}</textarea>
+            </label>
+        </div>
+
+    </div>
+
+    <div class="hr-line-dashed"></div>
+    {notempty name='vo.id'}<input type='hidden' value='{$vo.id}' name='id'>{/notempty}
+
+    <div class="layui-form-item text-center">
+        <button class="layui-btn" type='submit'>保存数据</button>
+        <button class="layui-btn layui-btn-danger" type='button' data-confirm="确定要取消编辑吗?" data-close>取消编辑</button>
+    </div>
+
+</form>

+ 68 - 0
app/data/view/shop_goods_mark/index.html

@@ -0,0 +1,68 @@
+{extend name="../../admin/view/main"}
+
+{block name="button"}
+<!--{if auth("add")}-->
+<button data-modal='{:url("add")}' data-title="添加标签" class='layui-btn layui-btn-sm layui-btn-primary'>添加标签</button>
+<!--{/if}-->
+<!--{if auth("remove")}-->
+<button data-action='{:url("remove")}' data-rule="id#{key}" data-confirm="确定要删除这些标签吗?" class='layui-btn layui-btn-sm layui-btn-primary'>删除标签</button>
+<!--{/if}-->
+{/block}
+
+{block name='content'}
+<div class="think-box-shadow">
+    <table class="layui-table margin-top-10" lay-skin="line">
+        {notempty name='list'}
+        <thead>
+        <tr>
+            <th class='list-table-check-td think-checkbox'>
+                <label><input data-auto-none data-check-target='.list-check-box' type='checkbox'/></label>
+            </th>
+            <th class='list-table-sort-td'>
+                <button type="button" data-reload class="layui-btn layui-btn-xs">刷 新</button>
+            </th>
+            <th class="text-left nowrap">标签名称</th>
+            <th class="text-left nowrap">标签状态</th>
+            <th class="text-left nowrap">创建时间</th>
+            <th class="text-left nowrap"></th>
+        </tr>
+        </thead>
+        {/notempty}
+        <tbody>
+        {foreach $list as $key=>$vo}
+        <tr data-dbclick>
+            <td class='list-table-check-td think-checkbox'>
+                <label><input class="list-check-box" value='{$vo.id}' type='checkbox'/></label>
+            </td>
+            <td class='list-table-sort-td'>
+                <label><input data-action-blur="{:request()->url()}" data-value="id#{$vo.id};action#sort;sort#{value}" data-loading="false" value="{$vo.sort}" class="list-sort-input"></label>
+            </td>
+            <td class="text-left nowrap">{$vo.name|default=''}</td>
+            <td>{if $vo.status eq 0}<span class="color-red">已禁用</span>{elseif $vo.status eq 1}<span class="color-green">使用中</span>{/if}</td>
+            <td class="text-left nowrap">{$vo.create_at|format_datetime}</td>
+            <td class='text-left nowrap'>
+
+                {if auth("edit")}
+                <a data-dbclick class="layui-btn layui-btn-sm layui-btn-xs" data-title="编辑标签" data-modal="{:url('edit')}?id={$vo.id}">编 辑</a>
+                {/if}
+
+                {if auth("state") and $vo.status eq 1}
+                <a class="layui-btn layui-btn-sm layui-btn-xs layui-btn-warm" data-action="{:url('state')}" data-value="id#{$vo.id};status#0">禁 用</a>
+                {/if}
+
+                {if auth("state") and $vo.status eq 0}
+                <a class="layui-btn layui-btn-sm layui-btn-xs layui-btn-warm" data-action="{:url('state')}" data-value="id#{$vo.id};status#1">启 用</a>
+                {/if}
+
+                {if auth("remove")}
+                <a class="layui-btn layui-btn-xs layui-btn-danger" data-confirm="确定要删除该标签吗?" data-action="{:url('remove')}" data-value="id#{$vo.id}">删 除</a>
+                {/if}
+
+            </td>
+        </tr>
+        {/foreach}
+        </tbody>
+    </table>
+    {empty name='list'}<span class="notdata">没有记录哦</span>{else}{$pagehtml|raw|default=''}{/empty}
+</div>
+{/block}

+ 40 - 0
app/data/view/shop_goods_mark/select.html

@@ -0,0 +1,40 @@
+{extend name="../../admin/view/full"}
+
+{block name='content'}
+<div class="think-box-shadow">
+    <table class="layui-table margin-top-10" lay-skin="line">
+        {notempty name='list'}
+        <thead>
+        <tr>
+            <th class="text-left nowrap">标签名称</th>
+            <th class="text-left nowrap">标签状态</th>
+            <th class="text-left nowrap"></th>
+        </tr>
+        </thead>
+        {/notempty}
+        <tbody>
+        {foreach $list as $key=>$vo}
+        <tr data-dbclick>
+            <td class="text-left nowrap">{$vo.title|default=''}</td>
+            <td>{if $vo.status eq 0}<span class="color-red">已禁用</span>{elseif $vo.status eq 1}<span class="color-green">使用中</span>{/if}</td>
+            <td class='text-left nowrap'><a class="layui-btn layui-btn-sm layui-btn-normal" data-item="{$vo.title}">选 择</a></td>
+        </tr>
+        {/foreach}
+        </tbody>
+    </table>
+    {empty name='list'}<span class="notdata">没有记录哦</span>{else}{$pagehtml|raw|default=''}{/empty}
+</div>
+{/block}
+
+{block name='script'}
+<script>
+    $(function () {
+        layui.form.render();
+        $('[data-article]').on('click', function () {
+            if (top.setItemId) top.setItemId(this.getAttribute('data-item') || '');
+            parent.layer.close(parent.layer.getFrameIndex(window.name));
+        });
+        $.form.reInit($('[data-select-container]'));
+    });
+</script>
+{/block}

+ 10 - 0
app/data/view/shop_goods_spec/form.html

@@ -0,0 +1,10 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+    <meta charset="UTF-8">
+    <title>Title</title>
+</head>
+<body>
+
+</body>
+</html>

+ 10 - 0
app/data/view/shop_goods_spec/index.html

@@ -0,0 +1,10 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+    <meta charset="UTF-8">
+    <title>Title</title>
+</head>
+<body>
+
+</body>
+</html>

+ 10 - 0
app/data/view/shop_goods_stock/form.html

@@ -0,0 +1,10 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+    <meta charset="UTF-8">
+    <title>Title</title>
+</head>
+<body>
+
+</body>
+</html>

+ 10 - 0
app/data/view/shop_goods_stock/index.html

@@ -0,0 +1,10 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+    <meta charset="UTF-8">
+    <title>Title</title>
+</head>
+<body>
+
+</body>
+</html>

+ 1 - 1
composer.json

@@ -28,7 +28,7 @@
     "topthink/framework": "^6.0",
     "topthink/think-view": "^1.0",
     "zoujingli/ip2region": "^1.0",
-    "zoujingli/think-library": "^6.0",
+    "zoujingli/think-library": "v6.0.x-dev",
     "zoujingli/wechat-developer": "^1.2"
   },
   "autoload": {

+ 501 - 0
vendor/composer/autoload_classmap.php

@@ -6,6 +6,507 @@ $vendorDir = dirname(dirname(__FILE__));
 $baseDir = dirname($vendorDir);
 
 return array(
+    'AliPay\\App' => $vendorDir . '/zoujingli/wechat-developer/AliPay/App.php',
+    'AliPay\\Bill' => $vendorDir . '/zoujingli/wechat-developer/AliPay/Bill.php',
+    'AliPay\\Pos' => $vendorDir . '/zoujingli/wechat-developer/AliPay/Pos.php',
+    'AliPay\\Scan' => $vendorDir . '/zoujingli/wechat-developer/AliPay/Scan.php',
+    'AliPay\\Trade' => $vendorDir . '/zoujingli/wechat-developer/AliPay/Trade.php',
+    'AliPay\\Transfer' => $vendorDir . '/zoujingli/wechat-developer/AliPay/Transfer.php',
+    'AliPay\\Wap' => $vendorDir . '/zoujingli/wechat-developer/AliPay/Wap.php',
+    'AliPay\\Web' => $vendorDir . '/zoujingli/wechat-developer/AliPay/Web.php',
+    'Endroid\\QrCode\\Bundle\\Controller\\QrCodeController' => $vendorDir . '/endroid/qr-code/src/Bundle/Controller/QrCodeController.php',
+    'Endroid\\QrCode\\Bundle\\DependencyInjection\\Configuration' => $vendorDir . '/endroid/qr-code/src/Bundle/DependencyInjection/Configuration.php',
+    'Endroid\\QrCode\\Bundle\\DependencyInjection\\EndroidQrCodeExtension' => $vendorDir . '/endroid/qr-code/src/Bundle/DependencyInjection/EndroidQrCodeExtension.php',
+    'Endroid\\QrCode\\Bundle\\EndroidQrCodeBundle' => $vendorDir . '/endroid/qr-code/src/Bundle/EndroidQrCodeBundle.php',
+    'Endroid\\QrCode\\Bundle\\Twig\\Extension\\QrCodeExtension' => $vendorDir . '/endroid/qr-code/src/Bundle/Twig/Extension/QrCodeExtension.php',
+    'Endroid\\QrCode\\Exceptions\\DataDoesntExistsException' => $vendorDir . '/endroid/qr-code/src/Exceptions/DataDoesntExistsException.php',
+    'Endroid\\QrCode\\Exceptions\\FreeTypeLibraryMissingException' => $vendorDir . '/endroid/qr-code/src/Exceptions/FreeTypeLibraryMissingException.php',
+    'Endroid\\QrCode\\Exceptions\\ImageFunctionFailedException' => $vendorDir . '/endroid/qr-code/src/Exceptions/ImageFunctionFailedException.php',
+    'Endroid\\QrCode\\Exceptions\\ImageFunctionUnknownException' => $vendorDir . '/endroid/qr-code/src/Exceptions/ImageFunctionUnknownException.php',
+    'Endroid\\QrCode\\Exceptions\\ImageSizeTooLargeException' => $vendorDir . '/endroid/qr-code/src/Exceptions/ImageSizeTooLargeException.php',
+    'Endroid\\QrCode\\Exceptions\\ImageTypeInvalidException' => $vendorDir . '/endroid/qr-code/src/Exceptions/ImageTypeInvalidException.php',
+    'Endroid\\QrCode\\Exceptions\\VersionTooLargeException' => $vendorDir . '/endroid/qr-code/src/Exceptions/VersionTooLargeException.php',
+    'Endroid\\QrCode\\Factory\\QrCodeFactory' => $vendorDir . '/endroid/qr-code/src/Factory/QrCodeFactory.php',
+    'Endroid\\QrCode\\QrCode' => $vendorDir . '/endroid/qr-code/src/QrCode.php',
     'Ip2Region' => $vendorDir . '/zoujingli/ip2region/Ip2Region.php',
+    'League\\Flysystem\\AdapterInterface' => $vendorDir . '/league/flysystem/src/AdapterInterface.php',
+    'League\\Flysystem\\Adapter\\AbstractAdapter' => $vendorDir . '/league/flysystem/src/Adapter/AbstractAdapter.php',
+    'League\\Flysystem\\Adapter\\AbstractFtpAdapter' => $vendorDir . '/league/flysystem/src/Adapter/AbstractFtpAdapter.php',
+    'League\\Flysystem\\Adapter\\CanOverwriteFiles' => $vendorDir . '/league/flysystem/src/Adapter/CanOverwriteFiles.php',
+    'League\\Flysystem\\Adapter\\Ftp' => $vendorDir . '/league/flysystem/src/Adapter/Ftp.php',
+    'League\\Flysystem\\Adapter\\Ftpd' => $vendorDir . '/league/flysystem/src/Adapter/Ftpd.php',
+    'League\\Flysystem\\Adapter\\Local' => $vendorDir . '/league/flysystem/src/Adapter/Local.php',
+    'League\\Flysystem\\Adapter\\NullAdapter' => $vendorDir . '/league/flysystem/src/Adapter/NullAdapter.php',
+    'League\\Flysystem\\Adapter\\Polyfill\\NotSupportingVisibilityTrait' => $vendorDir . '/league/flysystem/src/Adapter/Polyfill/NotSupportingVisibilityTrait.php',
+    'League\\Flysystem\\Adapter\\Polyfill\\StreamedCopyTrait' => $vendorDir . '/league/flysystem/src/Adapter/Polyfill/StreamedCopyTrait.php',
+    'League\\Flysystem\\Adapter\\Polyfill\\StreamedReadingTrait' => $vendorDir . '/league/flysystem/src/Adapter/Polyfill/StreamedReadingTrait.php',
+    'League\\Flysystem\\Adapter\\Polyfill\\StreamedTrait' => $vendorDir . '/league/flysystem/src/Adapter/Polyfill/StreamedTrait.php',
+    'League\\Flysystem\\Adapter\\Polyfill\\StreamedWritingTrait' => $vendorDir . '/league/flysystem/src/Adapter/Polyfill/StreamedWritingTrait.php',
+    'League\\Flysystem\\Adapter\\SynologyFtp' => $vendorDir . '/league/flysystem/src/Adapter/SynologyFtp.php',
+    'League\\Flysystem\\Cached\\CacheInterface' => $vendorDir . '/league/flysystem-cached-adapter/src/CacheInterface.php',
+    'League\\Flysystem\\Cached\\CachedAdapter' => $vendorDir . '/league/flysystem-cached-adapter/src/CachedAdapter.php',
+    'League\\Flysystem\\Cached\\Storage\\AbstractCache' => $vendorDir . '/league/flysystem-cached-adapter/src/Storage/AbstractCache.php',
+    'League\\Flysystem\\Cached\\Storage\\Adapter' => $vendorDir . '/league/flysystem-cached-adapter/src/Storage/Adapter.php',
+    'League\\Flysystem\\Cached\\Storage\\Memcached' => $vendorDir . '/league/flysystem-cached-adapter/src/Storage/Memcached.php',
+    'League\\Flysystem\\Cached\\Storage\\Memory' => $vendorDir . '/league/flysystem-cached-adapter/src/Storage/Memory.php',
+    'League\\Flysystem\\Cached\\Storage\\Noop' => $vendorDir . '/league/flysystem-cached-adapter/src/Storage/Noop.php',
+    'League\\Flysystem\\Cached\\Storage\\PhpRedis' => $vendorDir . '/league/flysystem-cached-adapter/src/Storage/PhpRedis.php',
+    'League\\Flysystem\\Cached\\Storage\\Predis' => $vendorDir . '/league/flysystem-cached-adapter/src/Storage/Predis.php',
+    'League\\Flysystem\\Cached\\Storage\\Psr6Cache' => $vendorDir . '/league/flysystem-cached-adapter/src/Storage/Psr6Cache.php',
+    'League\\Flysystem\\Cached\\Storage\\Stash' => $vendorDir . '/league/flysystem-cached-adapter/src/Storage/Stash.php',
+    'League\\Flysystem\\Config' => $vendorDir . '/league/flysystem/src/Config.php',
+    'League\\Flysystem\\ConfigAwareTrait' => $vendorDir . '/league/flysystem/src/ConfigAwareTrait.php',
+    'League\\Flysystem\\ConnectionErrorException' => $vendorDir . '/league/flysystem/src/ConnectionErrorException.php',
+    'League\\Flysystem\\ConnectionRuntimeException' => $vendorDir . '/league/flysystem/src/ConnectionRuntimeException.php',
+    'League\\Flysystem\\Directory' => $vendorDir . '/league/flysystem/src/Directory.php',
+    'League\\Flysystem\\Exception' => $vendorDir . '/league/flysystem/src/Exception.php',
+    'League\\Flysystem\\File' => $vendorDir . '/league/flysystem/src/File.php',
+    'League\\Flysystem\\FileExistsException' => $vendorDir . '/league/flysystem/src/FileExistsException.php',
+    'League\\Flysystem\\FileNotFoundException' => $vendorDir . '/league/flysystem/src/FileNotFoundException.php',
+    'League\\Flysystem\\Filesystem' => $vendorDir . '/league/flysystem/src/Filesystem.php',
+    'League\\Flysystem\\FilesystemException' => $vendorDir . '/league/flysystem/src/FilesystemException.php',
+    'League\\Flysystem\\FilesystemInterface' => $vendorDir . '/league/flysystem/src/FilesystemInterface.php',
+    'League\\Flysystem\\FilesystemNotFoundException' => $vendorDir . '/league/flysystem/src/FilesystemNotFoundException.php',
+    'League\\Flysystem\\Handler' => $vendorDir . '/league/flysystem/src/Handler.php',
+    'League\\Flysystem\\InvalidRootException' => $vendorDir . '/league/flysystem/src/InvalidRootException.php',
+    'League\\Flysystem\\MountManager' => $vendorDir . '/league/flysystem/src/MountManager.php',
+    'League\\Flysystem\\NotSupportedException' => $vendorDir . '/league/flysystem/src/NotSupportedException.php',
+    'League\\Flysystem\\PluginInterface' => $vendorDir . '/league/flysystem/src/PluginInterface.php',
+    'League\\Flysystem\\Plugin\\AbstractPlugin' => $vendorDir . '/league/flysystem/src/Plugin/AbstractPlugin.php',
+    'League\\Flysystem\\Plugin\\EmptyDir' => $vendorDir . '/league/flysystem/src/Plugin/EmptyDir.php',
+    'League\\Flysystem\\Plugin\\ForcedCopy' => $vendorDir . '/league/flysystem/src/Plugin/ForcedCopy.php',
+    'League\\Flysystem\\Plugin\\ForcedRename' => $vendorDir . '/league/flysystem/src/Plugin/ForcedRename.php',
+    'League\\Flysystem\\Plugin\\GetWithMetadata' => $vendorDir . '/league/flysystem/src/Plugin/GetWithMetadata.php',
+    'League\\Flysystem\\Plugin\\ListFiles' => $vendorDir . '/league/flysystem/src/Plugin/ListFiles.php',
+    'League\\Flysystem\\Plugin\\ListPaths' => $vendorDir . '/league/flysystem/src/Plugin/ListPaths.php',
+    'League\\Flysystem\\Plugin\\ListWith' => $vendorDir . '/league/flysystem/src/Plugin/ListWith.php',
+    'League\\Flysystem\\Plugin\\PluggableTrait' => $vendorDir . '/league/flysystem/src/Plugin/PluggableTrait.php',
+    'League\\Flysystem\\Plugin\\PluginNotFoundException' => $vendorDir . '/league/flysystem/src/Plugin/PluginNotFoundException.php',
+    'League\\Flysystem\\ReadInterface' => $vendorDir . '/league/flysystem/src/ReadInterface.php',
+    'League\\Flysystem\\RootViolationException' => $vendorDir . '/league/flysystem/src/RootViolationException.php',
+    'League\\Flysystem\\SafeStorage' => $vendorDir . '/league/flysystem/src/SafeStorage.php',
+    'League\\Flysystem\\UnreadableFileException' => $vendorDir . '/league/flysystem/src/UnreadableFileException.php',
+    'League\\Flysystem\\Util' => $vendorDir . '/league/flysystem/src/Util.php',
+    'League\\Flysystem\\Util\\ContentListingFormatter' => $vendorDir . '/league/flysystem/src/Util/ContentListingFormatter.php',
+    'League\\Flysystem\\Util\\MimeType' => $vendorDir . '/league/flysystem/src/Util/MimeType.php',
+    'League\\Flysystem\\Util\\StreamHasher' => $vendorDir . '/league/flysystem/src/Util/StreamHasher.php',
+    'League\\MimeTypeDetection\\EmptyExtensionToMimeTypeMap' => $vendorDir . '/league/mime-type-detection/src/EmptyExtensionToMimeTypeMap.php',
+    'League\\MimeTypeDetection\\ExtensionMimeTypeDetector' => $vendorDir . '/league/mime-type-detection/src/ExtensionMimeTypeDetector.php',
+    'League\\MimeTypeDetection\\ExtensionToMimeTypeMap' => $vendorDir . '/league/mime-type-detection/src/ExtensionToMimeTypeMap.php',
+    'League\\MimeTypeDetection\\FinfoMimeTypeDetector' => $vendorDir . '/league/mime-type-detection/src/FinfoMimeTypeDetector.php',
+    'League\\MimeTypeDetection\\GeneratedExtensionToMimeTypeMap' => $vendorDir . '/league/mime-type-detection/src/GeneratedExtensionToMimeTypeMap.php',
+    'League\\MimeTypeDetection\\MimeTypeDetector' => $vendorDir . '/league/mime-type-detection/src/MimeTypeDetector.php',
+    'Opis\\Closure\\Analyzer' => $vendorDir . '/opis/closure/src/Analyzer.php',
+    'Opis\\Closure\\ClosureContext' => $vendorDir . '/opis/closure/src/ClosureContext.php',
+    'Opis\\Closure\\ClosureScope' => $vendorDir . '/opis/closure/src/ClosureScope.php',
+    'Opis\\Closure\\ClosureStream' => $vendorDir . '/opis/closure/src/ClosureStream.php',
+    'Opis\\Closure\\ISecurityProvider' => $vendorDir . '/opis/closure/src/ISecurityProvider.php',
+    'Opis\\Closure\\ReflectionClosure' => $vendorDir . '/opis/closure/src/ReflectionClosure.php',
+    'Opis\\Closure\\SecurityException' => $vendorDir . '/opis/closure/src/SecurityException.php',
+    'Opis\\Closure\\SecurityProvider' => $vendorDir . '/opis/closure/src/SecurityProvider.php',
+    'Opis\\Closure\\SelfReference' => $vendorDir . '/opis/closure/src/SelfReference.php',
+    'Opis\\Closure\\SerializableClosure' => $vendorDir . '/opis/closure/src/SerializableClosure.php',
+    'Psr\\Cache\\CacheException' => $vendorDir . '/psr/cache/src/CacheException.php',
+    'Psr\\Cache\\CacheItemInterface' => $vendorDir . '/psr/cache/src/CacheItemInterface.php',
+    'Psr\\Cache\\CacheItemPoolInterface' => $vendorDir . '/psr/cache/src/CacheItemPoolInterface.php',
+    'Psr\\Cache\\InvalidArgumentException' => $vendorDir . '/psr/cache/src/InvalidArgumentException.php',
+    'Psr\\Container\\ContainerExceptionInterface' => $vendorDir . '/psr/container/src/ContainerExceptionInterface.php',
+    'Psr\\Container\\ContainerInterface' => $vendorDir . '/psr/container/src/ContainerInterface.php',
+    'Psr\\Container\\NotFoundExceptionInterface' => $vendorDir . '/psr/container/src/NotFoundExceptionInterface.php',
+    'Psr\\Log\\AbstractLogger' => $vendorDir . '/psr/log/Psr/Log/AbstractLogger.php',
+    'Psr\\Log\\InvalidArgumentException' => $vendorDir . '/psr/log/Psr/Log/InvalidArgumentException.php',
+    'Psr\\Log\\LogLevel' => $vendorDir . '/psr/log/Psr/Log/LogLevel.php',
+    'Psr\\Log\\LoggerAwareInterface' => $vendorDir . '/psr/log/Psr/Log/LoggerAwareInterface.php',
+    'Psr\\Log\\LoggerAwareTrait' => $vendorDir . '/psr/log/Psr/Log/LoggerAwareTrait.php',
+    'Psr\\Log\\LoggerInterface' => $vendorDir . '/psr/log/Psr/Log/LoggerInterface.php',
+    'Psr\\Log\\LoggerTrait' => $vendorDir . '/psr/log/Psr/Log/LoggerTrait.php',
+    'Psr\\Log\\NullLogger' => $vendorDir . '/psr/log/Psr/Log/NullLogger.php',
+    'Psr\\Log\\Test\\DummyTest' => $vendorDir . '/psr/log/Psr/Log/Test/DummyTest.php',
+    'Psr\\Log\\Test\\LoggerInterfaceTest' => $vendorDir . '/psr/log/Psr/Log/Test/LoggerInterfaceTest.php',
+    'Psr\\Log\\Test\\TestLogger' => $vendorDir . '/psr/log/Psr/Log/Test/TestLogger.php',
+    'Psr\\SimpleCache\\CacheException' => $vendorDir . '/psr/simple-cache/src/CacheException.php',
+    'Psr\\SimpleCache\\CacheInterface' => $vendorDir . '/psr/simple-cache/src/CacheInterface.php',
+    'Psr\\SimpleCache\\InvalidArgumentException' => $vendorDir . '/psr/simple-cache/src/InvalidArgumentException.php',
+    'Symfony\\Component\\OptionsResolver\\Debug\\OptionsResolverIntrospector' => $vendorDir . '/symfony/options-resolver/Debug/OptionsResolverIntrospector.php',
+    'Symfony\\Component\\OptionsResolver\\Exception\\AccessException' => $vendorDir . '/symfony/options-resolver/Exception/AccessException.php',
+    'Symfony\\Component\\OptionsResolver\\Exception\\ExceptionInterface' => $vendorDir . '/symfony/options-resolver/Exception/ExceptionInterface.php',
+    'Symfony\\Component\\OptionsResolver\\Exception\\InvalidArgumentException' => $vendorDir . '/symfony/options-resolver/Exception/InvalidArgumentException.php',
+    'Symfony\\Component\\OptionsResolver\\Exception\\InvalidOptionsException' => $vendorDir . '/symfony/options-resolver/Exception/InvalidOptionsException.php',
+    'Symfony\\Component\\OptionsResolver\\Exception\\MissingOptionsException' => $vendorDir . '/symfony/options-resolver/Exception/MissingOptionsException.php',
+    'Symfony\\Component\\OptionsResolver\\Exception\\NoConfigurationException' => $vendorDir . '/symfony/options-resolver/Exception/NoConfigurationException.php',
+    'Symfony\\Component\\OptionsResolver\\Exception\\NoSuchOptionException' => $vendorDir . '/symfony/options-resolver/Exception/NoSuchOptionException.php',
+    'Symfony\\Component\\OptionsResolver\\Exception\\OptionDefinitionException' => $vendorDir . '/symfony/options-resolver/Exception/OptionDefinitionException.php',
+    'Symfony\\Component\\OptionsResolver\\Exception\\UndefinedOptionsException' => $vendorDir . '/symfony/options-resolver/Exception/UndefinedOptionsException.php',
+    'Symfony\\Component\\OptionsResolver\\Options' => $vendorDir . '/symfony/options-resolver/Options.php',
+    'Symfony\\Component\\OptionsResolver\\OptionsResolver' => $vendorDir . '/symfony/options-resolver/OptionsResolver.php',
     'We' => $vendorDir . '/zoujingli/wechat-developer/We.php',
+    'WeChat\\Card' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Card.php',
+    'WeChat\\Contracts\\BasicAliPay' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Contracts/BasicAliPay.php',
+    'WeChat\\Contracts\\BasicPushEvent' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Contracts/BasicPushEvent.php',
+    'WeChat\\Contracts\\BasicWeChat' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Contracts/BasicWeChat.php',
+    'WeChat\\Contracts\\BasicWePay' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Contracts/BasicWePay.php',
+    'WeChat\\Contracts\\BasicWeWork' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Contracts/BasicWeWork.php',
+    'WeChat\\Contracts\\DataArray' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Contracts/DataArray.php',
+    'WeChat\\Contracts\\DataError' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Contracts/DataError.php',
+    'WeChat\\Contracts\\MyCurlFile' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Contracts/MyCurlFile.php',
+    'WeChat\\Contracts\\Tools' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Contracts/Tools.php',
+    'WeChat\\Custom' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Custom.php',
+    'WeChat\\Exceptions\\InvalidArgumentException' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidArgumentException.php',
+    'WeChat\\Exceptions\\InvalidDecryptException' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidDecryptException.php',
+    'WeChat\\Exceptions\\InvalidInstanceException' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidInstanceException.php',
+    'WeChat\\Exceptions\\InvalidResponseException' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidResponseException.php',
+    'WeChat\\Exceptions\\LocalCacheException' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Exceptions/LocalCacheException.php',
+    'WeChat\\Limit' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Limit.php',
+    'WeChat\\Media' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Media.php',
+    'WeChat\\Menu' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Menu.php',
+    'WeChat\\Oauth' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Oauth.php',
+    'WeChat\\Pay' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Pay.php',
+    'WeChat\\Product' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Product.php',
+    'WeChat\\Qrcode' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Qrcode.php',
+    'WeChat\\Receive' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Receive.php',
+    'WeChat\\Scan' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Scan.php',
+    'WeChat\\Script' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Script.php',
+    'WeChat\\Shake' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Shake.php',
+    'WeChat\\Tags' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Tags.php',
+    'WeChat\\Template' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Template.php',
+    'WeChat\\User' => $vendorDir . '/zoujingli/wechat-developer/WeChat/User.php',
+    'WeChat\\Wifi' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Wifi.php',
+    'WeMini\\Crypt' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Crypt.php',
+    'WeMini\\Delivery' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Delivery.php',
+    'WeMini\\Guide' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Guide.php',
+    'WeMini\\Image' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Image.php',
+    'WeMini\\Live' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Live.php',
+    'WeMini\\Logistics' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Logistics.php',
+    'WeMini\\Message' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Message.php',
+    'WeMini\\Newtmpl' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Newtmpl.php',
+    'WeMini\\Ocr' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Ocr.php',
+    'WeMini\\Operation' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Operation.php',
+    'WeMini\\Plugs' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Plugs.php',
+    'WeMini\\Poi' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Poi.php',
+    'WeMini\\Qrcode' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Qrcode.php',
+    'WeMini\\Search' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Search.php',
+    'WeMini\\Security' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Security.php',
+    'WeMini\\Soter' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Soter.php',
+    'WeMini\\Template' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Template.php',
+    'WeMini\\Total' => $vendorDir . '/zoujingli/wechat-developer/WeMini/Total.php',
+    'WePay\\Bill' => $vendorDir . '/zoujingli/wechat-developer/WePay/Bill.php',
+    'WePay\\Coupon' => $vendorDir . '/zoujingli/wechat-developer/WePay/Coupon.php',
+    'WePay\\Order' => $vendorDir . '/zoujingli/wechat-developer/WePay/Order.php',
+    'WePay\\Redpack' => $vendorDir . '/zoujingli/wechat-developer/WePay/Redpack.php',
+    'WePay\\Refund' => $vendorDir . '/zoujingli/wechat-developer/WePay/Refund.php',
+    'WePay\\Transfers' => $vendorDir . '/zoujingli/wechat-developer/WePay/Transfers.php',
+    'WePay\\TransfersBank' => $vendorDir . '/zoujingli/wechat-developer/WePay/TransfersBank.php',
+    'app\\admin\\controller\\Auth' => $baseDir . '/app/admin/controller/Auth.php',
+    'app\\admin\\controller\\Config' => $baseDir . '/app/admin/controller/Config.php',
+    'app\\admin\\controller\\Index' => $baseDir . '/app/admin/controller/Index.php',
+    'app\\admin\\controller\\Login' => $baseDir . '/app/admin/controller/Login.php',
+    'app\\admin\\controller\\Menu' => $baseDir . '/app/admin/controller/Menu.php',
+    'app\\admin\\controller\\Module' => $baseDir . '/app/admin/controller/Module.php',
+    'app\\admin\\controller\\Oplog' => $baseDir . '/app/admin/controller/Oplog.php',
+    'app\\admin\\controller\\Queue' => $baseDir . '/app/admin/controller/Queue.php',
+    'app\\admin\\controller\\User' => $baseDir . '/app/admin/controller/User.php',
+    'app\\admin\\controller\\api\\Plugs' => $baseDir . '/app/admin/controller/api/Plugs.php',
+    'app\\admin\\controller\\api\\Queue' => $baseDir . '/app/admin/controller/api/Queue.php',
+    'app\\admin\\controller\\api\\Update' => $baseDir . '/app/admin/controller/api/Update.php',
+    'app\\admin\\controller\\api\\Upload' => $baseDir . '/app/admin/controller/api/Upload.php',
+    'app\\data\\controller\\Config' => $baseDir . '/app/data/controller/Config.php',
+    'app\\data\\controller\\NewsItem' => $baseDir . '/app/data/controller/NewsItem.php',
+    'app\\data\\controller\\NewsMark' => $baseDir . '/app/data/controller/NewsMark.php',
+    'app\\data\\controller\\api\\Auth' => $baseDir . '/app/data/controller/api/Auth.php',
+    'app\\data\\controller\\api\\Data' => $baseDir . '/app/data/controller/api/Data.php',
+    'app\\data\\controller\\api\\Login' => $baseDir . '/app/data/controller/api/Login.php',
+    'app\\data\\controller\\api\\News' => $baseDir . '/app/data/controller/api/News.php',
+    'app\\data\\controller\\api\\auth\\Center' => $baseDir . '/app/data/controller/api/auth/Center.php',
+    'app\\data\\controller\\api\\auth\\News' => $baseDir . '/app/data/controller/api/auth/News.php',
+    'app\\data\\service\\NewsService' => $baseDir . '/app/data/service/NewsService.php',
+    'app\\data\\service\\UserService' => $baseDir . '/app/data/service/UserService.php',
+    'app\\index\\controller\\Index' => $baseDir . '/app/index/controller/Index.php',
+    'app\\wechat\\command\\Fans' => $baseDir . '/app/wechat/command/Fans.php',
+    'app\\wechat\\controller\\Config' => $baseDir . '/app/wechat/controller/Config.php',
+    'app\\wechat\\controller\\Fans' => $baseDir . '/app/wechat/controller/Fans.php',
+    'app\\wechat\\controller\\Keys' => $baseDir . '/app/wechat/controller/Keys.php',
+    'app\\wechat\\controller\\Menu' => $baseDir . '/app/wechat/controller/Menu.php',
+    'app\\wechat\\controller\\News' => $baseDir . '/app/wechat/controller/News.php',
+    'app\\wechat\\controller\\api\\Js' => $baseDir . '/app/wechat/controller/api/Js.php',
+    'app\\wechat\\controller\\api\\Login' => $baseDir . '/app/wechat/controller/api/Login.php',
+    'app\\wechat\\controller\\api\\Push' => $baseDir . '/app/wechat/controller/api/Push.php',
+    'app\\wechat\\controller\\api\\Review' => $baseDir . '/app/wechat/controller/api/Review.php',
+    'app\\wechat\\controller\\api\\Test' => $baseDir . '/app/wechat/controller/api/Test.php',
+    'app\\wechat\\service\\FansService' => $baseDir . '/app/wechat/service/FansService.php',
+    'app\\wechat\\service\\MediaService' => $baseDir . '/app/wechat/service/MediaService.php',
+    'app\\wechat\\service\\WechatService' => $baseDir . '/app/wechat/service/WechatService.php',
+    'think\\App' => $vendorDir . '/topthink/framework/src/think/App.php',
+    'think\\Cache' => $vendorDir . '/topthink/framework/src/think/Cache.php',
+    'think\\Collection' => $vendorDir . '/topthink/think-helper/src/Collection.php',
+    'think\\Config' => $vendorDir . '/topthink/framework/src/think/Config.php',
+    'think\\Console' => $vendorDir . '/topthink/framework/src/think/Console.php',
+    'think\\Container' => $vendorDir . '/topthink/framework/src/think/Container.php',
+    'think\\Cookie' => $vendorDir . '/topthink/framework/src/think/Cookie.php',
+    'think\\Db' => $vendorDir . '/topthink/framework/src/think/Db.php',
+    'think\\DbManager' => $vendorDir . '/topthink/think-orm/src/DbManager.php',
+    'think\\Env' => $vendorDir . '/topthink/framework/src/think/Env.php',
+    'think\\Event' => $vendorDir . '/topthink/framework/src/think/Event.php',
+    'think\\Exception' => $vendorDir . '/topthink/framework/src/think/Exception.php',
+    'think\\Facade' => $vendorDir . '/topthink/framework/src/think/Facade.php',
+    'think\\File' => $vendorDir . '/topthink/framework/src/think/File.php',
+    'think\\Filesystem' => $vendorDir . '/topthink/framework/src/think/Filesystem.php',
+    'think\\Http' => $vendorDir . '/topthink/framework/src/think/Http.php',
+    'think\\Lang' => $vendorDir . '/topthink/framework/src/think/Lang.php',
+    'think\\Log' => $vendorDir . '/topthink/framework/src/think/Log.php',
+    'think\\Manager' => $vendorDir . '/topthink/framework/src/think/Manager.php',
+    'think\\Middleware' => $vendorDir . '/topthink/framework/src/think/Middleware.php',
+    'think\\Model' => $vendorDir . '/topthink/think-orm/src/Model.php',
+    'think\\Paginator' => $vendorDir . '/topthink/think-orm/src/Paginator.php',
+    'think\\Pipeline' => $vendorDir . '/topthink/framework/src/think/Pipeline.php',
+    'think\\Request' => $vendorDir . '/topthink/framework/src/think/Request.php',
+    'think\\Response' => $vendorDir . '/topthink/framework/src/think/Response.php',
+    'think\\Route' => $vendorDir . '/topthink/framework/src/think/Route.php',
+    'think\\Service' => $vendorDir . '/topthink/framework/src/think/Service.php',
+    'think\\Session' => $vendorDir . '/topthink/framework/src/think/Session.php',
+    'think\\Template' => $vendorDir . '/topthink/think-template/src/Template.php',
+    'think\\Validate' => $vendorDir . '/topthink/framework/src/think/Validate.php',
+    'think\\View' => $vendorDir . '/topthink/framework/src/think/View.php',
+    'think\\admin\\Command' => $vendorDir . '/zoujingli/think-library/src/Command.php',
+    'think\\admin\\Controller' => $vendorDir . '/zoujingli/think-library/src/Controller.php',
+    'think\\admin\\Exception' => $vendorDir . '/zoujingli/think-library/src/Exception.php',
+    'think\\admin\\Helper' => $vendorDir . '/zoujingli/think-library/src/Helper.php',
+    'think\\admin\\Library' => $vendorDir . '/zoujingli/think-library/src/Library.php',
+    'think\\admin\\Queue' => $vendorDir . '/zoujingli/think-library/src/Queue.php',
+    'think\\admin\\Service' => $vendorDir . '/zoujingli/think-library/src/Service.php',
+    'think\\admin\\Storage' => $vendorDir . '/zoujingli/think-library/src/Storage.php',
+    'think\\admin\\command\\Database' => $vendorDir . '/zoujingli/think-library/src/command/Database.php',
+    'think\\admin\\command\\Install' => $vendorDir . '/zoujingli/think-library/src/command/Install.php',
+    'think\\admin\\command\\Queue' => $vendorDir . '/zoujingli/think-library/src/command/Queue.php',
+    'think\\admin\\command\\Version' => $vendorDir . '/zoujingli/think-library/src/command/Version.php',
+    'think\\admin\\extend\\CodeExtend' => $vendorDir . '/zoujingli/think-library/src/extend/CodeExtend.php',
+    'think\\admin\\extend\\DataExtend' => $vendorDir . '/zoujingli/think-library/src/extend/DataExtend.php',
+    'think\\admin\\extend\\ExcelExtend' => $vendorDir . '/zoujingli/think-library/src/extend/ExcelExtend.php',
+    'think\\admin\\extend\\HttpExtend' => $vendorDir . '/zoujingli/think-library/src/extend/HttpExtend.php',
+    'think\\admin\\extend\\JsonRpcClient' => $vendorDir . '/zoujingli/think-library/src/extend/JsonRpcClient.php',
+    'think\\admin\\extend\\JsonRpcServer' => $vendorDir . '/zoujingli/think-library/src/extend/JsonRpcServer.php',
+    'think\\admin\\extend\\Parsedown' => $vendorDir . '/zoujingli/think-library/src/extend/Parsedown.php',
+    'think\\admin\\helper\\DeleteHelper' => $vendorDir . '/zoujingli/think-library/src/helper/DeleteHelper.php',
+    'think\\admin\\helper\\FormHelper' => $vendorDir . '/zoujingli/think-library/src/helper/FormHelper.php',
+    'think\\admin\\helper\\PageHelper' => $vendorDir . '/zoujingli/think-library/src/helper/PageHelper.php',
+    'think\\admin\\helper\\QueryHelper' => $vendorDir . '/zoujingli/think-library/src/helper/QueryHelper.php',
+    'think\\admin\\helper\\SaveHelper' => $vendorDir . '/zoujingli/think-library/src/helper/SaveHelper.php',
+    'think\\admin\\helper\\TokenHelper' => $vendorDir . '/zoujingli/think-library/src/helper/TokenHelper.php',
+    'think\\admin\\helper\\ValidateHelper' => $vendorDir . '/zoujingli/think-library/src/helper/ValidateHelper.php',
+    'think\\admin\\multiple\\App' => $vendorDir . '/zoujingli/think-library/src/multiple/App.php',
+    'think\\admin\\multiple\\Url' => $vendorDir . '/zoujingli/think-library/src/multiple/Url.php',
+    'think\\admin\\multiple\\command\\Build' => $vendorDir . '/zoujingli/think-library/src/multiple/command/Build.php',
+    'think\\admin\\multiple\\command\\Clear' => $vendorDir . '/zoujingli/think-library/src/multiple/command/Clear.php',
+    'think\\admin\\service\\AdminService' => $vendorDir . '/zoujingli/think-library/src/service/AdminService.php',
+    'think\\admin\\service\\CaptchaService' => $vendorDir . '/zoujingli/think-library/src/service/CaptchaService.php',
+    'think\\admin\\service\\ExpressService' => $vendorDir . '/zoujingli/think-library/src/service/ExpressService.php',
+    'think\\admin\\service\\InterfaceService' => $vendorDir . '/zoujingli/think-library/src/service/InterfaceService.php',
+    'think\\admin\\service\\MenuService' => $vendorDir . '/zoujingli/think-library/src/service/MenuService.php',
+    'think\\admin\\service\\MessageService' => $vendorDir . '/zoujingli/think-library/src/service/MessageService.php',
+    'think\\admin\\service\\ModuleService' => $vendorDir . '/zoujingli/think-library/src/service/ModuleService.php',
+    'think\\admin\\service\\NodeService' => $vendorDir . '/zoujingli/think-library/src/service/NodeService.php',
+    'think\\admin\\service\\ProcessService' => $vendorDir . '/zoujingli/think-library/src/service/ProcessService.php',
+    'think\\admin\\service\\QueueService' => $vendorDir . '/zoujingli/think-library/src/service/QueueService.php',
+    'think\\admin\\service\\SystemService' => $vendorDir . '/zoujingli/think-library/src/service/SystemService.php',
+    'think\\admin\\service\\TokenService' => $vendorDir . '/zoujingli/think-library/src/service/TokenService.php',
+    'think\\admin\\service\\ZtSmsService' => $vendorDir . '/zoujingli/think-library/src/service/ZtSmsService.php',
+    'think\\admin\\storage\\AliossStorage' => $vendorDir . '/zoujingli/think-library/src/storage/AliossStorage.php',
+    'think\\admin\\storage\\LocalStorage' => $vendorDir . '/zoujingli/think-library/src/storage/LocalStorage.php',
+    'think\\admin\\storage\\QiniuStorage' => $vendorDir . '/zoujingli/think-library/src/storage/QiniuStorage.php',
+    'think\\cache\\Driver' => $vendorDir . '/topthink/framework/src/think/cache/Driver.php',
+    'think\\cache\\TagSet' => $vendorDir . '/topthink/framework/src/think/cache/TagSet.php',
+    'think\\cache\\driver\\File' => $vendorDir . '/topthink/framework/src/think/cache/driver/File.php',
+    'think\\cache\\driver\\Memcache' => $vendorDir . '/topthink/framework/src/think/cache/driver/Memcache.php',
+    'think\\cache\\driver\\Memcached' => $vendorDir . '/topthink/framework/src/think/cache/driver/Memcached.php',
+    'think\\cache\\driver\\Redis' => $vendorDir . '/topthink/framework/src/think/cache/driver/Redis.php',
+    'think\\cache\\driver\\Wincache' => $vendorDir . '/topthink/framework/src/think/cache/driver/Wincache.php',
+    'think\\console\\Command' => $vendorDir . '/topthink/framework/src/think/console/Command.php',
+    'think\\console\\Input' => $vendorDir . '/topthink/framework/src/think/console/Input.php',
+    'think\\console\\Output' => $vendorDir . '/topthink/framework/src/think/console/Output.php',
+    'think\\console\\Table' => $vendorDir . '/topthink/framework/src/think/console/Table.php',
+    'think\\console\\command\\Clear' => $vendorDir . '/topthink/framework/src/think/console/command/Clear.php',
+    'think\\console\\command\\Help' => $vendorDir . '/topthink/framework/src/think/console/command/Help.php',
+    'think\\console\\command\\Lists' => $vendorDir . '/topthink/framework/src/think/console/command/Lists.php',
+    'think\\console\\command\\Make' => $vendorDir . '/topthink/framework/src/think/console/command/Make.php',
+    'think\\console\\command\\RouteList' => $vendorDir . '/topthink/framework/src/think/console/command/RouteList.php',
+    'think\\console\\command\\RunServer' => $vendorDir . '/topthink/framework/src/think/console/command/RunServer.php',
+    'think\\console\\command\\ServiceDiscover' => $vendorDir . '/topthink/framework/src/think/console/command/ServiceDiscover.php',
+    'think\\console\\command\\VendorPublish' => $vendorDir . '/topthink/framework/src/think/console/command/VendorPublish.php',
+    'think\\console\\command\\Version' => $vendorDir . '/topthink/framework/src/think/console/command/Version.php',
+    'think\\console\\command\\make\\Command' => $vendorDir . '/topthink/framework/src/think/console/command/make/Command.php',
+    'think\\console\\command\\make\\Controller' => $vendorDir . '/topthink/framework/src/think/console/command/make/Controller.php',
+    'think\\console\\command\\make\\Event' => $vendorDir . '/topthink/framework/src/think/console/command/make/Event.php',
+    'think\\console\\command\\make\\Listener' => $vendorDir . '/topthink/framework/src/think/console/command/make/Listener.php',
+    'think\\console\\command\\make\\Middleware' => $vendorDir . '/topthink/framework/src/think/console/command/make/Middleware.php',
+    'think\\console\\command\\make\\Model' => $vendorDir . '/topthink/framework/src/think/console/command/make/Model.php',
+    'think\\console\\command\\make\\Service' => $vendorDir . '/topthink/framework/src/think/console/command/make/Service.php',
+    'think\\console\\command\\make\\Subscribe' => $vendorDir . '/topthink/framework/src/think/console/command/make/Subscribe.php',
+    'think\\console\\command\\make\\Validate' => $vendorDir . '/topthink/framework/src/think/console/command/make/Validate.php',
+    'think\\console\\command\\optimize\\Route' => $vendorDir . '/topthink/framework/src/think/console/command/optimize/Route.php',
+    'think\\console\\command\\optimize\\Schema' => $vendorDir . '/topthink/framework/src/think/console/command/optimize/Schema.php',
+    'think\\console\\input\\Argument' => $vendorDir . '/topthink/framework/src/think/console/input/Argument.php',
+    'think\\console\\input\\Definition' => $vendorDir . '/topthink/framework/src/think/console/input/Definition.php',
+    'think\\console\\input\\Option' => $vendorDir . '/topthink/framework/src/think/console/input/Option.php',
+    'think\\console\\output\\Ask' => $vendorDir . '/topthink/framework/src/think/console/output/Ask.php',
+    'think\\console\\output\\Descriptor' => $vendorDir . '/topthink/framework/src/think/console/output/Descriptor.php',
+    'think\\console\\output\\Formatter' => $vendorDir . '/topthink/framework/src/think/console/output/Formatter.php',
+    'think\\console\\output\\Question' => $vendorDir . '/topthink/framework/src/think/console/output/Question.php',
+    'think\\console\\output\\descriptor\\Console' => $vendorDir . '/topthink/framework/src/think/console/output/descriptor/Console.php',
+    'think\\console\\output\\driver\\Buffer' => $vendorDir . '/topthink/framework/src/think/console/output/driver/Buffer.php',
+    'think\\console\\output\\driver\\Console' => $vendorDir . '/topthink/framework/src/think/console/output/driver/Console.php',
+    'think\\console\\output\\driver\\Nothing' => $vendorDir . '/topthink/framework/src/think/console/output/driver/Nothing.php',
+    'think\\console\\output\\formatter\\Stack' => $vendorDir . '/topthink/framework/src/think/console/output/formatter/Stack.php',
+    'think\\console\\output\\formatter\\Style' => $vendorDir . '/topthink/framework/src/think/console/output/formatter/Style.php',
+    'think\\console\\output\\question\\Choice' => $vendorDir . '/topthink/framework/src/think/console/output/question/Choice.php',
+    'think\\console\\output\\question\\Confirmation' => $vendorDir . '/topthink/framework/src/think/console/output/question/Confirmation.php',
+    'think\\contract\\Arrayable' => $vendorDir . '/topthink/think-helper/src/contract/Arrayable.php',
+    'think\\contract\\CacheHandlerInterface' => $vendorDir . '/topthink/framework/src/think/contract/CacheHandlerInterface.php',
+    'think\\contract\\Jsonable' => $vendorDir . '/topthink/think-helper/src/contract/Jsonable.php',
+    'think\\contract\\LogHandlerInterface' => $vendorDir . '/topthink/framework/src/think/contract/LogHandlerInterface.php',
+    'think\\contract\\ModelRelationInterface' => $vendorDir . '/topthink/framework/src/think/contract/ModelRelationInterface.php',
+    'think\\contract\\SessionHandlerInterface' => $vendorDir . '/topthink/framework/src/think/contract/SessionHandlerInterface.php',
+    'think\\contract\\TemplateHandlerInterface' => $vendorDir . '/topthink/framework/src/think/contract/TemplateHandlerInterface.php',
+    'think\\db\\BaseQuery' => $vendorDir . '/topthink/think-orm/src/db/BaseQuery.php',
+    'think\\db\\Builder' => $vendorDir . '/topthink/think-orm/src/db/Builder.php',
+    'think\\db\\CacheItem' => $vendorDir . '/topthink/think-orm/src/db/CacheItem.php',
+    'think\\db\\Connection' => $vendorDir . '/topthink/think-orm/src/db/Connection.php',
+    'think\\db\\ConnectionInterface' => $vendorDir . '/topthink/think-orm/src/db/ConnectionInterface.php',
+    'think\\db\\Fetch' => $vendorDir . '/topthink/think-orm/src/db/Fetch.php',
+    'think\\db\\Mongo' => $vendorDir . '/topthink/think-orm/src/db/Mongo.php',
+    'think\\db\\PDOConnection' => $vendorDir . '/topthink/think-orm/src/db/PDOConnection.php',
+    'think\\db\\Query' => $vendorDir . '/topthink/think-orm/src/db/Query.php',
+    'think\\db\\Raw' => $vendorDir . '/topthink/think-orm/src/db/Raw.php',
+    'think\\db\\Where' => $vendorDir . '/topthink/think-orm/src/db/Where.php',
+    'think\\db\\builder\\Mongo' => $vendorDir . '/topthink/think-orm/src/db/builder/Mongo.php',
+    'think\\db\\builder\\Mysql' => $vendorDir . '/topthink/think-orm/src/db/builder/Mysql.php',
+    'think\\db\\builder\\Oracle' => $vendorDir . '/topthink/think-orm/src/db/builder/Oracle.php',
+    'think\\db\\builder\\Pgsql' => $vendorDir . '/topthink/think-orm/src/db/builder/Pgsql.php',
+    'think\\db\\builder\\Sqlite' => $vendorDir . '/topthink/think-orm/src/db/builder/Sqlite.php',
+    'think\\db\\builder\\Sqlsrv' => $vendorDir . '/topthink/think-orm/src/db/builder/Sqlsrv.php',
+    'think\\db\\concern\\AggregateQuery' => $vendorDir . '/topthink/think-orm/src/db/concern/AggregateQuery.php',
+    'think\\db\\concern\\JoinAndViewQuery' => $vendorDir . '/topthink/think-orm/src/db/concern/JoinAndViewQuery.php',
+    'think\\db\\concern\\ModelRelationQuery' => $vendorDir . '/topthink/think-orm/src/db/concern/ModelRelationQuery.php',
+    'think\\db\\concern\\ParamsBind' => $vendorDir . '/topthink/think-orm/src/db/concern/ParamsBind.php',
+    'think\\db\\concern\\ResultOperation' => $vendorDir . '/topthink/think-orm/src/db/concern/ResultOperation.php',
+    'think\\db\\concern\\TableFieldInfo' => $vendorDir . '/topthink/think-orm/src/db/concern/TableFieldInfo.php',
+    'think\\db\\concern\\TimeFieldQuery' => $vendorDir . '/topthink/think-orm/src/db/concern/TimeFieldQuery.php',
+    'think\\db\\concern\\Transaction' => $vendorDir . '/topthink/think-orm/src/db/concern/Transaction.php',
+    'think\\db\\concern\\WhereQuery' => $vendorDir . '/topthink/think-orm/src/db/concern/WhereQuery.php',
+    'think\\db\\connector\\Mongo' => $vendorDir . '/topthink/think-orm/src/db/connector/Mongo.php',
+    'think\\db\\connector\\Mysql' => $vendorDir . '/topthink/think-orm/src/db/connector/Mysql.php',
+    'think\\db\\connector\\Oracle' => $vendorDir . '/topthink/think-orm/src/db/connector/Oracle.php',
+    'think\\db\\connector\\Pgsql' => $vendorDir . '/topthink/think-orm/src/db/connector/Pgsql.php',
+    'think\\db\\connector\\Sqlite' => $vendorDir . '/topthink/think-orm/src/db/connector/Sqlite.php',
+    'think\\db\\connector\\Sqlsrv' => $vendorDir . '/topthink/think-orm/src/db/connector/Sqlsrv.php',
+    'think\\db\\exception\\BindParamException' => $vendorDir . '/topthink/think-orm/src/db/exception/BindParamException.php',
+    'think\\db\\exception\\DataNotFoundException' => $vendorDir . '/topthink/think-orm/src/db/exception/DataNotFoundException.php',
+    'think\\db\\exception\\DbException' => $vendorDir . '/topthink/think-orm/src/db/exception/DbException.php',
+    'think\\db\\exception\\InvalidArgumentException' => $vendorDir . '/topthink/think-orm/src/db/exception/InvalidArgumentException.php',
+    'think\\db\\exception\\ModelEventException' => $vendorDir . '/topthink/think-orm/src/db/exception/ModelEventException.php',
+    'think\\db\\exception\\ModelNotFoundException' => $vendorDir . '/topthink/think-orm/src/db/exception/ModelNotFoundException.php',
+    'think\\db\\exception\\PDOException' => $vendorDir . '/topthink/think-orm/src/db/exception/PDOException.php',
+    'think\\event\\AppInit' => $vendorDir . '/topthink/framework/src/think/event/AppInit.php',
+    'think\\event\\HttpEnd' => $vendorDir . '/topthink/framework/src/think/event/HttpEnd.php',
+    'think\\event\\HttpRun' => $vendorDir . '/topthink/framework/src/think/event/HttpRun.php',
+    'think\\event\\LogWrite' => $vendorDir . '/topthink/framework/src/think/event/LogWrite.php',
+    'think\\event\\RouteLoaded' => $vendorDir . '/topthink/framework/src/think/event/RouteLoaded.php',
+    'think\\exception\\ClassNotFoundException' => $vendorDir . '/topthink/framework/src/think/exception/ClassNotFoundException.php',
+    'think\\exception\\ErrorException' => $vendorDir . '/topthink/framework/src/think/exception/ErrorException.php',
+    'think\\exception\\FileException' => $vendorDir . '/topthink/framework/src/think/exception/FileException.php',
+    'think\\exception\\FuncNotFoundException' => $vendorDir . '/topthink/framework/src/think/exception/FuncNotFoundException.php',
+    'think\\exception\\Handle' => $vendorDir . '/topthink/framework/src/think/exception/Handle.php',
+    'think\\exception\\HttpException' => $vendorDir . '/topthink/framework/src/think/exception/HttpException.php',
+    'think\\exception\\HttpResponseException' => $vendorDir . '/topthink/framework/src/think/exception/HttpResponseException.php',
+    'think\\exception\\InvalidArgumentException' => $vendorDir . '/topthink/framework/src/think/exception/InvalidArgumentException.php',
+    'think\\exception\\RouteNotFoundException' => $vendorDir . '/topthink/framework/src/think/exception/RouteNotFoundException.php',
+    'think\\exception\\ValidateException' => $vendorDir . '/topthink/framework/src/think/exception/ValidateException.php',
+    'think\\facade\\App' => $vendorDir . '/topthink/framework/src/think/facade/App.php',
+    'think\\facade\\Cache' => $vendorDir . '/topthink/framework/src/think/facade/Cache.php',
+    'think\\facade\\Config' => $vendorDir . '/topthink/framework/src/think/facade/Config.php',
+    'think\\facade\\Console' => $vendorDir . '/topthink/framework/src/think/facade/Console.php',
+    'think\\facade\\Cookie' => $vendorDir . '/topthink/framework/src/think/facade/Cookie.php',
+    'think\\facade\\Db' => $vendorDir . '/topthink/think-orm/src/facade/Db.php',
+    'think\\facade\\Env' => $vendorDir . '/topthink/framework/src/think/facade/Env.php',
+    'think\\facade\\Event' => $vendorDir . '/topthink/framework/src/think/facade/Event.php',
+    'think\\facade\\Facade' => $vendorDir . '/topthink/think-orm/src/facade/Db.php',
+    'think\\facade\\Filesystem' => $vendorDir . '/topthink/framework/src/think/facade/Filesystem.php',
+    'think\\facade\\Lang' => $vendorDir . '/topthink/framework/src/think/facade/Lang.php',
+    'think\\facade\\Log' => $vendorDir . '/topthink/framework/src/think/facade/Log.php',
+    'think\\facade\\Middleware' => $vendorDir . '/topthink/framework/src/think/facade/Middleware.php',
+    'think\\facade\\Request' => $vendorDir . '/topthink/framework/src/think/facade/Request.php',
+    'think\\facade\\Route' => $vendorDir . '/topthink/framework/src/think/facade/Route.php',
+    'think\\facade\\Session' => $vendorDir . '/topthink/framework/src/think/facade/Session.php',
+    'think\\facade\\Template' => $vendorDir . '/topthink/think-template/src/facade/Template.php',
+    'think\\facade\\Validate' => $vendorDir . '/topthink/framework/src/think/facade/Validate.php',
+    'think\\facade\\View' => $vendorDir . '/topthink/framework/src/think/facade/View.php',
+    'think\\file\\UploadedFile' => $vendorDir . '/topthink/framework/src/think/file/UploadedFile.php',
+    'think\\filesystem\\CacheStore' => $vendorDir . '/topthink/framework/src/think/filesystem/CacheStore.php',
+    'think\\filesystem\\Driver' => $vendorDir . '/topthink/framework/src/think/filesystem/Driver.php',
+    'think\\filesystem\\driver\\Local' => $vendorDir . '/topthink/framework/src/think/filesystem/driver/Local.php',
+    'think\\helper\\Arr' => $vendorDir . '/topthink/think-helper/src/helper/Arr.php',
+    'think\\helper\\Str' => $vendorDir . '/topthink/think-helper/src/helper/Str.php',
+    'think\\initializer\\BootService' => $vendorDir . '/topthink/framework/src/think/initializer/BootService.php',
+    'think\\initializer\\Error' => $vendorDir . '/topthink/framework/src/think/initializer/Error.php',
+    'think\\initializer\\RegisterService' => $vendorDir . '/topthink/framework/src/think/initializer/RegisterService.php',
+    'think\\log\\Channel' => $vendorDir . '/topthink/framework/src/think/log/Channel.php',
+    'think\\log\\ChannelSet' => $vendorDir . '/topthink/framework/src/think/log/ChannelSet.php',
+    'think\\log\\driver\\File' => $vendorDir . '/topthink/framework/src/think/log/driver/File.php',
+    'think\\log\\driver\\Socket' => $vendorDir . '/topthink/framework/src/think/log/driver/Socket.php',
+    'think\\middleware\\AllowCrossDomain' => $vendorDir . '/topthink/framework/src/think/middleware/AllowCrossDomain.php',
+    'think\\middleware\\CheckRequestCache' => $vendorDir . '/topthink/framework/src/think/middleware/CheckRequestCache.php',
+    'think\\middleware\\FormTokenCheck' => $vendorDir . '/topthink/framework/src/think/middleware/FormTokenCheck.php',
+    'think\\middleware\\LoadLangPack' => $vendorDir . '/topthink/framework/src/think/middleware/LoadLangPack.php',
+    'think\\middleware\\SessionInit' => $vendorDir . '/topthink/framework/src/think/middleware/SessionInit.php',
+    'think\\model\\Collection' => $vendorDir . '/topthink/think-orm/src/model/Collection.php',
+    'think\\model\\Pivot' => $vendorDir . '/topthink/think-orm/src/model/Pivot.php',
+    'think\\model\\Relation' => $vendorDir . '/topthink/think-orm/src/model/Relation.php',
+    'think\\model\\concern\\Attribute' => $vendorDir . '/topthink/think-orm/src/model/concern/Attribute.php',
+    'think\\model\\concern\\Conversion' => $vendorDir . '/topthink/think-orm/src/model/concern/Conversion.php',
+    'think\\model\\concern\\ModelEvent' => $vendorDir . '/topthink/think-orm/src/model/concern/ModelEvent.php',
+    'think\\model\\concern\\OptimLock' => $vendorDir . '/topthink/think-orm/src/model/concern/OptimLock.php',
+    'think\\model\\concern\\RelationShip' => $vendorDir . '/topthink/think-orm/src/model/concern/RelationShip.php',
+    'think\\model\\concern\\SoftDelete' => $vendorDir . '/topthink/think-orm/src/model/concern/SoftDelete.php',
+    'think\\model\\concern\\TimeStamp' => $vendorDir . '/topthink/think-orm/src/model/concern/TimeStamp.php',
+    'think\\model\\relation\\BelongsTo' => $vendorDir . '/topthink/think-orm/src/model/relation/BelongsTo.php',
+    'think\\model\\relation\\BelongsToMany' => $vendorDir . '/topthink/think-orm/src/model/relation/BelongsToMany.php',
+    'think\\model\\relation\\HasMany' => $vendorDir . '/topthink/think-orm/src/model/relation/HasMany.php',
+    'think\\model\\relation\\HasManyThrough' => $vendorDir . '/topthink/think-orm/src/model/relation/HasManyThrough.php',
+    'think\\model\\relation\\HasOne' => $vendorDir . '/topthink/think-orm/src/model/relation/HasOne.php',
+    'think\\model\\relation\\HasOneThrough' => $vendorDir . '/topthink/think-orm/src/model/relation/HasOneThrough.php',
+    'think\\model\\relation\\MorphMany' => $vendorDir . '/topthink/think-orm/src/model/relation/MorphMany.php',
+    'think\\model\\relation\\MorphOne' => $vendorDir . '/topthink/think-orm/src/model/relation/MorphOne.php',
+    'think\\model\\relation\\MorphTo' => $vendorDir . '/topthink/think-orm/src/model/relation/MorphTo.php',
+    'think\\model\\relation\\MorphToMany' => $vendorDir . '/topthink/think-orm/src/model/relation/MorphToMany.php',
+    'think\\model\\relation\\OneToOne' => $vendorDir . '/topthink/think-orm/src/model/relation/OneToOne.php',
+    'think\\paginator\\driver\\Bootstrap' => $vendorDir . '/topthink/think-orm/src/paginator/driver/Bootstrap.php',
+    'think\\response\\File' => $vendorDir . '/topthink/framework/src/think/response/File.php',
+    'think\\response\\Html' => $vendorDir . '/topthink/framework/src/think/response/Html.php',
+    'think\\response\\Json' => $vendorDir . '/topthink/framework/src/think/response/Json.php',
+    'think\\response\\Jsonp' => $vendorDir . '/topthink/framework/src/think/response/Jsonp.php',
+    'think\\response\\Redirect' => $vendorDir . '/topthink/framework/src/think/response/Redirect.php',
+    'think\\response\\View' => $vendorDir . '/topthink/framework/src/think/response/View.php',
+    'think\\response\\Xml' => $vendorDir . '/topthink/framework/src/think/response/Xml.php',
+    'think\\route\\Dispatch' => $vendorDir . '/topthink/framework/src/think/route/Dispatch.php',
+    'think\\route\\Domain' => $vendorDir . '/topthink/framework/src/think/route/Domain.php',
+    'think\\route\\Resource' => $vendorDir . '/topthink/framework/src/think/route/Resource.php',
+    'think\\route\\Rule' => $vendorDir . '/topthink/framework/src/think/route/Rule.php',
+    'think\\route\\RuleGroup' => $vendorDir . '/topthink/framework/src/think/route/RuleGroup.php',
+    'think\\route\\RuleItem' => $vendorDir . '/topthink/framework/src/think/route/RuleItem.php',
+    'think\\route\\RuleName' => $vendorDir . '/topthink/framework/src/think/route/RuleName.php',
+    'think\\route\\Url' => $vendorDir . '/topthink/framework/src/think/route/Url.php',
+    'think\\route\\dispatch\\Callback' => $vendorDir . '/topthink/framework/src/think/route/dispatch/Callback.php',
+    'think\\route\\dispatch\\Controller' => $vendorDir . '/topthink/framework/src/think/route/dispatch/Controller.php',
+    'think\\route\\dispatch\\Url' => $vendorDir . '/topthink/framework/src/think/route/dispatch/Url.php',
+    'think\\service\\ModelService' => $vendorDir . '/topthink/framework/src/think/service/ModelService.php',
+    'think\\service\\PaginatorService' => $vendorDir . '/topthink/framework/src/think/service/PaginatorService.php',
+    'think\\service\\ValidateService' => $vendorDir . '/topthink/framework/src/think/service/ValidateService.php',
+    'think\\session\\Store' => $vendorDir . '/topthink/framework/src/think/session/Store.php',
+    'think\\session\\driver\\Cache' => $vendorDir . '/topthink/framework/src/think/session/driver/Cache.php',
+    'think\\session\\driver\\File' => $vendorDir . '/topthink/framework/src/think/session/driver/File.php',
+    'think\\template\\TagLib' => $vendorDir . '/topthink/think-template/src/template/TagLib.php',
+    'think\\template\\driver\\File' => $vendorDir . '/topthink/think-template/src/template/driver/File.php',
+    'think\\template\\exception\\TemplateNotFoundException' => $vendorDir . '/topthink/think-template/src/template/exception/TemplateNotFoundException.php',
+    'think\\template\\taglib\\Cx' => $vendorDir . '/topthink/think-template/src/template/taglib/Cx.php',
+    'think\\validate\\ValidateRule' => $vendorDir . '/topthink/framework/src/think/validate/ValidateRule.php',
+    'think\\view\\driver\\Php' => $vendorDir . '/topthink/framework/src/think/view/driver/Php.php',
+    'think\\view\\driver\\Think' => $vendorDir . '/topthink/think-view/src/Think.php',
 );

+ 501 - 0
vendor/composer/autoload_static.php

@@ -143,8 +143,509 @@ class ComposerStaticInit7ad2dfd941224dedfd9e69a3187017d8
     );
 
     public static $classMap = array (
+        'AliPay\\App' => __DIR__ . '/..' . '/zoujingli/wechat-developer/AliPay/App.php',
+        'AliPay\\Bill' => __DIR__ . '/..' . '/zoujingli/wechat-developer/AliPay/Bill.php',
+        'AliPay\\Pos' => __DIR__ . '/..' . '/zoujingli/wechat-developer/AliPay/Pos.php',
+        'AliPay\\Scan' => __DIR__ . '/..' . '/zoujingli/wechat-developer/AliPay/Scan.php',
+        'AliPay\\Trade' => __DIR__ . '/..' . '/zoujingli/wechat-developer/AliPay/Trade.php',
+        'AliPay\\Transfer' => __DIR__ . '/..' . '/zoujingli/wechat-developer/AliPay/Transfer.php',
+        'AliPay\\Wap' => __DIR__ . '/..' . '/zoujingli/wechat-developer/AliPay/Wap.php',
+        'AliPay\\Web' => __DIR__ . '/..' . '/zoujingli/wechat-developer/AliPay/Web.php',
+        'Endroid\\QrCode\\Bundle\\Controller\\QrCodeController' => __DIR__ . '/..' . '/endroid/qr-code/src/Bundle/Controller/QrCodeController.php',
+        'Endroid\\QrCode\\Bundle\\DependencyInjection\\Configuration' => __DIR__ . '/..' . '/endroid/qr-code/src/Bundle/DependencyInjection/Configuration.php',
+        'Endroid\\QrCode\\Bundle\\DependencyInjection\\EndroidQrCodeExtension' => __DIR__ . '/..' . '/endroid/qr-code/src/Bundle/DependencyInjection/EndroidQrCodeExtension.php',
+        'Endroid\\QrCode\\Bundle\\EndroidQrCodeBundle' => __DIR__ . '/..' . '/endroid/qr-code/src/Bundle/EndroidQrCodeBundle.php',
+        'Endroid\\QrCode\\Bundle\\Twig\\Extension\\QrCodeExtension' => __DIR__ . '/..' . '/endroid/qr-code/src/Bundle/Twig/Extension/QrCodeExtension.php',
+        'Endroid\\QrCode\\Exceptions\\DataDoesntExistsException' => __DIR__ . '/..' . '/endroid/qr-code/src/Exceptions/DataDoesntExistsException.php',
+        'Endroid\\QrCode\\Exceptions\\FreeTypeLibraryMissingException' => __DIR__ . '/..' . '/endroid/qr-code/src/Exceptions/FreeTypeLibraryMissingException.php',
+        'Endroid\\QrCode\\Exceptions\\ImageFunctionFailedException' => __DIR__ . '/..' . '/endroid/qr-code/src/Exceptions/ImageFunctionFailedException.php',
+        'Endroid\\QrCode\\Exceptions\\ImageFunctionUnknownException' => __DIR__ . '/..' . '/endroid/qr-code/src/Exceptions/ImageFunctionUnknownException.php',
+        'Endroid\\QrCode\\Exceptions\\ImageSizeTooLargeException' => __DIR__ . '/..' . '/endroid/qr-code/src/Exceptions/ImageSizeTooLargeException.php',
+        'Endroid\\QrCode\\Exceptions\\ImageTypeInvalidException' => __DIR__ . '/..' . '/endroid/qr-code/src/Exceptions/ImageTypeInvalidException.php',
+        'Endroid\\QrCode\\Exceptions\\VersionTooLargeException' => __DIR__ . '/..' . '/endroid/qr-code/src/Exceptions/VersionTooLargeException.php',
+        'Endroid\\QrCode\\Factory\\QrCodeFactory' => __DIR__ . '/..' . '/endroid/qr-code/src/Factory/QrCodeFactory.php',
+        'Endroid\\QrCode\\QrCode' => __DIR__ . '/..' . '/endroid/qr-code/src/QrCode.php',
         'Ip2Region' => __DIR__ . '/..' . '/zoujingli/ip2region/Ip2Region.php',
+        'League\\Flysystem\\AdapterInterface' => __DIR__ . '/..' . '/league/flysystem/src/AdapterInterface.php',
+        'League\\Flysystem\\Adapter\\AbstractAdapter' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/AbstractAdapter.php',
+        'League\\Flysystem\\Adapter\\AbstractFtpAdapter' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/AbstractFtpAdapter.php',
+        'League\\Flysystem\\Adapter\\CanOverwriteFiles' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/CanOverwriteFiles.php',
+        'League\\Flysystem\\Adapter\\Ftp' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Ftp.php',
+        'League\\Flysystem\\Adapter\\Ftpd' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Ftpd.php',
+        'League\\Flysystem\\Adapter\\Local' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Local.php',
+        'League\\Flysystem\\Adapter\\NullAdapter' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/NullAdapter.php',
+        'League\\Flysystem\\Adapter\\Polyfill\\NotSupportingVisibilityTrait' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Polyfill/NotSupportingVisibilityTrait.php',
+        'League\\Flysystem\\Adapter\\Polyfill\\StreamedCopyTrait' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Polyfill/StreamedCopyTrait.php',
+        'League\\Flysystem\\Adapter\\Polyfill\\StreamedReadingTrait' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Polyfill/StreamedReadingTrait.php',
+        'League\\Flysystem\\Adapter\\Polyfill\\StreamedTrait' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Polyfill/StreamedTrait.php',
+        'League\\Flysystem\\Adapter\\Polyfill\\StreamedWritingTrait' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Polyfill/StreamedWritingTrait.php',
+        'League\\Flysystem\\Adapter\\SynologyFtp' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/SynologyFtp.php',
+        'League\\Flysystem\\Cached\\CacheInterface' => __DIR__ . '/..' . '/league/flysystem-cached-adapter/src/CacheInterface.php',
+        'League\\Flysystem\\Cached\\CachedAdapter' => __DIR__ . '/..' . '/league/flysystem-cached-adapter/src/CachedAdapter.php',
+        'League\\Flysystem\\Cached\\Storage\\AbstractCache' => __DIR__ . '/..' . '/league/flysystem-cached-adapter/src/Storage/AbstractCache.php',
+        'League\\Flysystem\\Cached\\Storage\\Adapter' => __DIR__ . '/..' . '/league/flysystem-cached-adapter/src/Storage/Adapter.php',
+        'League\\Flysystem\\Cached\\Storage\\Memcached' => __DIR__ . '/..' . '/league/flysystem-cached-adapter/src/Storage/Memcached.php',
+        'League\\Flysystem\\Cached\\Storage\\Memory' => __DIR__ . '/..' . '/league/flysystem-cached-adapter/src/Storage/Memory.php',
+        'League\\Flysystem\\Cached\\Storage\\Noop' => __DIR__ . '/..' . '/league/flysystem-cached-adapter/src/Storage/Noop.php',
+        'League\\Flysystem\\Cached\\Storage\\PhpRedis' => __DIR__ . '/..' . '/league/flysystem-cached-adapter/src/Storage/PhpRedis.php',
+        'League\\Flysystem\\Cached\\Storage\\Predis' => __DIR__ . '/..' . '/league/flysystem-cached-adapter/src/Storage/Predis.php',
+        'League\\Flysystem\\Cached\\Storage\\Psr6Cache' => __DIR__ . '/..' . '/league/flysystem-cached-adapter/src/Storage/Psr6Cache.php',
+        'League\\Flysystem\\Cached\\Storage\\Stash' => __DIR__ . '/..' . '/league/flysystem-cached-adapter/src/Storage/Stash.php',
+        'League\\Flysystem\\Config' => __DIR__ . '/..' . '/league/flysystem/src/Config.php',
+        'League\\Flysystem\\ConfigAwareTrait' => __DIR__ . '/..' . '/league/flysystem/src/ConfigAwareTrait.php',
+        'League\\Flysystem\\ConnectionErrorException' => __DIR__ . '/..' . '/league/flysystem/src/ConnectionErrorException.php',
+        'League\\Flysystem\\ConnectionRuntimeException' => __DIR__ . '/..' . '/league/flysystem/src/ConnectionRuntimeException.php',
+        'League\\Flysystem\\Directory' => __DIR__ . '/..' . '/league/flysystem/src/Directory.php',
+        'League\\Flysystem\\Exception' => __DIR__ . '/..' . '/league/flysystem/src/Exception.php',
+        'League\\Flysystem\\File' => __DIR__ . '/..' . '/league/flysystem/src/File.php',
+        'League\\Flysystem\\FileExistsException' => __DIR__ . '/..' . '/league/flysystem/src/FileExistsException.php',
+        'League\\Flysystem\\FileNotFoundException' => __DIR__ . '/..' . '/league/flysystem/src/FileNotFoundException.php',
+        'League\\Flysystem\\Filesystem' => __DIR__ . '/..' . '/league/flysystem/src/Filesystem.php',
+        'League\\Flysystem\\FilesystemException' => __DIR__ . '/..' . '/league/flysystem/src/FilesystemException.php',
+        'League\\Flysystem\\FilesystemInterface' => __DIR__ . '/..' . '/league/flysystem/src/FilesystemInterface.php',
+        'League\\Flysystem\\FilesystemNotFoundException' => __DIR__ . '/..' . '/league/flysystem/src/FilesystemNotFoundException.php',
+        'League\\Flysystem\\Handler' => __DIR__ . '/..' . '/league/flysystem/src/Handler.php',
+        'League\\Flysystem\\InvalidRootException' => __DIR__ . '/..' . '/league/flysystem/src/InvalidRootException.php',
+        'League\\Flysystem\\MountManager' => __DIR__ . '/..' . '/league/flysystem/src/MountManager.php',
+        'League\\Flysystem\\NotSupportedException' => __DIR__ . '/..' . '/league/flysystem/src/NotSupportedException.php',
+        'League\\Flysystem\\PluginInterface' => __DIR__ . '/..' . '/league/flysystem/src/PluginInterface.php',
+        'League\\Flysystem\\Plugin\\AbstractPlugin' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/AbstractPlugin.php',
+        'League\\Flysystem\\Plugin\\EmptyDir' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/EmptyDir.php',
+        'League\\Flysystem\\Plugin\\ForcedCopy' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/ForcedCopy.php',
+        'League\\Flysystem\\Plugin\\ForcedRename' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/ForcedRename.php',
+        'League\\Flysystem\\Plugin\\GetWithMetadata' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/GetWithMetadata.php',
+        'League\\Flysystem\\Plugin\\ListFiles' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/ListFiles.php',
+        'League\\Flysystem\\Plugin\\ListPaths' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/ListPaths.php',
+        'League\\Flysystem\\Plugin\\ListWith' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/ListWith.php',
+        'League\\Flysystem\\Plugin\\PluggableTrait' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/PluggableTrait.php',
+        'League\\Flysystem\\Plugin\\PluginNotFoundException' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/PluginNotFoundException.php',
+        'League\\Flysystem\\ReadInterface' => __DIR__ . '/..' . '/league/flysystem/src/ReadInterface.php',
+        'League\\Flysystem\\RootViolationException' => __DIR__ . '/..' . '/league/flysystem/src/RootViolationException.php',
+        'League\\Flysystem\\SafeStorage' => __DIR__ . '/..' . '/league/flysystem/src/SafeStorage.php',
+        'League\\Flysystem\\UnreadableFileException' => __DIR__ . '/..' . '/league/flysystem/src/UnreadableFileException.php',
+        'League\\Flysystem\\Util' => __DIR__ . '/..' . '/league/flysystem/src/Util.php',
+        'League\\Flysystem\\Util\\ContentListingFormatter' => __DIR__ . '/..' . '/league/flysystem/src/Util/ContentListingFormatter.php',
+        'League\\Flysystem\\Util\\MimeType' => __DIR__ . '/..' . '/league/flysystem/src/Util/MimeType.php',
+        'League\\Flysystem\\Util\\StreamHasher' => __DIR__ . '/..' . '/league/flysystem/src/Util/StreamHasher.php',
+        'League\\MimeTypeDetection\\EmptyExtensionToMimeTypeMap' => __DIR__ . '/..' . '/league/mime-type-detection/src/EmptyExtensionToMimeTypeMap.php',
+        'League\\MimeTypeDetection\\ExtensionMimeTypeDetector' => __DIR__ . '/..' . '/league/mime-type-detection/src/ExtensionMimeTypeDetector.php',
+        'League\\MimeTypeDetection\\ExtensionToMimeTypeMap' => __DIR__ . '/..' . '/league/mime-type-detection/src/ExtensionToMimeTypeMap.php',
+        'League\\MimeTypeDetection\\FinfoMimeTypeDetector' => __DIR__ . '/..' . '/league/mime-type-detection/src/FinfoMimeTypeDetector.php',
+        'League\\MimeTypeDetection\\GeneratedExtensionToMimeTypeMap' => __DIR__ . '/..' . '/league/mime-type-detection/src/GeneratedExtensionToMimeTypeMap.php',
+        'League\\MimeTypeDetection\\MimeTypeDetector' => __DIR__ . '/..' . '/league/mime-type-detection/src/MimeTypeDetector.php',
+        'Opis\\Closure\\Analyzer' => __DIR__ . '/..' . '/opis/closure/src/Analyzer.php',
+        'Opis\\Closure\\ClosureContext' => __DIR__ . '/..' . '/opis/closure/src/ClosureContext.php',
+        'Opis\\Closure\\ClosureScope' => __DIR__ . '/..' . '/opis/closure/src/ClosureScope.php',
+        'Opis\\Closure\\ClosureStream' => __DIR__ . '/..' . '/opis/closure/src/ClosureStream.php',
+        'Opis\\Closure\\ISecurityProvider' => __DIR__ . '/..' . '/opis/closure/src/ISecurityProvider.php',
+        'Opis\\Closure\\ReflectionClosure' => __DIR__ . '/..' . '/opis/closure/src/ReflectionClosure.php',
+        'Opis\\Closure\\SecurityException' => __DIR__ . '/..' . '/opis/closure/src/SecurityException.php',
+        'Opis\\Closure\\SecurityProvider' => __DIR__ . '/..' . '/opis/closure/src/SecurityProvider.php',
+        'Opis\\Closure\\SelfReference' => __DIR__ . '/..' . '/opis/closure/src/SelfReference.php',
+        'Opis\\Closure\\SerializableClosure' => __DIR__ . '/..' . '/opis/closure/src/SerializableClosure.php',
+        'Psr\\Cache\\CacheException' => __DIR__ . '/..' . '/psr/cache/src/CacheException.php',
+        'Psr\\Cache\\CacheItemInterface' => __DIR__ . '/..' . '/psr/cache/src/CacheItemInterface.php',
+        'Psr\\Cache\\CacheItemPoolInterface' => __DIR__ . '/..' . '/psr/cache/src/CacheItemPoolInterface.php',
+        'Psr\\Cache\\InvalidArgumentException' => __DIR__ . '/..' . '/psr/cache/src/InvalidArgumentException.php',
+        'Psr\\Container\\ContainerExceptionInterface' => __DIR__ . '/..' . '/psr/container/src/ContainerExceptionInterface.php',
+        'Psr\\Container\\ContainerInterface' => __DIR__ . '/..' . '/psr/container/src/ContainerInterface.php',
+        'Psr\\Container\\NotFoundExceptionInterface' => __DIR__ . '/..' . '/psr/container/src/NotFoundExceptionInterface.php',
+        'Psr\\Log\\AbstractLogger' => __DIR__ . '/..' . '/psr/log/Psr/Log/AbstractLogger.php',
+        'Psr\\Log\\InvalidArgumentException' => __DIR__ . '/..' . '/psr/log/Psr/Log/InvalidArgumentException.php',
+        'Psr\\Log\\LogLevel' => __DIR__ . '/..' . '/psr/log/Psr/Log/LogLevel.php',
+        'Psr\\Log\\LoggerAwareInterface' => __DIR__ . '/..' . '/psr/log/Psr/Log/LoggerAwareInterface.php',
+        'Psr\\Log\\LoggerAwareTrait' => __DIR__ . '/..' . '/psr/log/Psr/Log/LoggerAwareTrait.php',
+        'Psr\\Log\\LoggerInterface' => __DIR__ . '/..' . '/psr/log/Psr/Log/LoggerInterface.php',
+        'Psr\\Log\\LoggerTrait' => __DIR__ . '/..' . '/psr/log/Psr/Log/LoggerTrait.php',
+        'Psr\\Log\\NullLogger' => __DIR__ . '/..' . '/psr/log/Psr/Log/NullLogger.php',
+        'Psr\\Log\\Test\\DummyTest' => __DIR__ . '/..' . '/psr/log/Psr/Log/Test/DummyTest.php',
+        'Psr\\Log\\Test\\LoggerInterfaceTest' => __DIR__ . '/..' . '/psr/log/Psr/Log/Test/LoggerInterfaceTest.php',
+        'Psr\\Log\\Test\\TestLogger' => __DIR__ . '/..' . '/psr/log/Psr/Log/Test/TestLogger.php',
+        'Psr\\SimpleCache\\CacheException' => __DIR__ . '/..' . '/psr/simple-cache/src/CacheException.php',
+        'Psr\\SimpleCache\\CacheInterface' => __DIR__ . '/..' . '/psr/simple-cache/src/CacheInterface.php',
+        'Psr\\SimpleCache\\InvalidArgumentException' => __DIR__ . '/..' . '/psr/simple-cache/src/InvalidArgumentException.php',
+        'Symfony\\Component\\OptionsResolver\\Debug\\OptionsResolverIntrospector' => __DIR__ . '/..' . '/symfony/options-resolver/Debug/OptionsResolverIntrospector.php',
+        'Symfony\\Component\\OptionsResolver\\Exception\\AccessException' => __DIR__ . '/..' . '/symfony/options-resolver/Exception/AccessException.php',
+        'Symfony\\Component\\OptionsResolver\\Exception\\ExceptionInterface' => __DIR__ . '/..' . '/symfony/options-resolver/Exception/ExceptionInterface.php',
+        'Symfony\\Component\\OptionsResolver\\Exception\\InvalidArgumentException' => __DIR__ . '/..' . '/symfony/options-resolver/Exception/InvalidArgumentException.php',
+        'Symfony\\Component\\OptionsResolver\\Exception\\InvalidOptionsException' => __DIR__ . '/..' . '/symfony/options-resolver/Exception/InvalidOptionsException.php',
+        'Symfony\\Component\\OptionsResolver\\Exception\\MissingOptionsException' => __DIR__ . '/..' . '/symfony/options-resolver/Exception/MissingOptionsException.php',
+        'Symfony\\Component\\OptionsResolver\\Exception\\NoConfigurationException' => __DIR__ . '/..' . '/symfony/options-resolver/Exception/NoConfigurationException.php',
+        'Symfony\\Component\\OptionsResolver\\Exception\\NoSuchOptionException' => __DIR__ . '/..' . '/symfony/options-resolver/Exception/NoSuchOptionException.php',
+        'Symfony\\Component\\OptionsResolver\\Exception\\OptionDefinitionException' => __DIR__ . '/..' . '/symfony/options-resolver/Exception/OptionDefinitionException.php',
+        'Symfony\\Component\\OptionsResolver\\Exception\\UndefinedOptionsException' => __DIR__ . '/..' . '/symfony/options-resolver/Exception/UndefinedOptionsException.php',
+        'Symfony\\Component\\OptionsResolver\\Options' => __DIR__ . '/..' . '/symfony/options-resolver/Options.php',
+        'Symfony\\Component\\OptionsResolver\\OptionsResolver' => __DIR__ . '/..' . '/symfony/options-resolver/OptionsResolver.php',
         'We' => __DIR__ . '/..' . '/zoujingli/wechat-developer/We.php',
+        'WeChat\\Card' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Card.php',
+        'WeChat\\Contracts\\BasicAliPay' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Contracts/BasicAliPay.php',
+        'WeChat\\Contracts\\BasicPushEvent' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Contracts/BasicPushEvent.php',
+        'WeChat\\Contracts\\BasicWeChat' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Contracts/BasicWeChat.php',
+        'WeChat\\Contracts\\BasicWePay' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Contracts/BasicWePay.php',
+        'WeChat\\Contracts\\BasicWeWork' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Contracts/BasicWeWork.php',
+        'WeChat\\Contracts\\DataArray' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Contracts/DataArray.php',
+        'WeChat\\Contracts\\DataError' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Contracts/DataError.php',
+        'WeChat\\Contracts\\MyCurlFile' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Contracts/MyCurlFile.php',
+        'WeChat\\Contracts\\Tools' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Contracts/Tools.php',
+        'WeChat\\Custom' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Custom.php',
+        'WeChat\\Exceptions\\InvalidArgumentException' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidArgumentException.php',
+        'WeChat\\Exceptions\\InvalidDecryptException' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidDecryptException.php',
+        'WeChat\\Exceptions\\InvalidInstanceException' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidInstanceException.php',
+        'WeChat\\Exceptions\\InvalidResponseException' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidResponseException.php',
+        'WeChat\\Exceptions\\LocalCacheException' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Exceptions/LocalCacheException.php',
+        'WeChat\\Limit' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Limit.php',
+        'WeChat\\Media' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Media.php',
+        'WeChat\\Menu' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Menu.php',
+        'WeChat\\Oauth' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Oauth.php',
+        'WeChat\\Pay' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Pay.php',
+        'WeChat\\Product' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Product.php',
+        'WeChat\\Qrcode' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Qrcode.php',
+        'WeChat\\Receive' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Receive.php',
+        'WeChat\\Scan' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Scan.php',
+        'WeChat\\Script' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Script.php',
+        'WeChat\\Shake' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Shake.php',
+        'WeChat\\Tags' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Tags.php',
+        'WeChat\\Template' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Template.php',
+        'WeChat\\User' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/User.php',
+        'WeChat\\Wifi' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Wifi.php',
+        'WeMini\\Crypt' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Crypt.php',
+        'WeMini\\Delivery' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Delivery.php',
+        'WeMini\\Guide' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Guide.php',
+        'WeMini\\Image' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Image.php',
+        'WeMini\\Live' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Live.php',
+        'WeMini\\Logistics' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Logistics.php',
+        'WeMini\\Message' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Message.php',
+        'WeMini\\Newtmpl' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Newtmpl.php',
+        'WeMini\\Ocr' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Ocr.php',
+        'WeMini\\Operation' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Operation.php',
+        'WeMini\\Plugs' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Plugs.php',
+        'WeMini\\Poi' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Poi.php',
+        'WeMini\\Qrcode' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Qrcode.php',
+        'WeMini\\Search' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Search.php',
+        'WeMini\\Security' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Security.php',
+        'WeMini\\Soter' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Soter.php',
+        'WeMini\\Template' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Template.php',
+        'WeMini\\Total' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeMini/Total.php',
+        'WePay\\Bill' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WePay/Bill.php',
+        'WePay\\Coupon' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WePay/Coupon.php',
+        'WePay\\Order' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WePay/Order.php',
+        'WePay\\Redpack' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WePay/Redpack.php',
+        'WePay\\Refund' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WePay/Refund.php',
+        'WePay\\Transfers' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WePay/Transfers.php',
+        'WePay\\TransfersBank' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WePay/TransfersBank.php',
+        'app\\admin\\controller\\Auth' => __DIR__ . '/../..' . '/app/admin/controller/Auth.php',
+        'app\\admin\\controller\\Config' => __DIR__ . '/../..' . '/app/admin/controller/Config.php',
+        'app\\admin\\controller\\Index' => __DIR__ . '/../..' . '/app/admin/controller/Index.php',
+        'app\\admin\\controller\\Login' => __DIR__ . '/../..' . '/app/admin/controller/Login.php',
+        'app\\admin\\controller\\Menu' => __DIR__ . '/../..' . '/app/admin/controller/Menu.php',
+        'app\\admin\\controller\\Module' => __DIR__ . '/../..' . '/app/admin/controller/Module.php',
+        'app\\admin\\controller\\Oplog' => __DIR__ . '/../..' . '/app/admin/controller/Oplog.php',
+        'app\\admin\\controller\\Queue' => __DIR__ . '/../..' . '/app/admin/controller/Queue.php',
+        'app\\admin\\controller\\User' => __DIR__ . '/../..' . '/app/admin/controller/User.php',
+        'app\\admin\\controller\\api\\Plugs' => __DIR__ . '/../..' . '/app/admin/controller/api/Plugs.php',
+        'app\\admin\\controller\\api\\Queue' => __DIR__ . '/../..' . '/app/admin/controller/api/Queue.php',
+        'app\\admin\\controller\\api\\Update' => __DIR__ . '/../..' . '/app/admin/controller/api/Update.php',
+        'app\\admin\\controller\\api\\Upload' => __DIR__ . '/../..' . '/app/admin/controller/api/Upload.php',
+        'app\\data\\controller\\Config' => __DIR__ . '/../..' . '/app/data/controller/Config.php',
+        'app\\data\\controller\\NewsItem' => __DIR__ . '/../..' . '/app/data/controller/NewsItem.php',
+        'app\\data\\controller\\NewsMark' => __DIR__ . '/../..' . '/app/data/controller/NewsMark.php',
+        'app\\data\\controller\\api\\Auth' => __DIR__ . '/../..' . '/app/data/controller/api/Auth.php',
+        'app\\data\\controller\\api\\Data' => __DIR__ . '/../..' . '/app/data/controller/api/Data.php',
+        'app\\data\\controller\\api\\Login' => __DIR__ . '/../..' . '/app/data/controller/api/Login.php',
+        'app\\data\\controller\\api\\News' => __DIR__ . '/../..' . '/app/data/controller/api/News.php',
+        'app\\data\\controller\\api\\auth\\Center' => __DIR__ . '/../..' . '/app/data/controller/api/auth/Center.php',
+        'app\\data\\controller\\api\\auth\\News' => __DIR__ . '/../..' . '/app/data/controller/api/auth/News.php',
+        'app\\data\\service\\NewsService' => __DIR__ . '/../..' . '/app/data/service/NewsService.php',
+        'app\\data\\service\\UserService' => __DIR__ . '/../..' . '/app/data/service/UserService.php',
+        'app\\index\\controller\\Index' => __DIR__ . '/../..' . '/app/index/controller/Index.php',
+        'app\\wechat\\command\\Fans' => __DIR__ . '/../..' . '/app/wechat/command/Fans.php',
+        'app\\wechat\\controller\\Config' => __DIR__ . '/../..' . '/app/wechat/controller/Config.php',
+        'app\\wechat\\controller\\Fans' => __DIR__ . '/../..' . '/app/wechat/controller/Fans.php',
+        'app\\wechat\\controller\\Keys' => __DIR__ . '/../..' . '/app/wechat/controller/Keys.php',
+        'app\\wechat\\controller\\Menu' => __DIR__ . '/../..' . '/app/wechat/controller/Menu.php',
+        'app\\wechat\\controller\\News' => __DIR__ . '/../..' . '/app/wechat/controller/News.php',
+        'app\\wechat\\controller\\api\\Js' => __DIR__ . '/../..' . '/app/wechat/controller/api/Js.php',
+        'app\\wechat\\controller\\api\\Login' => __DIR__ . '/../..' . '/app/wechat/controller/api/Login.php',
+        'app\\wechat\\controller\\api\\Push' => __DIR__ . '/../..' . '/app/wechat/controller/api/Push.php',
+        'app\\wechat\\controller\\api\\Review' => __DIR__ . '/../..' . '/app/wechat/controller/api/Review.php',
+        'app\\wechat\\controller\\api\\Test' => __DIR__ . '/../..' . '/app/wechat/controller/api/Test.php',
+        'app\\wechat\\service\\FansService' => __DIR__ . '/../..' . '/app/wechat/service/FansService.php',
+        'app\\wechat\\service\\MediaService' => __DIR__ . '/../..' . '/app/wechat/service/MediaService.php',
+        'app\\wechat\\service\\WechatService' => __DIR__ . '/../..' . '/app/wechat/service/WechatService.php',
+        'think\\App' => __DIR__ . '/..' . '/topthink/framework/src/think/App.php',
+        'think\\Cache' => __DIR__ . '/..' . '/topthink/framework/src/think/Cache.php',
+        'think\\Collection' => __DIR__ . '/..' . '/topthink/think-helper/src/Collection.php',
+        'think\\Config' => __DIR__ . '/..' . '/topthink/framework/src/think/Config.php',
+        'think\\Console' => __DIR__ . '/..' . '/topthink/framework/src/think/Console.php',
+        'think\\Container' => __DIR__ . '/..' . '/topthink/framework/src/think/Container.php',
+        'think\\Cookie' => __DIR__ . '/..' . '/topthink/framework/src/think/Cookie.php',
+        'think\\Db' => __DIR__ . '/..' . '/topthink/framework/src/think/Db.php',
+        'think\\DbManager' => __DIR__ . '/..' . '/topthink/think-orm/src/DbManager.php',
+        'think\\Env' => __DIR__ . '/..' . '/topthink/framework/src/think/Env.php',
+        'think\\Event' => __DIR__ . '/..' . '/topthink/framework/src/think/Event.php',
+        'think\\Exception' => __DIR__ . '/..' . '/topthink/framework/src/think/Exception.php',
+        'think\\Facade' => __DIR__ . '/..' . '/topthink/framework/src/think/Facade.php',
+        'think\\File' => __DIR__ . '/..' . '/topthink/framework/src/think/File.php',
+        'think\\Filesystem' => __DIR__ . '/..' . '/topthink/framework/src/think/Filesystem.php',
+        'think\\Http' => __DIR__ . '/..' . '/topthink/framework/src/think/Http.php',
+        'think\\Lang' => __DIR__ . '/..' . '/topthink/framework/src/think/Lang.php',
+        'think\\Log' => __DIR__ . '/..' . '/topthink/framework/src/think/Log.php',
+        'think\\Manager' => __DIR__ . '/..' . '/topthink/framework/src/think/Manager.php',
+        'think\\Middleware' => __DIR__ . '/..' . '/topthink/framework/src/think/Middleware.php',
+        'think\\Model' => __DIR__ . '/..' . '/topthink/think-orm/src/Model.php',
+        'think\\Paginator' => __DIR__ . '/..' . '/topthink/think-orm/src/Paginator.php',
+        'think\\Pipeline' => __DIR__ . '/..' . '/topthink/framework/src/think/Pipeline.php',
+        'think\\Request' => __DIR__ . '/..' . '/topthink/framework/src/think/Request.php',
+        'think\\Response' => __DIR__ . '/..' . '/topthink/framework/src/think/Response.php',
+        'think\\Route' => __DIR__ . '/..' . '/topthink/framework/src/think/Route.php',
+        'think\\Service' => __DIR__ . '/..' . '/topthink/framework/src/think/Service.php',
+        'think\\Session' => __DIR__ . '/..' . '/topthink/framework/src/think/Session.php',
+        'think\\Template' => __DIR__ . '/..' . '/topthink/think-template/src/Template.php',
+        'think\\Validate' => __DIR__ . '/..' . '/topthink/framework/src/think/Validate.php',
+        'think\\View' => __DIR__ . '/..' . '/topthink/framework/src/think/View.php',
+        'think\\admin\\Command' => __DIR__ . '/..' . '/zoujingli/think-library/src/Command.php',
+        'think\\admin\\Controller' => __DIR__ . '/..' . '/zoujingli/think-library/src/Controller.php',
+        'think\\admin\\Exception' => __DIR__ . '/..' . '/zoujingli/think-library/src/Exception.php',
+        'think\\admin\\Helper' => __DIR__ . '/..' . '/zoujingli/think-library/src/Helper.php',
+        'think\\admin\\Library' => __DIR__ . '/..' . '/zoujingli/think-library/src/Library.php',
+        'think\\admin\\Queue' => __DIR__ . '/..' . '/zoujingli/think-library/src/Queue.php',
+        'think\\admin\\Service' => __DIR__ . '/..' . '/zoujingli/think-library/src/Service.php',
+        'think\\admin\\Storage' => __DIR__ . '/..' . '/zoujingli/think-library/src/Storage.php',
+        'think\\admin\\command\\Database' => __DIR__ . '/..' . '/zoujingli/think-library/src/command/Database.php',
+        'think\\admin\\command\\Install' => __DIR__ . '/..' . '/zoujingli/think-library/src/command/Install.php',
+        'think\\admin\\command\\Queue' => __DIR__ . '/..' . '/zoujingli/think-library/src/command/Queue.php',
+        'think\\admin\\command\\Version' => __DIR__ . '/..' . '/zoujingli/think-library/src/command/Version.php',
+        'think\\admin\\extend\\CodeExtend' => __DIR__ . '/..' . '/zoujingli/think-library/src/extend/CodeExtend.php',
+        'think\\admin\\extend\\DataExtend' => __DIR__ . '/..' . '/zoujingli/think-library/src/extend/DataExtend.php',
+        'think\\admin\\extend\\ExcelExtend' => __DIR__ . '/..' . '/zoujingli/think-library/src/extend/ExcelExtend.php',
+        'think\\admin\\extend\\HttpExtend' => __DIR__ . '/..' . '/zoujingli/think-library/src/extend/HttpExtend.php',
+        'think\\admin\\extend\\JsonRpcClient' => __DIR__ . '/..' . '/zoujingli/think-library/src/extend/JsonRpcClient.php',
+        'think\\admin\\extend\\JsonRpcServer' => __DIR__ . '/..' . '/zoujingli/think-library/src/extend/JsonRpcServer.php',
+        'think\\admin\\extend\\Parsedown' => __DIR__ . '/..' . '/zoujingli/think-library/src/extend/Parsedown.php',
+        'think\\admin\\helper\\DeleteHelper' => __DIR__ . '/..' . '/zoujingli/think-library/src/helper/DeleteHelper.php',
+        'think\\admin\\helper\\FormHelper' => __DIR__ . '/..' . '/zoujingli/think-library/src/helper/FormHelper.php',
+        'think\\admin\\helper\\PageHelper' => __DIR__ . '/..' . '/zoujingli/think-library/src/helper/PageHelper.php',
+        'think\\admin\\helper\\QueryHelper' => __DIR__ . '/..' . '/zoujingli/think-library/src/helper/QueryHelper.php',
+        'think\\admin\\helper\\SaveHelper' => __DIR__ . '/..' . '/zoujingli/think-library/src/helper/SaveHelper.php',
+        'think\\admin\\helper\\TokenHelper' => __DIR__ . '/..' . '/zoujingli/think-library/src/helper/TokenHelper.php',
+        'think\\admin\\helper\\ValidateHelper' => __DIR__ . '/..' . '/zoujingli/think-library/src/helper/ValidateHelper.php',
+        'think\\admin\\multiple\\App' => __DIR__ . '/..' . '/zoujingli/think-library/src/multiple/App.php',
+        'think\\admin\\multiple\\Url' => __DIR__ . '/..' . '/zoujingli/think-library/src/multiple/Url.php',
+        'think\\admin\\multiple\\command\\Build' => __DIR__ . '/..' . '/zoujingli/think-library/src/multiple/command/Build.php',
+        'think\\admin\\multiple\\command\\Clear' => __DIR__ . '/..' . '/zoujingli/think-library/src/multiple/command/Clear.php',
+        'think\\admin\\service\\AdminService' => __DIR__ . '/..' . '/zoujingli/think-library/src/service/AdminService.php',
+        'think\\admin\\service\\CaptchaService' => __DIR__ . '/..' . '/zoujingli/think-library/src/service/CaptchaService.php',
+        'think\\admin\\service\\ExpressService' => __DIR__ . '/..' . '/zoujingli/think-library/src/service/ExpressService.php',
+        'think\\admin\\service\\InterfaceService' => __DIR__ . '/..' . '/zoujingli/think-library/src/service/InterfaceService.php',
+        'think\\admin\\service\\MenuService' => __DIR__ . '/..' . '/zoujingli/think-library/src/service/MenuService.php',
+        'think\\admin\\service\\MessageService' => __DIR__ . '/..' . '/zoujingli/think-library/src/service/MessageService.php',
+        'think\\admin\\service\\ModuleService' => __DIR__ . '/..' . '/zoujingli/think-library/src/service/ModuleService.php',
+        'think\\admin\\service\\NodeService' => __DIR__ . '/..' . '/zoujingli/think-library/src/service/NodeService.php',
+        'think\\admin\\service\\ProcessService' => __DIR__ . '/..' . '/zoujingli/think-library/src/service/ProcessService.php',
+        'think\\admin\\service\\QueueService' => __DIR__ . '/..' . '/zoujingli/think-library/src/service/QueueService.php',
+        'think\\admin\\service\\SystemService' => __DIR__ . '/..' . '/zoujingli/think-library/src/service/SystemService.php',
+        'think\\admin\\service\\TokenService' => __DIR__ . '/..' . '/zoujingli/think-library/src/service/TokenService.php',
+        'think\\admin\\service\\ZtSmsService' => __DIR__ . '/..' . '/zoujingli/think-library/src/service/ZtSmsService.php',
+        'think\\admin\\storage\\AliossStorage' => __DIR__ . '/..' . '/zoujingli/think-library/src/storage/AliossStorage.php',
+        'think\\admin\\storage\\LocalStorage' => __DIR__ . '/..' . '/zoujingli/think-library/src/storage/LocalStorage.php',
+        'think\\admin\\storage\\QiniuStorage' => __DIR__ . '/..' . '/zoujingli/think-library/src/storage/QiniuStorage.php',
+        'think\\cache\\Driver' => __DIR__ . '/..' . '/topthink/framework/src/think/cache/Driver.php',
+        'think\\cache\\TagSet' => __DIR__ . '/..' . '/topthink/framework/src/think/cache/TagSet.php',
+        'think\\cache\\driver\\File' => __DIR__ . '/..' . '/topthink/framework/src/think/cache/driver/File.php',
+        'think\\cache\\driver\\Memcache' => __DIR__ . '/..' . '/topthink/framework/src/think/cache/driver/Memcache.php',
+        'think\\cache\\driver\\Memcached' => __DIR__ . '/..' . '/topthink/framework/src/think/cache/driver/Memcached.php',
+        'think\\cache\\driver\\Redis' => __DIR__ . '/..' . '/topthink/framework/src/think/cache/driver/Redis.php',
+        'think\\cache\\driver\\Wincache' => __DIR__ . '/..' . '/topthink/framework/src/think/cache/driver/Wincache.php',
+        'think\\console\\Command' => __DIR__ . '/..' . '/topthink/framework/src/think/console/Command.php',
+        'think\\console\\Input' => __DIR__ . '/..' . '/topthink/framework/src/think/console/Input.php',
+        'think\\console\\Output' => __DIR__ . '/..' . '/topthink/framework/src/think/console/Output.php',
+        'think\\console\\Table' => __DIR__ . '/..' . '/topthink/framework/src/think/console/Table.php',
+        'think\\console\\command\\Clear' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/Clear.php',
+        'think\\console\\command\\Help' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/Help.php',
+        'think\\console\\command\\Lists' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/Lists.php',
+        'think\\console\\command\\Make' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/Make.php',
+        'think\\console\\command\\RouteList' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/RouteList.php',
+        'think\\console\\command\\RunServer' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/RunServer.php',
+        'think\\console\\command\\ServiceDiscover' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/ServiceDiscover.php',
+        'think\\console\\command\\VendorPublish' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/VendorPublish.php',
+        'think\\console\\command\\Version' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/Version.php',
+        'think\\console\\command\\make\\Command' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/make/Command.php',
+        'think\\console\\command\\make\\Controller' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/make/Controller.php',
+        'think\\console\\command\\make\\Event' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/make/Event.php',
+        'think\\console\\command\\make\\Listener' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/make/Listener.php',
+        'think\\console\\command\\make\\Middleware' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/make/Middleware.php',
+        'think\\console\\command\\make\\Model' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/make/Model.php',
+        'think\\console\\command\\make\\Service' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/make/Service.php',
+        'think\\console\\command\\make\\Subscribe' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/make/Subscribe.php',
+        'think\\console\\command\\make\\Validate' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/make/Validate.php',
+        'think\\console\\command\\optimize\\Route' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/optimize/Route.php',
+        'think\\console\\command\\optimize\\Schema' => __DIR__ . '/..' . '/topthink/framework/src/think/console/command/optimize/Schema.php',
+        'think\\console\\input\\Argument' => __DIR__ . '/..' . '/topthink/framework/src/think/console/input/Argument.php',
+        'think\\console\\input\\Definition' => __DIR__ . '/..' . '/topthink/framework/src/think/console/input/Definition.php',
+        'think\\console\\input\\Option' => __DIR__ . '/..' . '/topthink/framework/src/think/console/input/Option.php',
+        'think\\console\\output\\Ask' => __DIR__ . '/..' . '/topthink/framework/src/think/console/output/Ask.php',
+        'think\\console\\output\\Descriptor' => __DIR__ . '/..' . '/topthink/framework/src/think/console/output/Descriptor.php',
+        'think\\console\\output\\Formatter' => __DIR__ . '/..' . '/topthink/framework/src/think/console/output/Formatter.php',
+        'think\\console\\output\\Question' => __DIR__ . '/..' . '/topthink/framework/src/think/console/output/Question.php',
+        'think\\console\\output\\descriptor\\Console' => __DIR__ . '/..' . '/topthink/framework/src/think/console/output/descriptor/Console.php',
+        'think\\console\\output\\driver\\Buffer' => __DIR__ . '/..' . '/topthink/framework/src/think/console/output/driver/Buffer.php',
+        'think\\console\\output\\driver\\Console' => __DIR__ . '/..' . '/topthink/framework/src/think/console/output/driver/Console.php',
+        'think\\console\\output\\driver\\Nothing' => __DIR__ . '/..' . '/topthink/framework/src/think/console/output/driver/Nothing.php',
+        'think\\console\\output\\formatter\\Stack' => __DIR__ . '/..' . '/topthink/framework/src/think/console/output/formatter/Stack.php',
+        'think\\console\\output\\formatter\\Style' => __DIR__ . '/..' . '/topthink/framework/src/think/console/output/formatter/Style.php',
+        'think\\console\\output\\question\\Choice' => __DIR__ . '/..' . '/topthink/framework/src/think/console/output/question/Choice.php',
+        'think\\console\\output\\question\\Confirmation' => __DIR__ . '/..' . '/topthink/framework/src/think/console/output/question/Confirmation.php',
+        'think\\contract\\Arrayable' => __DIR__ . '/..' . '/topthink/think-helper/src/contract/Arrayable.php',
+        'think\\contract\\CacheHandlerInterface' => __DIR__ . '/..' . '/topthink/framework/src/think/contract/CacheHandlerInterface.php',
+        'think\\contract\\Jsonable' => __DIR__ . '/..' . '/topthink/think-helper/src/contract/Jsonable.php',
+        'think\\contract\\LogHandlerInterface' => __DIR__ . '/..' . '/topthink/framework/src/think/contract/LogHandlerInterface.php',
+        'think\\contract\\ModelRelationInterface' => __DIR__ . '/..' . '/topthink/framework/src/think/contract/ModelRelationInterface.php',
+        'think\\contract\\SessionHandlerInterface' => __DIR__ . '/..' . '/topthink/framework/src/think/contract/SessionHandlerInterface.php',
+        'think\\contract\\TemplateHandlerInterface' => __DIR__ . '/..' . '/topthink/framework/src/think/contract/TemplateHandlerInterface.php',
+        'think\\db\\BaseQuery' => __DIR__ . '/..' . '/topthink/think-orm/src/db/BaseQuery.php',
+        'think\\db\\Builder' => __DIR__ . '/..' . '/topthink/think-orm/src/db/Builder.php',
+        'think\\db\\CacheItem' => __DIR__ . '/..' . '/topthink/think-orm/src/db/CacheItem.php',
+        'think\\db\\Connection' => __DIR__ . '/..' . '/topthink/think-orm/src/db/Connection.php',
+        'think\\db\\ConnectionInterface' => __DIR__ . '/..' . '/topthink/think-orm/src/db/ConnectionInterface.php',
+        'think\\db\\Fetch' => __DIR__ . '/..' . '/topthink/think-orm/src/db/Fetch.php',
+        'think\\db\\Mongo' => __DIR__ . '/..' . '/topthink/think-orm/src/db/Mongo.php',
+        'think\\db\\PDOConnection' => __DIR__ . '/..' . '/topthink/think-orm/src/db/PDOConnection.php',
+        'think\\db\\Query' => __DIR__ . '/..' . '/topthink/think-orm/src/db/Query.php',
+        'think\\db\\Raw' => __DIR__ . '/..' . '/topthink/think-orm/src/db/Raw.php',
+        'think\\db\\Where' => __DIR__ . '/..' . '/topthink/think-orm/src/db/Where.php',
+        'think\\db\\builder\\Mongo' => __DIR__ . '/..' . '/topthink/think-orm/src/db/builder/Mongo.php',
+        'think\\db\\builder\\Mysql' => __DIR__ . '/..' . '/topthink/think-orm/src/db/builder/Mysql.php',
+        'think\\db\\builder\\Oracle' => __DIR__ . '/..' . '/topthink/think-orm/src/db/builder/Oracle.php',
+        'think\\db\\builder\\Pgsql' => __DIR__ . '/..' . '/topthink/think-orm/src/db/builder/Pgsql.php',
+        'think\\db\\builder\\Sqlite' => __DIR__ . '/..' . '/topthink/think-orm/src/db/builder/Sqlite.php',
+        'think\\db\\builder\\Sqlsrv' => __DIR__ . '/..' . '/topthink/think-orm/src/db/builder/Sqlsrv.php',
+        'think\\db\\concern\\AggregateQuery' => __DIR__ . '/..' . '/topthink/think-orm/src/db/concern/AggregateQuery.php',
+        'think\\db\\concern\\JoinAndViewQuery' => __DIR__ . '/..' . '/topthink/think-orm/src/db/concern/JoinAndViewQuery.php',
+        'think\\db\\concern\\ModelRelationQuery' => __DIR__ . '/..' . '/topthink/think-orm/src/db/concern/ModelRelationQuery.php',
+        'think\\db\\concern\\ParamsBind' => __DIR__ . '/..' . '/topthink/think-orm/src/db/concern/ParamsBind.php',
+        'think\\db\\concern\\ResultOperation' => __DIR__ . '/..' . '/topthink/think-orm/src/db/concern/ResultOperation.php',
+        'think\\db\\concern\\TableFieldInfo' => __DIR__ . '/..' . '/topthink/think-orm/src/db/concern/TableFieldInfo.php',
+        'think\\db\\concern\\TimeFieldQuery' => __DIR__ . '/..' . '/topthink/think-orm/src/db/concern/TimeFieldQuery.php',
+        'think\\db\\concern\\Transaction' => __DIR__ . '/..' . '/topthink/think-orm/src/db/concern/Transaction.php',
+        'think\\db\\concern\\WhereQuery' => __DIR__ . '/..' . '/topthink/think-orm/src/db/concern/WhereQuery.php',
+        'think\\db\\connector\\Mongo' => __DIR__ . '/..' . '/topthink/think-orm/src/db/connector/Mongo.php',
+        'think\\db\\connector\\Mysql' => __DIR__ . '/..' . '/topthink/think-orm/src/db/connector/Mysql.php',
+        'think\\db\\connector\\Oracle' => __DIR__ . '/..' . '/topthink/think-orm/src/db/connector/Oracle.php',
+        'think\\db\\connector\\Pgsql' => __DIR__ . '/..' . '/topthink/think-orm/src/db/connector/Pgsql.php',
+        'think\\db\\connector\\Sqlite' => __DIR__ . '/..' . '/topthink/think-orm/src/db/connector/Sqlite.php',
+        'think\\db\\connector\\Sqlsrv' => __DIR__ . '/..' . '/topthink/think-orm/src/db/connector/Sqlsrv.php',
+        'think\\db\\exception\\BindParamException' => __DIR__ . '/..' . '/topthink/think-orm/src/db/exception/BindParamException.php',
+        'think\\db\\exception\\DataNotFoundException' => __DIR__ . '/..' . '/topthink/think-orm/src/db/exception/DataNotFoundException.php',
+        'think\\db\\exception\\DbException' => __DIR__ . '/..' . '/topthink/think-orm/src/db/exception/DbException.php',
+        'think\\db\\exception\\InvalidArgumentException' => __DIR__ . '/..' . '/topthink/think-orm/src/db/exception/InvalidArgumentException.php',
+        'think\\db\\exception\\ModelEventException' => __DIR__ . '/..' . '/topthink/think-orm/src/db/exception/ModelEventException.php',
+        'think\\db\\exception\\ModelNotFoundException' => __DIR__ . '/..' . '/topthink/think-orm/src/db/exception/ModelNotFoundException.php',
+        'think\\db\\exception\\PDOException' => __DIR__ . '/..' . '/topthink/think-orm/src/db/exception/PDOException.php',
+        'think\\event\\AppInit' => __DIR__ . '/..' . '/topthink/framework/src/think/event/AppInit.php',
+        'think\\event\\HttpEnd' => __DIR__ . '/..' . '/topthink/framework/src/think/event/HttpEnd.php',
+        'think\\event\\HttpRun' => __DIR__ . '/..' . '/topthink/framework/src/think/event/HttpRun.php',
+        'think\\event\\LogWrite' => __DIR__ . '/..' . '/topthink/framework/src/think/event/LogWrite.php',
+        'think\\event\\RouteLoaded' => __DIR__ . '/..' . '/topthink/framework/src/think/event/RouteLoaded.php',
+        'think\\exception\\ClassNotFoundException' => __DIR__ . '/..' . '/topthink/framework/src/think/exception/ClassNotFoundException.php',
+        'think\\exception\\ErrorException' => __DIR__ . '/..' . '/topthink/framework/src/think/exception/ErrorException.php',
+        'think\\exception\\FileException' => __DIR__ . '/..' . '/topthink/framework/src/think/exception/FileException.php',
+        'think\\exception\\FuncNotFoundException' => __DIR__ . '/..' . '/topthink/framework/src/think/exception/FuncNotFoundException.php',
+        'think\\exception\\Handle' => __DIR__ . '/..' . '/topthink/framework/src/think/exception/Handle.php',
+        'think\\exception\\HttpException' => __DIR__ . '/..' . '/topthink/framework/src/think/exception/HttpException.php',
+        'think\\exception\\HttpResponseException' => __DIR__ . '/..' . '/topthink/framework/src/think/exception/HttpResponseException.php',
+        'think\\exception\\InvalidArgumentException' => __DIR__ . '/..' . '/topthink/framework/src/think/exception/InvalidArgumentException.php',
+        'think\\exception\\RouteNotFoundException' => __DIR__ . '/..' . '/topthink/framework/src/think/exception/RouteNotFoundException.php',
+        'think\\exception\\ValidateException' => __DIR__ . '/..' . '/topthink/framework/src/think/exception/ValidateException.php',
+        'think\\facade\\App' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/App.php',
+        'think\\facade\\Cache' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/Cache.php',
+        'think\\facade\\Config' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/Config.php',
+        'think\\facade\\Console' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/Console.php',
+        'think\\facade\\Cookie' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/Cookie.php',
+        'think\\facade\\Db' => __DIR__ . '/..' . '/topthink/think-orm/src/facade/Db.php',
+        'think\\facade\\Env' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/Env.php',
+        'think\\facade\\Event' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/Event.php',
+        'think\\facade\\Facade' => __DIR__ . '/..' . '/topthink/think-orm/src/facade/Db.php',
+        'think\\facade\\Filesystem' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/Filesystem.php',
+        'think\\facade\\Lang' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/Lang.php',
+        'think\\facade\\Log' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/Log.php',
+        'think\\facade\\Middleware' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/Middleware.php',
+        'think\\facade\\Request' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/Request.php',
+        'think\\facade\\Route' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/Route.php',
+        'think\\facade\\Session' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/Session.php',
+        'think\\facade\\Template' => __DIR__ . '/..' . '/topthink/think-template/src/facade/Template.php',
+        'think\\facade\\Validate' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/Validate.php',
+        'think\\facade\\View' => __DIR__ . '/..' . '/topthink/framework/src/think/facade/View.php',
+        'think\\file\\UploadedFile' => __DIR__ . '/..' . '/topthink/framework/src/think/file/UploadedFile.php',
+        'think\\filesystem\\CacheStore' => __DIR__ . '/..' . '/topthink/framework/src/think/filesystem/CacheStore.php',
+        'think\\filesystem\\Driver' => __DIR__ . '/..' . '/topthink/framework/src/think/filesystem/Driver.php',
+        'think\\filesystem\\driver\\Local' => __DIR__ . '/..' . '/topthink/framework/src/think/filesystem/driver/Local.php',
+        'think\\helper\\Arr' => __DIR__ . '/..' . '/topthink/think-helper/src/helper/Arr.php',
+        'think\\helper\\Str' => __DIR__ . '/..' . '/topthink/think-helper/src/helper/Str.php',
+        'think\\initializer\\BootService' => __DIR__ . '/..' . '/topthink/framework/src/think/initializer/BootService.php',
+        'think\\initializer\\Error' => __DIR__ . '/..' . '/topthink/framework/src/think/initializer/Error.php',
+        'think\\initializer\\RegisterService' => __DIR__ . '/..' . '/topthink/framework/src/think/initializer/RegisterService.php',
+        'think\\log\\Channel' => __DIR__ . '/..' . '/topthink/framework/src/think/log/Channel.php',
+        'think\\log\\ChannelSet' => __DIR__ . '/..' . '/topthink/framework/src/think/log/ChannelSet.php',
+        'think\\log\\driver\\File' => __DIR__ . '/..' . '/topthink/framework/src/think/log/driver/File.php',
+        'think\\log\\driver\\Socket' => __DIR__ . '/..' . '/topthink/framework/src/think/log/driver/Socket.php',
+        'think\\middleware\\AllowCrossDomain' => __DIR__ . '/..' . '/topthink/framework/src/think/middleware/AllowCrossDomain.php',
+        'think\\middleware\\CheckRequestCache' => __DIR__ . '/..' . '/topthink/framework/src/think/middleware/CheckRequestCache.php',
+        'think\\middleware\\FormTokenCheck' => __DIR__ . '/..' . '/topthink/framework/src/think/middleware/FormTokenCheck.php',
+        'think\\middleware\\LoadLangPack' => __DIR__ . '/..' . '/topthink/framework/src/think/middleware/LoadLangPack.php',
+        'think\\middleware\\SessionInit' => __DIR__ . '/..' . '/topthink/framework/src/think/middleware/SessionInit.php',
+        'think\\model\\Collection' => __DIR__ . '/..' . '/topthink/think-orm/src/model/Collection.php',
+        'think\\model\\Pivot' => __DIR__ . '/..' . '/topthink/think-orm/src/model/Pivot.php',
+        'think\\model\\Relation' => __DIR__ . '/..' . '/topthink/think-orm/src/model/Relation.php',
+        'think\\model\\concern\\Attribute' => __DIR__ . '/..' . '/topthink/think-orm/src/model/concern/Attribute.php',
+        'think\\model\\concern\\Conversion' => __DIR__ . '/..' . '/topthink/think-orm/src/model/concern/Conversion.php',
+        'think\\model\\concern\\ModelEvent' => __DIR__ . '/..' . '/topthink/think-orm/src/model/concern/ModelEvent.php',
+        'think\\model\\concern\\OptimLock' => __DIR__ . '/..' . '/topthink/think-orm/src/model/concern/OptimLock.php',
+        'think\\model\\concern\\RelationShip' => __DIR__ . '/..' . '/topthink/think-orm/src/model/concern/RelationShip.php',
+        'think\\model\\concern\\SoftDelete' => __DIR__ . '/..' . '/topthink/think-orm/src/model/concern/SoftDelete.php',
+        'think\\model\\concern\\TimeStamp' => __DIR__ . '/..' . '/topthink/think-orm/src/model/concern/TimeStamp.php',
+        'think\\model\\relation\\BelongsTo' => __DIR__ . '/..' . '/topthink/think-orm/src/model/relation/BelongsTo.php',
+        'think\\model\\relation\\BelongsToMany' => __DIR__ . '/..' . '/topthink/think-orm/src/model/relation/BelongsToMany.php',
+        'think\\model\\relation\\HasMany' => __DIR__ . '/..' . '/topthink/think-orm/src/model/relation/HasMany.php',
+        'think\\model\\relation\\HasManyThrough' => __DIR__ . '/..' . '/topthink/think-orm/src/model/relation/HasManyThrough.php',
+        'think\\model\\relation\\HasOne' => __DIR__ . '/..' . '/topthink/think-orm/src/model/relation/HasOne.php',
+        'think\\model\\relation\\HasOneThrough' => __DIR__ . '/..' . '/topthink/think-orm/src/model/relation/HasOneThrough.php',
+        'think\\model\\relation\\MorphMany' => __DIR__ . '/..' . '/topthink/think-orm/src/model/relation/MorphMany.php',
+        'think\\model\\relation\\MorphOne' => __DIR__ . '/..' . '/topthink/think-orm/src/model/relation/MorphOne.php',
+        'think\\model\\relation\\MorphTo' => __DIR__ . '/..' . '/topthink/think-orm/src/model/relation/MorphTo.php',
+        'think\\model\\relation\\MorphToMany' => __DIR__ . '/..' . '/topthink/think-orm/src/model/relation/MorphToMany.php',
+        'think\\model\\relation\\OneToOne' => __DIR__ . '/..' . '/topthink/think-orm/src/model/relation/OneToOne.php',
+        'think\\paginator\\driver\\Bootstrap' => __DIR__ . '/..' . '/topthink/think-orm/src/paginator/driver/Bootstrap.php',
+        'think\\response\\File' => __DIR__ . '/..' . '/topthink/framework/src/think/response/File.php',
+        'think\\response\\Html' => __DIR__ . '/..' . '/topthink/framework/src/think/response/Html.php',
+        'think\\response\\Json' => __DIR__ . '/..' . '/topthink/framework/src/think/response/Json.php',
+        'think\\response\\Jsonp' => __DIR__ . '/..' . '/topthink/framework/src/think/response/Jsonp.php',
+        'think\\response\\Redirect' => __DIR__ . '/..' . '/topthink/framework/src/think/response/Redirect.php',
+        'think\\response\\View' => __DIR__ . '/..' . '/topthink/framework/src/think/response/View.php',
+        'think\\response\\Xml' => __DIR__ . '/..' . '/topthink/framework/src/think/response/Xml.php',
+        'think\\route\\Dispatch' => __DIR__ . '/..' . '/topthink/framework/src/think/route/Dispatch.php',
+        'think\\route\\Domain' => __DIR__ . '/..' . '/topthink/framework/src/think/route/Domain.php',
+        'think\\route\\Resource' => __DIR__ . '/..' . '/topthink/framework/src/think/route/Resource.php',
+        'think\\route\\Rule' => __DIR__ . '/..' . '/topthink/framework/src/think/route/Rule.php',
+        'think\\route\\RuleGroup' => __DIR__ . '/..' . '/topthink/framework/src/think/route/RuleGroup.php',
+        'think\\route\\RuleItem' => __DIR__ . '/..' . '/topthink/framework/src/think/route/RuleItem.php',
+        'think\\route\\RuleName' => __DIR__ . '/..' . '/topthink/framework/src/think/route/RuleName.php',
+        'think\\route\\Url' => __DIR__ . '/..' . '/topthink/framework/src/think/route/Url.php',
+        'think\\route\\dispatch\\Callback' => __DIR__ . '/..' . '/topthink/framework/src/think/route/dispatch/Callback.php',
+        'think\\route\\dispatch\\Controller' => __DIR__ . '/..' . '/topthink/framework/src/think/route/dispatch/Controller.php',
+        'think\\route\\dispatch\\Url' => __DIR__ . '/..' . '/topthink/framework/src/think/route/dispatch/Url.php',
+        'think\\service\\ModelService' => __DIR__ . '/..' . '/topthink/framework/src/think/service/ModelService.php',
+        'think\\service\\PaginatorService' => __DIR__ . '/..' . '/topthink/framework/src/think/service/PaginatorService.php',
+        'think\\service\\ValidateService' => __DIR__ . '/..' . '/topthink/framework/src/think/service/ValidateService.php',
+        'think\\session\\Store' => __DIR__ . '/..' . '/topthink/framework/src/think/session/Store.php',
+        'think\\session\\driver\\Cache' => __DIR__ . '/..' . '/topthink/framework/src/think/session/driver/Cache.php',
+        'think\\session\\driver\\File' => __DIR__ . '/..' . '/topthink/framework/src/think/session/driver/File.php',
+        'think\\template\\TagLib' => __DIR__ . '/..' . '/topthink/think-template/src/template/TagLib.php',
+        'think\\template\\driver\\File' => __DIR__ . '/..' . '/topthink/think-template/src/template/driver/File.php',
+        'think\\template\\exception\\TemplateNotFoundException' => __DIR__ . '/..' . '/topthink/think-template/src/template/exception/TemplateNotFoundException.php',
+        'think\\template\\taglib\\Cx' => __DIR__ . '/..' . '/topthink/think-template/src/template/taglib/Cx.php',
+        'think\\validate\\ValidateRule' => __DIR__ . '/..' . '/topthink/framework/src/think/validate/ValidateRule.php',
+        'think\\view\\driver\\Php' => __DIR__ . '/..' . '/topthink/framework/src/think/view/driver/Php.php',
+        'think\\view\\driver\\Think' => __DIR__ . '/..' . '/topthink/think-view/src/Think.php',
     );
 
     public static function getInitializer(ClassLoader $loader)

+ 6 - 6
vendor/composer/installed.json

@@ -958,17 +958,17 @@
     },
     {
         "name": "zoujingli/think-library",
-        "version": "v6.0.4",
-        "version_normalized": "6.0.4.0",
+        "version": "v6.0.x-dev",
+        "version_normalized": "6.0.9999999.9999999-dev",
         "source": {
             "type": "git",
             "url": "https://github.com/zoujingli/ThinkLibrary.git",
-            "reference": "8ae46bac7e9c1a17cc111fffa9a5d91669eaa756"
+            "reference": "2c0b63b9a34de703a52fbc3018417b95235b3a1f"
         },
         "dist": {
             "type": "zip",
-            "url": "https://api.github.com/repos/zoujingli/ThinkLibrary/zipball/8ae46bac7e9c1a17cc111fffa9a5d91669eaa756",
-            "reference": "8ae46bac7e9c1a17cc111fffa9a5d91669eaa756",
+            "url": "https://api.github.com/repos/zoujingli/ThinkLibrary/zipball/2c0b63b9a34de703a52fbc3018417b95235b3a1f",
+            "reference": "2c0b63b9a34de703a52fbc3018417b95235b3a1f",
             "shasum": "",
             "mirrors": [
                 {
@@ -985,7 +985,7 @@
             "ext-mbstring": "*",
             "topthink/framework": "^6.0"
         },
-        "time": "2020-09-04T06:32:24+00:00",
+        "time": "2020-09-08T02:23:12+00:00",
         "type": "library",
         "extra": {
             "think": {

+ 1 - 1
vendor/services.php

@@ -1,5 +1,5 @@
 <?php 
-// This file is automatically generated at:2020-09-07 10:11:02
+// This file is automatically generated at:2020-09-08 10:39:45
 declare (strict_types = 1);
 return array (
   0 => 'think\\admin\\Library',

+ 2 - 2
vendor/zoujingli/think-library/src/Command.php

@@ -87,7 +87,7 @@ abstract class Command extends ThinkCommand
      * @return static
      * @throws Exception
      */
-    protected function setQueueError($message)
+    protected function setQueueError(string $message)
     {
         if (defined('WorkQueueCode')) {
             throw new Exception($message, 4, WorkQueueCode);
@@ -103,7 +103,7 @@ abstract class Command extends ThinkCommand
      * @return static
      * @throws Exception
      */
-    protected function setQueueSuccess($message)
+    protected function setQueueSuccess(string $message)
     {
         if (defined('WorkQueueCode')) {
             throw new Exception($message, 3, WorkQueueCode);

+ 4 - 4
vendor/zoujingli/think-library/src/Helper.php

@@ -43,17 +43,17 @@ abstract class Helper
      * 控制器实例
      * @var Controller
      */
-    public $controller;
+    public $class;
 
     /**
      * Helper constructor.
      * @param App $app
-     * @param Controller $controller
+     * @param Controller $class
      */
-    public function __construct(Controller $controller, App $app)
+    public function __construct(Controller $class, App $app)
     {
         $this->app = $app;
-        $this->controller = $controller;
+        $this->class = $class;
     }
 
     /**

+ 1 - 1
vendor/zoujingli/think-library/src/Library.php

@@ -41,7 +41,7 @@ class Library extends Service
     /**
      * 扩展库版本号
      */
-    const VERSION = '6.0.4';
+    const VERSION = '6.0.5';
 
     /**
      * 启动服务

+ 6 - 6
vendor/zoujingli/think-library/src/Storage.php

@@ -117,7 +117,7 @@ abstract class Storage
      * @param string $fun 名称规则方法
      * @return string
      */
-    public static function name($url, $ext = '', $pre = '', $fun = 'md5')
+    public static function name(string $url, string $ext = '', string $pre = '', string $fun = 'md5'): string
     {
         [$hah, $ext] = [$fun($url), trim($ext ?: pathinfo($url, 4), '.\\/')];
         $attr = [trim($pre, '.\\/'), substr($hah, 0, 2), substr($hah, 2, 30)];
@@ -131,7 +131,7 @@ abstract class Storage
      * @param integer $expire 文件保留时间
      * @return array
      */
-    public static function down($url, $force = false, $expire = 0)
+    public static function down(string $url, bool $force = false, int $expire = 0): array
     {
         try {
             $file = LocalStorage::instance();
@@ -153,7 +153,7 @@ abstract class Storage
      * @param array $mime 文件信息
      * @return string
      */
-    public static function mime($exts, $mime = [])
+    public static function mime($exts, array $mime = []): string
     {
         $mimes = static::mimes();
         foreach (is_string($exts) ? explode(',', $exts) : $exts as $ext) {
@@ -178,7 +178,7 @@ abstract class Storage
      * @param string $url
      * @return string
      */
-    public static function curlGet($url)
+    public static function curlGet(string $url)
     {
         $ch = curl_init();
         curl_setopt($ch, CURLOPT_URL, $url);
@@ -196,7 +196,7 @@ abstract class Storage
      * @param string $attname 下载名称
      * @return string
      */
-    protected function getSuffix($attname = null)
+    protected function getSuffix(string $attname = null): string
     {
         if ($this->linkType === 'full') {
             if (is_string($attname) && strlen($attname) > 0) {
@@ -211,7 +211,7 @@ abstract class Storage
      * @param string $name 文件名称
      * @return string
      */
-    protected function delSuffix($name)
+    protected function delSuffix(string $name): string
     {
         if (strpos($name, '?') !== false) {
             return strstr($name, '?', true);

+ 1 - 1
vendor/zoujingli/think-library/src/common.php

@@ -40,7 +40,7 @@ if (!function_exists('auth')) {
      * @return boolean
      * @throws ReflectionException
      */
-    function auth($node)
+    function auth($node): bool
     {
         return AdminService::instance()->check($node);
     }

+ 3 - 3
vendor/zoujingli/think-library/src/extend/CodeExtend.php

@@ -29,7 +29,7 @@ class CodeExtend
      * @param string $prefix 编码前缀
      * @return string
      */
-    public static function random($size = 10, $type = 1, $prefix = '')
+    public static function random(int $size = 10, int $type = 1, string $prefix = ''): string
     {
         $numbs = '0123456789';
         $chars = 'abcdefghijklmnopqrstuvwxyz';
@@ -48,7 +48,7 @@ class CodeExtend
      * @param string $prefix
      * @return string
      */
-    public static function uniqidDate($size = 16, $prefix = '')
+    public static function uniqidDate(int $size = 16, string $prefix = ''): string
     {
         if ($size < 14) $size = 14;
         $string = $prefix . date('Ymd') . (date('H') + date('i')) . date('s');
@@ -62,7 +62,7 @@ class CodeExtend
      * @param string $prefix
      * @return string
      */
-    public static function uniqidNumber($size = 12, $prefix = '')
+    public static function uniqidNumber(int $size = 12, string $prefix = ''): string
     {
         $time = time() . '';
         if ($size < 10) $size = 10;

+ 6 - 6
vendor/zoujingli/think-library/src/extend/DataExtend.php

@@ -31,7 +31,7 @@ class DataExtend
      * @param string $sub 子数组名称
      * @return array
      */
-    public static function arr2tree($list, $cid = 'id', $pid = 'pid', $sub = 'sub')
+    public static function arr2tree(array $list, string $cid = 'id', string $pid = 'pid', string $sub = 'sub'): array
     {
         [$tree, $tmp] = [[], array_combine(array_column($list, $cid), array_values($list))];
         foreach ($list as $vo) isset($vo[$pid]) && isset($tmp[$vo[$pid]]) ? $tmp[$vo[$pid]][$sub][] = &$tmp[$vo[$cid]] : $tree[] = &$tmp[$vo[$cid]];
@@ -48,7 +48,7 @@ class DataExtend
      * @param string $ppath 上级 PATH
      * @return array
      */
-    public static function arr2table(array $list, $cid = 'id', $pid = 'pid', $cpath = 'path', $ppath = '')
+    public static function arr2table(array $list, string $cid = 'id', string $pid = 'pid', string $cpath = 'path', string $ppath = ''): array
     {
         $tree = [];
         foreach (static::arr2tree($list, $cid, $pid) as $attr) {
@@ -68,16 +68,16 @@ class DataExtend
     /**
      * 获取数据树子ID
      * @param array $list 数据列表
-     * @param integer $id 起始ID
-     * @param string $key ID_KEY
+     * @param mixed $id 起始ID
+     * @param string $ckey ID_KEY
      * @param string $pkey PID_KEY
      * @return array
      */
-    public static function getArrSubIds($list, $id = 0, $key = 'id', $pkey = 'pid')
+    public static function getArrSubIds(array $list, $id = 0, string $ckey = 'id', string $pkey = 'pid'): array
     {
         $ids = [intval($id)];
         foreach ($list as $vo) if (intval($vo[$pkey]) > 0 && intval($vo[$pkey]) === intval($id)) {
-            $ids = array_merge($ids, static::getArrSubIds($list, intval($vo[$key]), $key, $pkey));
+            $ids = array_merge($ids, static::getArrSubIds($list, intval($vo[$ckey]), $ckey, $pkey));
         }
         return $ids;
     }

+ 5 - 5
vendor/zoujingli/think-library/src/extend/HttpExtend.php

@@ -29,7 +29,7 @@ class HttpExtend
      * @param array $options CURL请求参数
      * @return boolean|string
      */
-    public static function get($location, $query = [], array $options = [])
+    public static function get(string $location, array $query = [], array $options = [])
     {
         $options['query'] = $query;
         return static::request('get', $location, $options);
@@ -42,7 +42,7 @@ class HttpExtend
      * @param array $options CURL请求参数
      * @return boolean|string
      */
-    public static function post($location, $data = [], array $options = [])
+    public static function post(string $location, array $data = [], array $options = [])
     {
         $options['data'] = $data;
         return static::request('post', $location, $options);
@@ -58,7 +58,7 @@ class HttpExtend
      * @param boolean $returnHeader 是否返回头部信息
      * @return boolean|string
      */
-    public static function submit($url, array $data = [], array $file = [], array $header = [], $method = 'POST', $returnHeader = true)
+    public static function submit(string $url, array $data = [], array $file = [], array $header = [], string $method = 'POST', bool $returnHeader = true)
     {
         [$line, $boundary] = [[], CodeExtend::random(18)];
         foreach ($data as $key => $value) {
@@ -85,7 +85,7 @@ class HttpExtend
      * @param array $options 请求参数[headers,query,data,cookie,cookie_file,timeout,returnHeader]
      * @return boolean|string
      */
-    public static function request($method, $location, array $options = [])
+    public static function request(string $method, string $location, array $options = [])
     {
         // GET 参数设置
         if (!empty($options['query'])) {
@@ -142,7 +142,7 @@ class HttpExtend
      * 获取浏览器代理信息
      * @return string
      */
-    private static function getUserAgent()
+    private static function getUserAgent(): string
     {
         if (!empty($_SERVER['HTTP_USER_AGENT'])) return $_SERVER['HTTP_USER_AGENT'];
         $agents = [

+ 1 - 1
vendor/zoujingli/think-library/src/extend/JsonRpcClient.php

@@ -51,7 +51,7 @@ class JsonRpcClient
      * @return mixed
      * @throws \think\admin\Exception
      */
-    public function __call($method, $params)
+    public function __call(string $method, array $params)
     {
         // Performs the HTTP POST
         $options = [

+ 16 - 28
vendor/zoujingli/think-library/src/helper/DeleteHelper.php

@@ -26,18 +26,6 @@ use think\db\Query;
 class DeleteHelper extends Helper
 {
     /**
-     * 数据对象主键名称
-     * @var string
-     */
-    protected $field;
-
-    /**
-     * 数据对象主键值
-     * @var string
-     */
-    protected $value;
-
-    /**
      * 逻辑器初始化
      * @param string|Query $dbQuery
      * @param string $field 操作数据主键
@@ -45,42 +33,42 @@ class DeleteHelper extends Helper
      * @return boolean|null|void
      * @throws \think\db\exception\DbException
      */
-    public function init($dbQuery, $field = '', $where = [])
+    public function init($dbQuery, string $field = '', array $where = [])
     {
-        $this->query = $this->buildQuery($dbQuery);
-        $this->field = $field ?: $this->query->getPk();
-        $this->value = $this->app->request->post($this->field, null);
+        $query = $this->buildQuery($dbQuery);
+        $field = $field ?: ($query->getPk() ?: 'id');
+        $value = $this->app->request->post($field, null);
         // 查询限制处理
-        if (!empty($where)) $this->query->where($where);
-        if (!isset($where[$this->field]) && is_string($this->value)) {
-            $this->query->whereIn($this->field, explode(',', $this->value));
+        if (!empty($where)) $query->where($where);
+        if (!isset($where[$field]) && is_string($value)) {
+            $query->whereIn($field, explode(',', $value));
         }
         // 前置回调处理
-        if (false === $this->controller->callback('_delete_filter', $this->query, $where)) {
+        if (false === $this->class->callback('_delete_filter', $query, $where)) {
             return null;
         }
         // 阻止危险操作
-        if (!$this->query->getOptions('where')) {
-            $this->controller->error(lang('think_library_delete_error'));
+        if (!$query->getOptions('where')) {
+            $this->class->error(lang('think_library_delete_error'));
         }
         // 组装执行数据
         $data = [];
-        if (method_exists($this->query, 'getTableFields')) {
-            $fields = $this->query->getTableFields();
+        if (method_exists($query, 'getTableFields')) {
+            $fields = $query->getTableFields();
             if (in_array('deleted', $fields)) $data['deleted'] = 1;
             if (in_array('is_deleted', $fields)) $data['is_deleted'] = 1;
         }
         // 执行删除操作
-        $result = empty($data) ? $this->query->delete() : $this->query->update($data);
+        $result = empty($data) ? $query->delete() : $query->update($data);
         // 结果回调处理
-        if (false === $this->controller->callback('_delete_result', $result)) {
+        if (false === $this->class->callback('_delete_result', $result)) {
             return $result;
         }
         // 回复返回结果
         if ($result !== false) {
-            $this->controller->success(lang('think_library_delete_success'), '');
+            $this->class->success(lang('think_library_delete_success'), '');
         } else {
-            $this->controller->error(lang('think_library_delete_error'));
+            $this->class->error(lang('think_library_delete_error'));
         }
     }
 }

+ 15 - 46
vendor/zoujingli/think-library/src/helper/FormHelper.php

@@ -25,35 +25,6 @@ use think\db\Query;
  */
 class FormHelper extends Helper
 {
-    /**
-     * 表单扩展数据
-     * @var array
-     */
-    protected $data;
-
-    /**
-     * 表单额外更新条件
-     * @var array
-     */
-    protected $where;
-
-    /**
-     * 数据对象主键名称
-     * @var string
-     */
-    protected $field;
-
-    /**
-     * 数据对象主键值
-     * @var string
-     */
-    protected $value;
-
-    /**
-     * 表单模板文件
-     * @var string
-     */
-    protected $template;
 
     /**
      * 逻辑器初始化
@@ -67,34 +38,32 @@ class FormHelper extends Helper
      * @throws \think\db\exception\DbException
      * @throws \think\db\exception\ModelNotFoundException
      */
-    public function init($dbQuery, $template = '', $field = '', $where = [], $data = [])
+    public function init($dbQuery, string $template = '', string $field = '', array $where = [], array $data = [])
     {
-        $this->query = $this->buildQuery($dbQuery);
-        [$this->template, $this->where, $this->data] = [$template, $where, $data];
-        $this->field = $field ?: ($this->query->getPk() ?: 'id');
-        $this->value = input($this->field, $data[$this->field] ?? null);
+        $query = $this->buildQuery($dbQuery);
+        $field = $field ?: ($query->getPk() ?: 'id');
+        $value = input($field, $data[$field] ?? null);
         // GET请求, 获取数据并显示表单页面
         if ($this->app->request->isGet()) {
-            if ($this->value !== null) {
-                $where = [$this->field => $this->value];
-                $data = (array)$this->query->where($where)->where($this->where)->find();
+            if ($value !== null) {
+                $find = $query->where([$field => $value])->where($where)->find();
+                if (!empty($find) && is_array($find)) $data = array_merge($data, $find);
             }
-            $data = array_merge($data, $this->data);
-            if (false !== $this->controller->callback('_form_filter', $data)) {
-                return $this->controller->fetch($this->template, ['vo' => $data]);
+            if (false !== $this->class->callback('_form_filter', $data)) {
+                return $this->class->fetch($template, ['vo' => $data]);
             }
             return $data;
         }
         // POST请求, 数据自动存库处理
         if ($this->app->request->isPost()) {
-            $data = array_merge($this->app->request->post(), $this->data);
-            if (false !== $this->controller->callback('_form_filter', $data, $this->where)) {
-                $result = data_save($this->query, $data, $this->field, $this->where);
-                if (false !== $this->controller->callback('_form_result', $result, $data)) {
+            $data = array_merge($this->app->request->post(), $data);
+            if (false !== $this->class->callback('_form_filter', $data, $where)) {
+                $result = data_save($query, $data, $field, $where);
+                if (false !== $this->class->callback('_form_result', $result, $data)) {
                     if ($result !== false) {
-                        $this->controller->success(lang('think_library_form_success'));
+                        $this->class->success(lang('think_library_form_success'));
                     } else {
-                        $this->controller->error(lang('think_library_form_error'));
+                        $this->class->error(lang('think_library_form_error'));
                     }
                 }
                 return $result;

+ 10 - 37
vendor/zoujingli/think-library/src/helper/PageHelper.php

@@ -25,29 +25,6 @@ use think\db\Query;
  */
 class PageHelper extends Helper
 {
-    /**
-     * 是否启用分页
-     * @var boolean
-     */
-    protected $page;
-
-    /**
-     * 集合分页记录数
-     * @var integer
-     */
-    protected $total;
-
-    /**
-     * 集合每页记录数
-     * @var integer
-     */
-    protected $limit;
-
-    /**
-     * 是否渲染模板
-     * @var boolean
-     */
-    protected $display;
 
     /**
      * 逻辑器初始化
@@ -64,25 +41,21 @@ class PageHelper extends Helper
      */
     public function init($dbQuery, $page = true, $display = true, $total = false, $limit = 0, $template = '')
     {
-        $this->page = $page;
-        $this->total = $total;
-        $this->limit = $limit;
-        $this->display = $display;
         $this->query = $this->buildQuery($dbQuery);
         // 数据列表排序自动处理
         if ($this->app->request->isPost()) $this->sortAction();
         // 列表设置默认排序处理
         if (!$this->query->getOptions('order')) $this->orderAction();
         // 列表分页及结果集处理
-        if ($this->page) {
-            if ($this->limit > 0) {
-                $limit = intval($this->limit);
+        if ($page) {
+            if ($limit > 0) {
+                $limit = intval($limit);
             } else {
                 $limit = $this->app->request->get('limit', $this->app->cookie->get('limit'));
                 $this->app->cookie->set('limit', $limit = intval($limit >= 10 ? $limit : 20));
             }
             [$options, $query] = ['', $this->app->request->get()];
-            $pager = $this->query->paginate(['list_rows' => $limit, 'query' => $query], $this->total);
+            $pager = $this->query->paginate(['list_rows' => $limit, 'query' => $query], $total);
             foreach ([10, 20, 30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130, 140, 150, 160, 170, 180, 190, 200] as $num) {
                 [$query['limit'], $query['page'], $selects] = [$num, 1, $limit === $num ? 'selected' : ''];
                 if (stripos($this->app->request->get('spm', '-'), 'm-') === 0) {
@@ -96,16 +69,16 @@ class PageHelper extends Helper
             $pagetext = lang('think_library_page_html', [$pager->total(), $selects, $pager->lastPage(), $pager->currentPage()]);
             $pagehtml = "<div class='pagination-container nowrap'><span>{$pagetext}</span>{$pager->render()}</div>";
             if (stripos($this->app->request->get('spm', '-'), 'm-') === 0) {
-                $this->controller->assign('pagehtml', preg_replace('|href="(.*?)"|', 'data-open="$1" onclick="return false" href="$1"', $pagehtml));
+                $this->class->assign('pagehtml', preg_replace('|href="(.*?)"|', 'data-open="$1" onclick="return false" href="$1"', $pagehtml));
             } else {
-                $this->controller->assign('pagehtml', $pagehtml);
+                $this->class->assign('pagehtml', $pagehtml);
             }
             $result = ['page' => ['limit' => intval($limit), 'total' => intval($pager->total()), 'pages' => intval($pager->lastPage()), 'current' => intval($pager->currentPage())], 'list' => $pager->items()];
         } else {
             $result = ['list' => $this->query->select()->toArray()];
         }
-        if (false !== $this->controller->callback('_page_filter', $result['list']) && $this->display) {
-            return $this->controller->fetch($template, $result);
+        if (false !== $this->class->callback('_page_filter', $result['list']) && $display) {
+            return $this->class->fetch($template, $result);
         } else {
             return $result;
         }
@@ -125,11 +98,11 @@ class PageHelper extends Helper
                     $map = [$pk => $this->app->request->post($pk, 0)];
                     $data = ['sort' => intval($this->app->request->post('sort', 0))];
                     if ($this->app->db->table($this->query->getTable())->where($map)->update($data) !== false) {
-                        $this->controller->success(lang('think_library_sort_success'), '');
+                        $this->class->success(lang('think_library_sort_success'), '');
                     }
                 }
             }
-            $this->controller->error($message ?? lang('think_library_sort_error'));
+            $this->class->error(lang('think_library_sort_error'));
         }
     }
 

+ 12 - 36
vendor/zoujingli/think-library/src/helper/SaveHelper.php

@@ -25,29 +25,6 @@ use think\db\Query;
  */
 class SaveHelper extends Helper
 {
-    /**
-     * 表单扩展数据
-     * @var array
-     */
-    protected $data;
-
-    /**
-     * 表单额外更新条件
-     * @var array
-     */
-    protected $where;
-
-    /**
-     * 数据对象主键名称
-     * @var array|string
-     */
-    protected $field;
-
-    /**
-     * 数据对象主键值
-     * @var string
-     */
-    protected $value;
 
     /**
      * 逻辑器初始化
@@ -60,31 +37,30 @@ class SaveHelper extends Helper
      */
     public function init($dbQuery, $data = [], $field = '', $where = [])
     {
-        $this->where = $where;
-        $this->query = $this->buildQuery($dbQuery);
-        $this->field = $field ?: $this->query->getPk();
-        $this->data = $data ?: $this->app->request->post();
-        $this->value = $this->app->request->post($this->field, null);
+        $query = $this->buildQuery($dbQuery);
+        $data = $data ?: $this->app->request->post();
+        $field = $field ?: ($query->getPk() ?: 'id');
+        $value = $this->app->request->post($field, null);
         // 主键限制处理
-        if (!isset($this->where[$this->field]) && is_string($this->value)) {
-            $this->query->whereIn($this->field, explode(',', $this->value));
-            if (isset($this->data)) unset($this->data[$this->field]);
+        if (!isset($where[$field]) && is_string($value)) {
+            $query->whereIn($field, explode(',', $value));
+            if (isset($data)) unset($data[$field]);
         }
         // 前置回调处理
-        if (false === $this->controller->callback('_save_filter', $this->query, $this->data)) {
+        if (false === $this->class->callback('_save_filter', $query, $data)) {
             return false;
         }
         // 执行更新操作
-        $result = $this->query->where($this->where)->update($this->data) !== false;
+        $result = $query->where($where)->update($data) !== false;
         // 结果回调处理
-        if (false === $this->controller->callback('_save_result', $result)) {
+        if (false === $this->class->callback('_save_result', $result)) {
             return $result;
         }
         // 回复前端结果
         if ($result !== false) {
-            $this->controller->success(lang('think_library_save_success'), '');
+            $this->class->success(lang('think_library_save_success'), '');
         } else {
-            $this->controller->error(lang('think_library_save_error'));
+            $this->class->error(lang('think_library_save_error'));
         }
     }
 

+ 2 - 2
vendor/zoujingli/think-library/src/helper/TokenHelper.php

@@ -34,10 +34,10 @@ class TokenHelper extends Helper
      */
     public function init($return = false)
     {
-        $this->controller->csrf_state = true;
+        $this->class->csrf_state = true;
         if ($this->app->request->isPost() && !TokenService::instance()->checkFormToken()) {
             if ($return) return false;
-            $this->controller->error($this->controller->csrf_message);
+            $this->class->error($this->class->csrf_message);
         } else {
             return true;
         }

+ 3 - 3
vendor/zoujingli/think-library/src/helper/ValidateHelper.php

@@ -41,8 +41,8 @@ class ValidateHelper extends Helper
     public function init(array $rules, $input = '', $callable = null): array
     {
         if (is_string($input)) {
-            $input = trim($input, '.') ?: 'request';
-            $input = $this->app->request->$input();
+            $type = trim($input, '.') ?: 'request';
+            $input = $this->app->request->$type();
         }
         [$data, $rule, $info] = [[], [], []];
         foreach ($rules as $name => $message) if (is_numeric($name)) {
@@ -67,7 +67,7 @@ class ValidateHelper extends Helper
         } elseif (is_callable($callable)) {
             return call_user_func($callable, $validate->getError());
         } else {
-            return $this->controller->error($validate->getError());
+            return $this->class->error($validate->getError());
         }
     }
 }

+ 6 - 6
vendor/zoujingli/think-library/src/service/AdminService.php

@@ -30,7 +30,7 @@ class AdminService extends Service
      * 是否已经登录
      * @return boolean
      */
-    public function isLogin()
+    public function isLogin(): bool
     {
         return $this->getUserId() > 0;
     }
@@ -39,7 +39,7 @@ class AdminService extends Service
      * 是否为超级用户
      * @return boolean
      */
-    public function isSuper()
+    public function isSuper(): bool
     {
         return $this->getUserName() === 'admin';
     }
@@ -48,7 +48,7 @@ class AdminService extends Service
      * 获取后台用户ID
      * @return integer
      */
-    public function getUserId()
+    public function getUserId(): int
     {
         return intval($this->app->session->get('user.id', 0));
     }
@@ -57,7 +57,7 @@ class AdminService extends Service
      * 获取后台用户名称
      * @return string
      */
-    public function getUserName()
+    public function getUserName(): string
     {
         return $this->app->session->get('user.username', '');
     }
@@ -69,7 +69,7 @@ class AdminService extends Service
      * @return boolean
      * @throws \ReflectionException
      */
-    public function check($node = '')
+    public function check(string $node = ''): bool
     {
         if ($this->isSuper()) return true;
         $service = NodeService::instance();
@@ -95,7 +95,7 @@ class AdminService extends Service
      * @return array
      * @throws \ReflectionException
      */
-    public function getTree($checkeds = [])
+    public function getTree(array $checkeds = []): array
     {
         [$nodes, $pnodes, $methods] = [[], [], array_reverse(NodeService::instance()->getMethods())];
         foreach ($methods as $node => $method) {

+ 5 - 5
vendor/zoujingli/think-library/src/service/CaptchaService.php

@@ -71,7 +71,7 @@ class CaptchaService extends Service
      * 获取验证码值
      * @return string
      */
-    public function getCode()
+    public function getCode(): string
     {
         return $this->code;
     }
@@ -80,7 +80,7 @@ class CaptchaService extends Service
      * 获取图片内容
      * @return string
      */
-    public function getData()
+    public function getData(): string
     {
         return "data:image/png;base64,{$this->createImage()}";
     }
@@ -89,7 +89,7 @@ class CaptchaService extends Service
      * 获取验证码编号
      * @return string
      */
-    public function getUniqid()
+    public function getUniqid(): string
     {
         return $this->uniqid;
     }
@@ -98,7 +98,7 @@ class CaptchaService extends Service
      * 获取验证码数据
      * @return array
      */
-    public function getAttrs()
+    public function getAttrs(): array
     {
         return [
             'code'   => $this->getCode(),
@@ -113,7 +113,7 @@ class CaptchaService extends Service
      * @param string $uniqid 验证码编号
      * @return boolean
      */
-    public function check($code, $uniqid = null)
+    public function check(string $code, $uniqid = null): bool
     {
         $_uni = is_string($uniqid) ? $uniqid : input('uniqid', '-');
         $_val = $this->app->cache->get($_uni, '');

+ 2 - 2
vendor/zoujingli/think-library/src/service/ExpressService.php

@@ -65,7 +65,7 @@ class ExpressService extends Service
      * @param array $list 快递路径列表
      * @return array
      */
-    public function express($code, $number, $list = [])
+    public function express(string $code, string $number, array $list = []): array
     {
         // 1-新订单,2-在途中,3-签收,4-问题件
         // 0-在途,1-揽收,2-疑难,3-签收,4-退签,5-派件,6-退回
@@ -90,7 +90,7 @@ class ExpressService extends Service
      * @param array $data
      * @return array
      */
-    public function getExpressList($data = [])
+    public function getExpressList(array $data = []): array
     {
         if (preg_match('/"currentData":.*?\[(.*?)],/', $this->getWapBaiduHtml(), $matches)) {
             foreach (json_decode("[{$matches['1']}]") as $item) $data[$item->value] = $item->text;

+ 40 - 44
vendor/zoujingli/think-library/src/service/ModuleService.php

@@ -60,7 +60,7 @@ class ModuleService extends Service
      * 获取服务端地址
      * @return string
      */
-    public function getServer()
+    public function getServer(): string
     {
         return $this->server;
     }
@@ -69,7 +69,7 @@ class ModuleService extends Service
      * 获取版本号信息
      * @return string
      */
-    public function getVersion()
+    public function getVersion(): string
     {
         return $this->version;
     }
@@ -172,8 +172,8 @@ class ModuleService extends Service
     {
         // 扫描规则文件
         foreach ($rules as $key => $rule) {
-            $name = strtr(trim($rule, '\\/'), '\\', '/');
-            $data = array_merge($data, $this->_scanLocalFileHashList($this->root . $name));
+            $path = $this->root . strtr(trim($rule, '\\/'), '\\', '/');
+            $data = array_merge($data, $this->_scanLocalFileHashList($path));
         }
         // 清除忽略文件
         foreach ($data as $key => $item) foreach ($ignore as $ign) {
@@ -191,17 +191,17 @@ class ModuleService extends Service
     public function checkAllowDownload(string $name): bool
     {
         // 禁止目录级别上跳
-        if (stripos($name, '../') !== false) {
+        if (stripos($name, '..') !== false) {
             return false;
         }
+        // 禁止非官方演示项目下载,不支持通过指令更新
+        // if (!SystemService::instance()->checkRunMode('dev')) {
+        //    return false;
+        // }
         // 禁止下载数据库配置文件
         if (stripos(strtr($name, '\\', '/'), 'config/database') !== false) {
             return false;
         }
-        // 禁止非官方演示项目下载
-        if (!SystemService::instance()->checkRunMode('dev')) {
-            return false;
-        }
         // 检查允许下载的文件规则
         foreach ($this->_getAllowDownloadRule() as $rule) {
             if (stripos($name, $rule) === 0) return true;
@@ -212,25 +212,24 @@ class ModuleService extends Service
 
     /**
      * 获取文件差异数据
-     * @param array $rules 文件规则
+     * @param array $rules 查询规则
      * @param array $ignore 忽略规则
+     * @param array $result 差异数据
      * @return array
      */
-    public function grenerateDifference(array $rules = [], array $ignore = []): array
+    public function grenerateDifference(array $rules = [], array $ignore = [], array $result = []): array
     {
-        [$rules1, $ignore1, $data] = [$rules, $ignore, []];
-        $result = json_decode(HttpExtend::post($this->server . '/admin/api.update/node', [
-            'rules' => json_encode($rules1), 'ignore' => json_encode($ignore1),
+        $online = json_decode(HttpExtend::post($this->server . '/admin/api.update/node', [
+            'rules' => json_encode($rules), 'ignore' => json_encode($ignore),
         ]), true);
-        if (!empty($result['code'])) {
-            $new = $this->getChanges($result['data']['rules'], $result['data']['ignore']);
-            foreach ($this->_grenerateDifferenceContrast($result['data']['list'], $new['list']) as $file) {
-                if (in_array($file['type'], ['add', 'del', 'mod'])) foreach ($rules1 as $rule) {
-                    if (stripos($file['name'], $rule) === 0) $data[] = $file;
-                }
+        if (empty($online['code'])) return $result;
+        $change = $this->getChanges($online['data']['rules'] ?? [], $online['data']['ignore'] ?? []);
+        foreach ($this->_grenerateDifferenceContrast($online['data']['list'], $change['list']) as $file) {
+            if (in_array($file['type'], ['add', 'del', 'mod'])) foreach ($rules as $rule) {
+                if (stripos($file['name'], $rule) === 0) $result[] = $file;
             }
         }
-        return $data;
+        return $result;
     }
 
     /**
@@ -326,28 +325,24 @@ class ModuleService extends Service
 
     /**
      * 根据线上线下生成操作数组
-     * @param array $serve 线上文件列表信息
-     * @param array $local 本地文件列表信息
+     * @param array $serve 线上文件数据
+     * @param array $local 本地文件数据
+     * @param array $diffy 计算结果数据
      * @return array
      */
-    private function _grenerateDifferenceContrast(array $serve = [], array $local = []): array
+    private function _grenerateDifferenceContrast(array $serve = [], array $local = [], array $diffy = []): array
     {
-        // 数据扁平化
-        [$_serve, $_local, $_diffy] = [[], [], []];
-        foreach ($serve as $t) $_serve[$t['name']] = $t;
-        foreach ($local as $t) $_local[$t['name']] = $t;
-        unset($serve, $local);
-        // 线上数据差异计算
-        foreach ($_serve as $t) isset($_local[$t['name']]) ? array_push($_diffy, [
-            'type' => $t['hash'] === $_local[$t['name']]['hash'] ? null : 'mod', 'name' => $t['name'],
-        ]) : array_push($_diffy, ['type' => 'add', 'name' => $t['name']]);
-        // 本地数据增量计算
-        foreach ($_local as $t) if (!isset($_serve[$t['name']])) array_push($_diffy, ['type' => 'del', 'name' => $t['name']]);
-        unset($_serve, $_local);
-        usort($_diffy, function ($a, $b) {
-            return $a['name'] !== $b['name'] ? ($a['name'] > $b['name'] ? 1 : -1) : 0;
-        });
-        return $_diffy;
+        $serve = array_combine(array_column($serve, 'name'), array_column($serve, 'hash'));
+        $local = array_combine(array_column($local, 'name'), array_column($local, 'hash'));
+        foreach ($serve as $name => $hash) {
+            $type = isset($local[$name]) ? ($hash === $local[$name] ? null : 'mod') : 'add';
+            $diffy[$name] = ['type' => $type, 'name' => $name];
+        }
+        foreach ($local as $name => $hash) if (!isset($serve[$name])) {
+            $diffy[$name] = ['type' => 'del', 'name' => $name];
+        }
+        ksort($diffy);
+        return array_values($diffy);
     }
 
     /**
@@ -358,10 +353,11 @@ class ModuleService extends Service
      */
     private function _scanLocalFileHashList(string $path, array $data = []): array
     {
-        foreach (NodeService::instance()->scanDirectory($path, [], null) as $file) $data[] = [
-            'name' => str_replace(strtr($this->root, '\\', '/'), '', $file),
-            'hash' => md5(preg_replace('/\s+/', '', file_get_contents($file))),
-        ];
+        foreach (NodeService::instance()->scanDirectory($path, [], null) as $file) {
+            if ($this->checkAllowDownload($name = substr($file, strlen($this->root)))) {
+                $data[] = ['name' => $name, 'hash' => md5(preg_replace('/\s+/', '', file_get_contents($file)))];
+            }
+        }
         return $data;
     }
 }

+ 14 - 16
vendor/zoujingli/think-library/src/service/NodeService.php

@@ -29,7 +29,7 @@ class NodeService extends Service
      * @param string $name
      * @return string
      */
-    public function nameTolower($name)
+    public function nameTolower(string $name): string
     {
         $dots = [];
         foreach (explode('.', strtr($name, '/', '.')) as $dot) {
@@ -43,7 +43,7 @@ class NodeService extends Service
      * @param string $type
      * @return string
      */
-    public function getCurrent($type = '')
+    public function getCurrent(string $type = ''): string
     {
         $prefix = $this->app->getNamespace();
         $middle = '\\' . $this->nameTolower($this->app->request->controller());
@@ -56,7 +56,7 @@ class NodeService extends Service
      * @param string $node
      * @return string
      */
-    public function fullnode($node)
+    public function fullnode($node): string
     {
         if (empty($node)) return $this->getCurrent();
         if (count($attrs = explode('/', $node)) === 1) {
@@ -72,7 +72,7 @@ class NodeService extends Service
      * @param array $data
      * @return array
      */
-    public function getModules($data = [])
+    public function getModules(array $data = []): array
     {
         $path = $this->app->getBasePath();
         foreach (scandir($path) as $item) if ($item[0] !== '.') {
@@ -87,7 +87,7 @@ class NodeService extends Service
      * @return array
      * @throws \ReflectionException
      */
-    public function getMethods($force = false)
+    public function getMethods(bool $force = false): array
     {
         static $data = [];
         if (empty($force)) {
@@ -121,7 +121,7 @@ class NodeService extends Service
      * @param string $default 默认标题
      * @return array
      */
-    private function _parseComment($comment, $default = '')
+    private function _parseComment(string $comment, string $default = ''): array
     {
         $text = strtr($comment, "\n", ' ');
         $title = preg_replace('/^\/\*\s*\*\s*\*\s*(.*?)\s*\*.*?$/', '$1', $text);
@@ -138,22 +138,20 @@ class NodeService extends Service
      * 获取所有PHP文件列表
      * @param string $path 扫描目录
      * @param array $data 额外数据
-     * @param string $ext 文件后缀
+     * @param null|string $ext 文件后缀
      * @return array
      */
-    public function scanDirectory($path, $data = [], $ext = 'php')
+    public function scanDirectory(string $path, array $data = [], $ext = 'php'): array
     {
         if (file_exists($path)) {
             if (is_file($path)) {
                 $data[] = strtr($path, '\\', '/');
-            } elseif (is_dir($path)) {
-                foreach (scandir($path) as $item) if ($item[0] !== '.') {
-                    $real = rtrim($path, '\\/') . DIRECTORY_SEPARATOR . $item;
-                    if (is_readable($real)) if (is_dir($real)) {
-                        $data = $this->scanDirectory($real, $data, $ext);
-                    } elseif (is_file($real) && (is_null($ext) || pathinfo($real, 4) === $ext)) {
-                        $data[] = strtr($real, '\\', '/');
-                    }
+            } elseif (is_dir($path)) foreach (scandir($path) as $item) if ($item[0] !== '.') {
+                $real = rtrim($path, '\\/') . DIRECTORY_SEPARATOR . $item;
+                if (is_readable($real)) if (is_dir($real)) {
+                    $data = $this->scanDirectory($real, $data, $ext);
+                } elseif (is_file($real) && (is_null($ext) || pathinfo($real, 4) === $ext)) {
+                    $data[] = strtr($real, '\\', '/');
                 }
             }
         }

+ 7 - 7
vendor/zoujingli/think-library/src/service/ProcessService.php

@@ -30,7 +30,7 @@ class ProcessService extends Service
      * @param string $args 指定参数
      * @return string
      */
-    public function think($args = '')
+    public function think(string $args = ''): string
     {
         $root = $this->app->getRootPath();
         return trim("php {$root}think {$args}");
@@ -40,7 +40,7 @@ class ProcessService extends Service
      * 获取当前应用版本
      * @return string
      */
-    public function version()
+    public function version(): string
     {
         return ModuleService::instance()->getVersion();
     }
@@ -65,7 +65,7 @@ class ProcessService extends Service
      * @param string $command 任务指令
      * @return array
      */
-    public function query($command)
+    public function query(string $command): array
     {
         $list = [];
         if ($this->iswin()) {
@@ -90,7 +90,7 @@ class ProcessService extends Service
      * @param integer $pid 进程号
      * @return boolean
      */
-    public function close($pid)
+    public function close($pid): bool
     {
         if ($this->iswin()) {
             $this->exec("wmic process {$pid} call terminate");
@@ -116,7 +116,7 @@ class ProcessService extends Service
      * 判断系统类型
      * @return boolean
      */
-    public function iswin()
+    public function iswin(): bool
     {
         return PATH_SEPARATOR === ';';
     }
@@ -127,7 +127,7 @@ class ProcessService extends Service
      * @param string $tochar
      * @return string
      */
-    private function _space($content, $tochar = ' ')
+    private function _space(string $content, string $tochar = ' '): string
     {
         return preg_replace('|\s+|', $tochar, strtr(trim($content), '\\', '/'));
     }
@@ -138,7 +138,7 @@ class ProcessService extends Service
      * @param string $substr
      * @return boolean
      */
-    private function _issub($content, $substr)
+    private function _issub(string $content, string $substr): bool
     {
         return stripos($this->_space($content), $this->_space($substr)) !== false;
     }

+ 1 - 1
vendor/zoujingli/think-library/src/service/QueueService.php

@@ -152,7 +152,7 @@ class QueueService extends Service
      * @param null|integer $progress 进度数值
      * @return array
      */
-    public function progress($status = null, $message = null, $progress = null)
+    public function progress($status = null, $message = null, $progress = null): array
     {
         $ckey = "queue_{$this->code}_progress";
         if (is_numeric($status) && intval($status) === 3) {

+ 3 - 3
vendor/zoujingli/think-library/src/service/SystemService.php

@@ -248,9 +248,9 @@ class SystemService extends Service
      * 获取实时运行配置
      * @param string $key
      * @param array $default
-     * @return array
+     * @return array|string
      */
-    public function getRuntime($key = null, $default = [])
+    public function getRuntime($key = null, array $default = [])
     {
         $filename = "{$this->app->getRootPath()}runtime/config.json";
         if (file_exists($filename) && is_file($filename)) {
@@ -286,7 +286,7 @@ class SystemService extends Service
      * @param array $data 配置数据
      * @return boolean 是否调试模式
      */
-    public function bindRuntime($data = []): bool
+    public function bindRuntime(array $data = []): bool
     {
         if (empty($data)) $data = $this->getRuntime();
         $bind['app_map'] = $this->app->config->get('app.app_map', []);

+ 4 - 4
vendor/zoujingli/think-library/src/service/TokenService.php

@@ -58,7 +58,7 @@ class TokenService extends Service
      * 获取缓存名称
      * @return string
      */
-    public function getCacheName()
+    public function getCacheName(): string
     {
         $sid = $this->app->session->getId();
         return 'systoken_' . ($sid ?: 'default');
@@ -77,7 +77,7 @@ class TokenService extends Service
      * 获取当前请求 CSRF 值
      * @return array|string
      */
-    public function getInputToken()
+    public function getInputToken(): string
     {
         return $this->app->request->header('user-form-token', input('_csrf_', ''));
     }
@@ -88,7 +88,7 @@ class TokenService extends Service
      * @param string $node 授权节点
      * @return boolean
      */
-    public function checkFormToken($token = null, $node = null)
+    public function checkFormToken($token = null, $node = null): bool
     {
         $cnode = NodeService::instance()->fullnode($node);
         $cache = $this->_getCacheItem($token ?: $this->getInputToken());
@@ -113,7 +113,7 @@ class TokenService extends Service
      * @param string $node
      * @return array
      */
-    public function buildFormToken($node = null)
+    public function buildFormToken($node = null): array
     {
         $cnode = NodeService::instance()->fullnode($node);
         [$token, $time] = [uniqid() . rand(100000, 999999), time()];