sgd521 преди 2 години
родител
ревизия
2cc5885801
променени са 100 файла, в които са добавени 0 реда и са изтрити 25185 реда
  1. 0 11
      .gitignore
  2. 0 21
      LICENSE
  3. 0 2
      README.md
  4. 0 137
      application/api/common.php
  5. 0 173
      application/api/controller/Area.php
  6. 0 172
      application/api/controller/Base.php
  7. 0 252
      application/api/controller/Box.php
  8. 0 238
      application/api/controller/Index.php
  9. 0 301
      application/api/controller/Login.php
  10. 0 557
      application/api/controller/Order.php
  11. 0 502
      application/api/controller/Pay.php
  12. 0 153
      application/api/controller/Publics.php
  13. 0 103
      application/api/controller/Recharge.php
  14. 0 850
      application/api/controller/Secondary.php
  15. 0 130
      application/api/controller/Sms.php
  16. 0 247
      application/api/controller/Synthetic.php
  17. 0 29
      application/api/controller/Test.php
  18. 0 436
      application/api/controller/Timedtask.php
  19. 0 298
      application/api/controller/Timedtask1.php
  20. 0 151
      application/api/controller/Upload.php
  21. 0 1279
      application/api/controller/UserCenter.php
  22. 0 74
      application/api/controller/WeChart.php
  23. 0 1830
      application/common.php
  24. 0 53
      application/common/Api/ConfigApi.php
  25. 0 76
      application/common/behavior/Common.php
  26. 0 114
      application/common/controller/Api.php
  27. 0 471
      application/common/controller/Backend.php
  28. 0 137
      application/common/controller/Frontend.php
  29. 0 104
      application/common/lang/zh-cn/addon.php
  30. 0 87
      application/common/library/AliPay.php
  31. 0 144
      application/common/library/AliPay2.php
  32. 0 239
      application/common/library/AliPay3.php
  33. 0 613
      application/common/library/Auth.php
  34. 0 304
      application/common/library/Common.php
  35. 0 197
      application/common/library/Email.php
  36. 0 144
      application/common/library/Ems.php
  37. 0 142
      application/common/library/Hecheng.php
  38. 0 217
      application/common/library/HuijuH5Pay.php
  39. 0 156
      application/common/library/HuijuKjPay.php
  40. 0 81
      application/common/library/Jiyan.php
  41. 0 148
      application/common/library/JuheRecharge.php
  42. 0 144
      application/common/library/Menu.php
  43. 0 245
      application/common/library/PHPExcelService.php
  44. 0 3223
      application/common/library/QRcode.php
  45. 0 129
      application/common/library/Shande.php
  46. 0 158
      application/common/library/Token.php
  47. 0 189
      application/common/library/WxMerchPay.php
  48. 0 394
      application/common/library/WxPay.php
  49. 0 188
      application/common/library/alipay/aop/AlipayMobilePublicMultiMediaClient.php
  50. 0 115
      application/common/library/alipay/aop/AlipayMobilePublicMultiMediaExecute.php
  51. 0 1237
      application/common/library/alipay/aop/AopCertClient.php
  52. 0 527
      application/common/library/alipay/aop/AopCertification.php
  53. 0 1299
      application/common/library/alipay/aop/AopClient.php
  54. 0 81
      application/common/library/alipay/aop/AopEncrypt.php
  55. 0 18
      application/common/library/alipay/aop/EncryptParseItem.php
  56. 0 16
      application/common/library/alipay/aop/EncryptResponseData.php
  57. 0 15
      application/common/library/alipay/aop/SignData.php
  58. 0 14
      application/common/library/alipay/aop/readme
  59. 0 118
      application/common/library/alipay/aop/request/AftAifinFireeyeOcrImageQueryRequest.php
  60. 0 118
      application/common/library/alipay/aop/request/AftFinsecureRiskplusSecurityPolicyQueryRequest.php
  61. 0 118
      application/common/library/alipay/aop/request/AliosOpenAutoInfoQueryRequest.php
  62. 0 118
      application/common/library/alipay/aop/request/AlipayAccountExrateAdviceAcceptRequest.php
  63. 0 118
      application/common/library/alipay/aop/request/AlipayAccountExrateAllclientrateQueryRequest.php
  64. 0 118
      application/common/library/alipay/aop/request/AlipayAccountExrateRatequeryRequest.php
  65. 0 118
      application/common/library/alipay/aop/request/AlipayAccountExrateTraderequestCreateRequest.php
  66. 0 171
      application/common/library/alipay/aop/request/AlipayAcquireCancelRequest.php
  67. 0 152
      application/common/library/alipay/aop/request/AlipayAcquireCloseRequest.php
  68. 0 550
      application/common/library/alipay/aop/request/AlipayAcquireCreateandpayRequest.php
  69. 0 402
      application/common/library/alipay/aop/request/AlipayAcquirePrecreateRequest.php
  70. 0 136
      application/common/library/alipay/aop/request/AlipayAcquireQueryRequest.php
  71. 0 236
      application/common/library/alipay/aop/request/AlipayAcquireRefundRequest.php
  72. 0 118
      application/common/library/alipay/aop/request/AlipayAppTokenGetRequest.php
  73. 0 103
      application/common/library/alipay/aop/request/AlipayAssetPointBalanceQueryRequest.php
  74. 0 103
      application/common/library/alipay/aop/request/AlipayAssetPointBudgetQueryRequest.php
  75. 0 118
      application/common/library/alipay/aop/request/AlipayAssetPointOrderCreateRequest.php
  76. 0 118
      application/common/library/alipay/aop/request/AlipayAssetPointOrderQueryRequest.php
  77. 0 118
      application/common/library/alipay/aop/request/AlipayBossCsChannelQueryRequest.php
  78. 0 103
      application/common/library/alipay/aop/request/AlipayBossFncXwbtestRetModifyRequest.php
  79. 0 118
      application/common/library/alipay/aop/request/AlipayBossProdArrangementOfflineQueryRequest.php
  80. 0 118
      application/common/library/alipay/aop/request/AlipayBossProdMyTestQueryRequest.php
  81. 0 103
      application/common/library/alipay/aop/request/AlipayCommerceAdContractSignRequest.php
  82. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceAirCallcenterTradeApplyRequest.php
  83. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceAirXfgDsgModifyRequest.php
  84. 0 103
      application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorCityQueryRequest.php
  85. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorDepositCancelRequest.php
  86. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorDepositConfirmRequest.php
  87. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorDepositQueryRequest.php
  88. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorFunctionQueryRequest.php
  89. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorScriptQueryRequest.php
  90. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorStationQueryRequest.php
  91. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorVoucherBatchqueryRequest.php
  92. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorVoucherCancelRequest.php
  93. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorVoucherConfirmRequest.php
  94. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorVoucherGenerateRequest.php
  95. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorVoucherQueryRequest.php
  96. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorVoucherRefundRequest.php
  97. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorVoucherUploadRequest.php
  98. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceDataCampaignCreateRequest.php
  99. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceDataCampaignSendRequest.php
  100. 0 118
      application/common/library/alipay/aop/request/AlipayCommerceDataCustommetricSyncRequest.php

+ 0 - 11
.gitignore

@@ -1,11 +0,0 @@
-/.git
-/.svn
-/.idea
-/runtime
-/safefile
-/nbproject
-/config/cert
-/composer.lock
-/public/upload
-public/static/theme/css/console.*.css
-public/static/theme/css/console.*.css.map

+ 0 - 21
LICENSE

@@ -1,21 +0,0 @@
-MIT License
-
-Copyright (c) 2019 邹景立
-
-Permission is hereby granted, free of charge, to any person obtaining a copy
-of this software and associated documentation files (the "Software"), to deal
-in the Software without restriction, including without limitation the rights
-to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
-copies of the Software, and to permit persons to whom the Software is
-furnished to do so, subject to the following conditions:
-
-The above copyright notice and this permission notice shall be included in all
-copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
-SOFTWARE.

+ 0 - 2
README.md

@@ -1,2 +0,0 @@
-# collect
-

+ 0 - 137
application/api/common.php

@@ -1,137 +0,0 @@
-<?php
-// 接口公共方法
-use think\Db;
-//function get_order_sn(){
-//    $order_id_main = date('YmdHis') . rand(10000000,99999999);
-//    $order_id_len = strlen($order_id_main);
-//    $order_id_sum = 0;
-//    for($i=0; $i<$order_id_len; $i++){
-//        $order_id_sum += (int)(substr($order_id_main,$i,1));
-//    }
-//    $osn = $order_id_main . str_pad((100 - $order_id_sum % 100) % 100,2,'0',STR_PAD_LEFT);
-//    return $osn;
-//}
-
-
-// 生成消息记录
-function  send_user_message($user_id,$type_id,$content){
-    $msg_data =[
-        'user_id' => $user_id,
-        'type_id' => $type_id,
-        'content' => $content,
-        'create_at' => date('Y-m-d H:i:s'),
-    ];
-    Db::table('user_message')->insert($msg_data);
-    return Db::getLastInsID();
-}
-
-function  goods_sell_info($goods_info,$user_id,$from_id = 0)
-{
-    $sell_info =[
-        'goods_id'=>$goods_info['id'],
-        'goods_type'=>$goods_info['type'],
-        'user_id'=>$user_id,
-        'year'=> date('Y'),
-        'month'=> date('m'),
-        'day'=> date('d'),
-        'from_id'=> $from_id,
-        'goods_info'=>json_encode($goods_info)
-    ];
-    Db::table('goods_sell_info')->insert($sell_info);
-}
-
-/**
- * 获取商品hash值
- * @param $user_id 用户id
- * @param $name 商品id
- * @param $count   收藏数量
- * @return string
- */
-function get_goods_hash($user_id,$name='',$count = 0){
-    $host = "http://101.200.81.225:9090/contract/call";
-    //$host = "http://jc.nfrcn.vip:9090/contract/call";
-    $method = "POST";
-    $headers = array();
-    array_push($headers, "Content-Type".":"."application/json; charset=UTF-8");
-    $bodys = [
-        'key' => 'JDchinahgsc20220035',
-        'userkey' =>$user_id,
-        'product' => json_encode(['name'=>$name,'count'=>$count])
-    ];
-    $curl = curl_init();
-    curl_setopt($curl, CURLOPT_CUSTOMREQUEST, $method);
-    curl_setopt($curl, CURLOPT_URL, $host);
-    curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
-    curl_setopt($curl, CURLOPT_FAILONERROR, false);
-    curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
-    curl_setopt($curl, CURLOPT_HEADER, false);
-    if (1 == strpos("$".$host, "https://"))
-    {
-        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
-        curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
-    }
-    curl_setopt($curl, CURLOPT_POSTFIELDS, json_encode($bodys));
-    $res = curl_exec($curl);
-    if(!$res) return ['hash_str'=>''];
-    $hash_res = json_decode($res,true);
-    return [
-        'hash_str'=> isset($hash_res['code']) &&  $hash_res['code'] == 200 ? $hash_res['data']['contentHash']:'',// 哈希
-    ];
-}
-
-
-/**
- * 获取系统配置
- * @param $array
- * @return array
- * @throws \think\db\exception\DataNotFoundException
- * @throws \think\db\exception\ModelNotFoundException
- * @throws \think\exception\DbException
- */
-function getConfig($array){
-    $set = Db::table('system_config')->where('name','in',$array)->select();
-    $ret = [];
-    foreach ($set as $value) {
-        $ret[$value['name']]=$value['value'];
-    }
-    return $ret;
-}
-
-
-
-
-/**
- * @title 取消订单定时任务
- * @desc  十五分钟内未支付的自动取消
- */
-function cancel_goods_order($user_id = 0)
-{
-    $set_time = intval(sysconf('cancel_time')) ? : 5;// 没设置默认5分钟未支付的自动取消
-    $sel_time = time() - $set_time * 60 ;
-    $where = [];
-    $where[] = ['create_at','< time',date('Y-m-d H:i:s',$sel_time)];
-    $where[] = ['status','=',0];
-    $where[] = ['cancel_state','=',0];
-    if($user_id)  $where[] = ['uid','=',$user_id];
-    $order_data = Db::table('goods_order')
-        ->where($where)
-        ->select();
-    foreach ($order_data as $order_info) {
-        Db::startTrans();
-        try {
-            Db::table('goods_order')->where(['id'=>$order_info['id']])
-                ->update(['status'=>9,'cancel_state'=>1,'cancel_at'=>date('Y-m-d H:i:s'),'cancel_desc'=>'支付超时!自动取消']);
-            Db::table('store_goods')->where('id', $order_info['goods_id'])
-                ->setInc('stock', $order_info['goods_num']);
-            Db::commit();
-        }catch (\Exception $e){
-            Db::rollback();
-        }
-    }
-}
-
-
-
-
-
-

+ 0 - 173
application/api/controller/Area.php

@@ -1,173 +0,0 @@
-<?php
-
-// +----------------------------------------------------------------------
-// | ThinkAdmin
-// +----------------------------------------------------------------------
-// | 版权所有 2014~2019 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
-// +----------------------------------------------------------------------
-// | 官方网站: http://demo.thinkadmin.top
-// +----------------------------------------------------------------------
-// | 开源协议 ( https://mit-license.org )
-// +----------------------------------------------------------------------
-// | gitee 代码仓库:https://gitee.com/zoujingli/ThinkAdmin
-// | github 代码仓库:https://github.com/zoujingli/ThinkAdmin
-// +----------------------------------------------------------------------
-
-namespace app\api\controller;
-
-use app\common\controller\Api;
-use library\File;
-use think\Db;
-/**
- * @title 地址库
- * @controller Area
- * @group common
- */
-class Area extends Base
-{
-    /**
-     * @title 获取省市区
-     * @desc 获取省市区
-     * @author QC
-     * @url /api/Area/getAllArea
-     * @method GET
-     * @tag 省市区
-     */
-    public function getAllArea(){
-        $area_set = Db::table('platform_set')->where('name','all_area')->find();
-        if(!empty($area_set) && $area_set['content']) {
-           $list = json_decode($area_set['content'],true);
-        }else{
-            $field=['id','pid','shortname','name'];
-            $list=Db::table('store_area')->where('pid',0)->field($field)->select();
-            foreach ($list as $k=>&$v){
-                $v['children']= Db::table('store_area')->where('pid',$v['id'])->field($field)->select();
-                if(!empty($v['children'])){
-                    foreach ($v['children'] as $kk=>&$vv){
-                        $vv['children']=Db::table('store_area')->where('pid',$vv['id'])->field($field)->select();
-                    }
-                }
-            }
-            if(!empty($area_set)){
-                Db::table('platform_set')->where('name','all_area')->update(['content'=>json_encode($list)]);
-            }else{
-                Db::table('platform_set')->insert(['name'=>'all_area','content'=>json_encode($list)]);
-            }
-        }
-        $this->success('获取成功',$list);
-    }
-
-    /**
-     * @title 获取下级地区
-     * @desc 获取下级地区
-     * @author QC
-     * @url /api/Area/getChildrenArea
-     * @method GET
-     * @param  name:id type:int  default:1 desc:省id或市id
-     */
-    public function getChildrenArea()
-    {
-        $field=['id','pid','shortname','name'];
-        $list=Db::table('store_area')->where('pid',$this->request->get('id'))->field($field)->select();
-        $this->success('获取成功',$list);
-    }
-
-    /**
-     * 获取定位城市
-     */
-    public function getCity(){
-        $list=Db::table('store_area')->where('level',2)->field('first')->group('first')->order('first asc')->select();
-        $field=['id','pid','shortname','name','first'];
-        foreach ($list as $k=>&$v){
-            $v['list']=Db::table('store_area')->where('level',2)->where('first',$v['first'])->field($field)->select();
-        }
-        $hot=Db::table('store_area')->whereIn('id',[2,802,1965])->field($field)->select();
-        $history=Db::table('store_area')->whereIn('id',[2,802,1965])->field($field)->select();
-        array_unshift($list,['first'=>'历史','list'=>$history],['first'=>'热门城市','list'=>$hot]);
-        $this->success('获取成功',$list);
-    }
-
-    /**
-     * @title 通过省市区id返回具体地址信息
-     * @desc 通过省市区id返回具体地址信息
-     * @author QC
-     * @url /api/Area/getCity
-     * @method GET
-     * @tag 省市区
-     */
-    public function get_area($province_id,$city_id,$county_id){
-        $province = '';
-        if(!empty($province_id)){
-            $quarters = Db::name('store_area')->field('name')->where('id',$province_id)->find();
-            $province = $quarters['name'];
-        }
-        $city = '';
-        if(!empty($city_id)){
-            $quarters = Db::name('store_area')->field('name')->where('id',$city_id)->find();
-            $city = $quarters['name'];
-        }
-        $county = '';
-        if(!empty($county_id)){
-            $quarters = Db::name('store_area')->field('name')->where('id',$county_id)->find();
-            $county = $quarters['name'];
-        }
-        return $province.$city.$county;
-    }
-    /**
-     * 通过省市区名称返回省市区id
-     */
-    public function get_area_id($province = '',$city = '',$county = ''){
-        $province_id = '';
-        if(!empty($province)){
-            $province_id = Db::name('store_area')->where('name',$province)->value('id');
-        }
-        $city_id = '';
-        if(!empty($city)){
-            $city_id = Db::name('store_area')->where('name',$city)->value('id');
-        }
-        $county_id = '';
-        if(!empty($county)){
-            $county_id = Db::name('store_area')->where('name',$county)->value('id');
-        }
-        return $province_id.$city_id.$county_id;
-    }
-    /**
-     * 通过id获取名称
-     */
-    public function get_name($id){
-        $quarters = Db::name('store_area')->field('name')->where('id',$id)->find();
-        return $quarters['name'];
-    }
-    /**
-     * 通过省/市的ID获取所有县区ID
-     * $type 1代表省 2代表市
-     */
-    public function get_county_id($id,$type=1){
-        $county_id_str = '';
-        if($type == 1){
-            $city_id_arr = Db::name('store_area')->field('id')->where('pid',$id)->column('id');
-            foreach ($city_id_arr as $value){
-                $county_id_arr = Db::name('store_area')->field('id')->where('pid',$value)->column('id');
-                $county_id_str .= implode(',',$county_id_arr).',';
-            }
-        }else{
-            $county_id_arr = Db::name('store_area')->field('id')->where('pid',$id)->column('id');
-            $county_id_str .= implode(',',$county_id_arr).',';
-        }
-        return substr($county_id_str,0,strlen($county_id_str)-1);
-    }
-    /**
-     * 通过省的ID获取所有市的ID
-     */
-    public function get_city_id($id){
-        $city_id_arr = Db::name('store_area')->field('id')->where('pid',$id)->column('id');
-        return implode(',',$city_id_arr);
-    }
-    /**
-     * 通过市的ID获取省的ID
-     */
-    public function get_province_id($id){
-        $province_id = Db::name('store_area')->field('id')->where('id',$id)->value('pid');
-        return $province_id;
-    }
-}

+ 0 - 172
application/api/controller/Base.php

@@ -1,172 +0,0 @@
-<?php
-
-// +----------------------------------------------------------------------
-// | ThinkAdmin
-// +----------------------------------------------------------------------
-// | 版权所有 2014~2019 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
-// +----------------------------------------------------------------------
-// | 官方网站: http://demo.thinkadmin.top
-// +----------------------------------------------------------------------
-// | 开源协议 ( https://mit-license.org )
-// +----------------------------------------------------------------------
-// | gitee 代码仓库:https://gitee.com/zoujingli/ThinkAdmin
-// | github 代码仓库:https://github.com/zoujingli/ThinkAdmin
-// +----------------------------------------------------------------------
-
-namespace app\api\controller;
-
-use app\common\controller\Api;
-use Firebase\JWT\JWT;
-use think\Controller;
-use think\Db;
-use think\Exception;
-use think\exception\HttpResponseException;
-use think\Request;
-use think\Response;
-
-/**
- * 会员管理基类
- * Class Member
- * @package app\store\controller\api
- */
-class Base extends Controller
-{
-    protected $uid = 10;
-
-    protected $page; // 页数
-    protected $page_num;
-    protected $off_set;
-    public function initialize(){
-        $this->page = input('page',1);
-        $this->page_num = input('page_num',20);
-        $this->off_set   =   $this->page * $this->page_num - $this->page_num;
-    }
-    //校验jwt权限API
-    protected function check_login()
-    {
-        $authorization = app()->request->header('Authorization');
-        //var_dump($authorization.'111');exit();
-        if(empty($authorization) || $authorization == null){
-            $this->error('未登录,请先登录','',0);
-        }
-        $key = md5(config('app.jwt'));
-        try {
-            $jwtAuth = json_encode(JWT::decode($authorization, $key, array('HS256')));
-            $authInfo = json_decode($jwtAuth, true);
-            if (!empty($authInfo['uid'])) {
-                $member = Db::name('store_member')->field('status')->where('id',$authInfo['uid'])->find();
-                if($member['status']){
-                    $this->uid = $authInfo['uid'];
-                    return $this->uid;
-                }else{
-                    $this->error('该会员已被禁用','',0);
-                }
-            } else {
-                $this->error('Token验证不通过,用户不存在','',0);
-            }
-        } catch (\Firebase\JWT\SignatureInvalidException $e) {
-            $this->error('Token无效','',0);
-        } catch (\Firebase\JWT\ExpiredException $e) {
-            $this->error('Token过期','',0);
-        } catch (Exception $e) {
-            return $e;
-        }
-    }
-
-    protected function set_uid(){
-        $authorization = app()->request->header('Authorization');
-        $key = md5(config('app.jwt'));
-        if(empty($authorization) || $authorization == null){
-            return false;
-        }
-        $jwtAuth = json_encode(JWT::decode($authorization, $key, array('HS256')));
-        $authInfo = json_decode($jwtAuth, true);
-        if (!empty($authInfo['uid'])) {
-            $member = Db::name('store_member')->field('status')->where('id',$authInfo['uid'])->find();
-            if($member['status']){
-                $this->uid = $authInfo['uid'];
-                return $this->uid;
-            }
-        }
-    }
-
-    /**
-     * 操作成功返回的数据
-     * @param string $msg   提示信息
-     * @param mixed $data   要返回的数据
-     * @param int   $code   错误码,默认为1
-     * @param string $type  输出类型
-     * @param array $header 发送的 Header 信息
-     */
-    protected function success($msg = '', $data = null , $is_login = 1, $code = 1, $type = null, array $header = [])
-    {
-        $this->results($msg, $data, $is_login, $code, $type, $header);
-    }
-
-    /**
-     * 操作失败返回的数据
-     * @param string $msg   提示信息
-     * @param mixed $data   要返回的数据
-     * @param int   $code   错误码,默认为0
-     * @param string $type  输出类型
-     * @param array $header 发送的 Header 信息
-     */
-    protected function error($msg = '', $data = null, $is_login = 1, $code = 0, $type = null, array $header = [])
-    {
-        if(empty($this->uid)){
-            $is_login = 0;
-        }
-        $this->results($msg, $data, $is_login, $code, $type, $header);
-    }
-    /**
-     * 返回封装后的 API 数据到客户端
-     * @access protected
-     * @param mixed  $msg    提示信息
-     * @param mixed  $data   要返回的数据
-     * @param int    $code   错误码,默认为0
-     * @param string $type   输出类型,支持json/xml/jsonp
-     * @param array  $header 发送的 Header 信息
-     * @return void
-     * @throws HttpResponseException
-     */
-    protected function results($msg, $data = null, $is_login, $code = 0, $type = null, array $header = [])
-    {
-        $result = [
-            'code' => $code,
-            'is_login' => $is_login,
-            'msg'  => $msg,
-            'time' => \think\facade\Request::instance()->server('REQUEST_TIME'),
-            'data' => $data,
-        ];
-        // 如果未设置类型则自动判断
-        $type = $type ? $type : 'json';
-
-        if (isset($header['statuscode']))
-        {
-            $code = $header['statuscode'];
-            unset($header['statuscode']);
-        }
-        else
-        {
-            //未设置状态码,根据code值判断
-            $code = $code >= 1000 || $code < 200 ? 200 : $code;
-        }
-        $response = Response::create($result, $type, $code)->header($header);
-        throw new HttpResponseException($response);
-    }
-    protected function get_uid(){
-        $uid = 0;
-        $authorization = app()->request->header('Authorization');
-        if(!empty($authorization)){
-            $key = md5(config('app.jwt'));
-            $jwtAuth = json_encode(JWT::decode($authorization, $key, array('HS256')));
-            $authInfo = json_decode($jwtAuth, true);
-            if (!empty($authInfo['uid'])) {
-                $uid = $authInfo['uid'];
-            }
-        }
-        return $uid;
-    }
-
-
-}

+ 0 - 252
application/api/controller/Box.php

@@ -1,252 +0,0 @@
-<?php
-
-
-namespace app\api\controller;
-use app\common\library\AliPay;
-use EasyWeChat\Factory;
-use think\Db;
-/**
- * @title 盲盒
- * @controller Box
- * @package app\api\controller
- */
-class Box extends Base
-{
-
-    public function initialize(){
-        parent::check_login();
-    }
-
-    /**
-     * @title 抽奖
-     * @desc  抽奖
-     * @author  Gavin
-     * @url /api/Box/lucky_draw
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     *
-     */
-    public function lucky_draw(){
-        $user = getMemberInfoHash($this->uid); //获取用户信息
-        //获取每日免费次数
-        $free_number = getConfigValue('free_lucky_number');
-        //获取当日免费抽奖记录
-        $date = date('Y-m-d');
-        $now_date_count = Db::name('store_blind_box_log')
-            ->where('m_id',$this->uid)
-            ->where('date',$date)
-            ->where('is_free',0)
-            ->count();
-        $free = $free_number-$now_date_count; //剩余免费次数
-        $number = $user['lottery_number'] + $free;
-        if ($number<=0) $this->error('抽奖次数不足');
-        checkBox();
-        $prize_arr = Db::name('store_blind_box')
-            ->where('status',1)
-            ->where('is_del',1)
-            ->field('id,rate')
-            ->select();
-        foreach ($prize_arr as $key => $val) {
-            $arr[$val['id']] = $val['rate'];//概率数组
-        }
-        $rid = get_rand($arr); //根据概率获取奖项id
-        $info = Db::name('store_blind_box')->where('id',$rid)->field('id,title,prize,is_prize')->find();
-        $return = [
-            'is_prize'=>$info['is_prize']
-        ];
-        $coll_info =  getCollectionInfoHash($info['prize']);
-        if ($info['is_prize']==1){
-            $json_info = json_encode($coll_info,true);
-            $return['name'] = $info['title'];
-            $return['cover'] = $coll_info['cover'];
-
-        }else{
-            $json_info = '';
-            $return['name'] = '未中奖';
-            $return['cover'] = '';
-        }
-        $com = true;
-        Db::startTrans();
-        try {
-            $data = [
-                'm_id'=>$this->uid,
-                'b_id'=>$rid,
-                'is_prize'=>$info['is_prize'],
-                'name'=>$return['name'],
-                'cover'=>$return['cover'],
-                'info'=>$json_info,
-                'date'=>$date,
-                'is_free'=>$free>0 ? 0 : 1
-            ];
-            Db::name('store_blind_box_log')->insert($data);
-            if (!$free){
-                Db::name('store_member')->where('id',$this->uid)->setDec('lottery_number');
-            }
-            //减少数据库库存
-            if ($info['is_prize']==1){
-                Db::name('store_collection')->where('id',$info['prize'])->setDec('now_inventory');
-                //获取排名
-                $rank = getRanking($info['prize'])+1;
-                $tag = getTag($info['prize'],$rank,$coll_info['inventory']);
-                saveRanking($info['prize']);
-                $nfttype = Db::name('hash2')->where('goods_id',$info['prize'])->where('success',1)->value('NFTType');
-                $collectors_hash = '';
-                $date = [
-                    'order_id'=>0,
-                    'order_no'=>get_order_sn(),
-                    'tag'=>$tag,
-                    'mid'=>$this->uid,
-                    'c_id'=>$info['prize'],
-                    'name'=>$coll_info['name'],
-                    'cover'=>$coll_info['cover'],
-                    'pro_info'=>$json_info,
-                    'nfttype'=>$nfttype,
-                    'collectors_hash'=>$collectors_hash,
-                    'status'=>4
-                ];
-                Db::name('store_order_info')->insert($date);
-            }
-            Db::commit();
-        }catch (\Exception $e){
-            $com=false;
-            Db::rollback();
-        }
-        if ($com){
-            setMemberInfoHash($this->uid);
-            if ($info['is_prize']==1){
-                //减掉库存
-                loseCollectionInventory($info['prize'],1);
-            }
-
-
-            $this->success('成功',$return);
-        }
-        $this->error('系统错误,请稍后重试');
-    }
-
-    /**
-     * @title 充值次数
-     * @desc  充值次数
-     * @author  Gavin
-     * @url /api/Box/recharge
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param name:num type:int require:1 default:1 desc:充值次数
-     * @param name:pay_type type:string require:1 default:wx desc:wx:微信zfb:支付宝
-     * @param name:from type:string require:1 default:wx desc:wx:微信公众号h5:网页
-     *
-     * @return  name:order_no type:int require:0 default:0 desc:订单号
-     * @return  name:pay type:string require:0 default:0 desc:支付信息
-     */
-    public function recharge(){
-        $num = input('num',1);
-        $pay_type = input('pay_type','wx');
-        $from = input('from','wx');
-        $user = getMemberInfoHash($this->uid); //获取用户信息
-        if ($num<1) $this->error('数量错误');
-        $com = true;
-        Db::startTrans();
-        try {
-            $order_no = get_order_sn();
-            //获取价格
-            $price = getConfigValue('lucky_recharge_price');
-            $total_fee = bcmul($price,$num,2);
-            $data = [
-                'order_no'=>$order_no,
-                'm_id'=>$this->uid,
-                'num'=>$num,
-                'price'=>$price,
-                'pay_price'=>$total_fee,
-                'pay_type'=>$pay_type
-            ];
-            Db::name('store_blind_recharge')->insert($data);
-            $body = 'top艺术充值盲盒次数';
-            switch ($pay_type){
-                case 'wx':
-                    $config = retrunWxConfig();
-                    $total_fee = $total_fee * 100;
-                    $config['notify_url'] = 'https://'.$_SERVER['SERVER_NAME'].'/api/Pay/BlindRechargeNotify';
-                    $app = Factory::payment($config);
-
-                    $post_data = [
-                        'body' => $body,
-                        'out_trade_no' => $order_no,
-                        'total_fee' => $total_fee,
-                        'attach'=>$this->uid,     //自定义传值
-                    ];
-                    //trade_type   SAPI--JSAPI支付(或小程序支付)、NATIVE--Native支付、APP--app支付,MWEB--H5支付
-                    if ($from=='wx'){
-                        $post_data['openid'] = $user['openid'];
-                        $post_data['trade_type'] = 'JSAPI';
-                    }elseif ($from=='h5'){
-                        $post_data['trade_type'] = 'MWEB';
-                    }
-                    $result = $app->order->unify($post_data);
-
-                    if ($result['return_msg']=='OK'){
-                        if ($result['result_code']=='FAIL'){
-                            $com = false;
-                            Db::rollback();
-                        }else{
-                            $order1 = $app->jssdk->bridgeConfig($result['prepay_id']);//执行二次签名返回参数
-                            $retrun_data['order_no'] = $order_no;
-                            $retrun_data['pay'] = json_decode($order1,true);
-                            Db::commit();
-                        }
-                    }else{
-                        $com = false;
-                        Db::rollback();
-                    }
-                    break;
-                case 'zfb':
-
-                    $zfb = new AliPay();
-                    $notify_url = 'https://'.$_SERVER['SERVER_NAME'].'/index.php/api/Pay/alipayBlindRechargeNotify';//回调地址
-                    $order = $zfb->ali_pay_pc($body, $total_fee, $order_no, $notify_url,'https://'.$_SERVER['SERVER_NAME'].'/web/h5/pages/manghe/manghe');//调用支付宝支付的方法
-                    $retrun_data['order_no'] = $order_no;
-                    $retrun_data['pay'] = $order;
-                    Db::commit();
-                    break;
-            }
-        }catch (\Exception $e){
-            $com=false;
-            Db::rollback();
-        }
-        if ($com){
-            $this->success('成功',$retrun_data);
-        }
-        $this->error('失败,请稍后重试');
-    }
-
-
-
-    /**
-     * @title 用户中奖纪录
-     * @desc 用户中奖纪录
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/Box/boxLog
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @return  name:id type:int require:0 default:0 desc:ID
-     * @return  name:name type:string require:0 default:0 desc:奖品名称
-     * @return  name:cover type:string require:0 default:0 desc:藏品图片
-     * @return  name:member_name type:string require:0 default:0 desc:用户昵称
-     * @return  name:create_at type:string require:0 default:0 desc:时间
-     */
-    public function boxLog(){
-        $list = Db::name('store_blind_box_log')
-            ->whereIn('is_prize',1)
-            ->field('id,m_id,name,cover,create_at')
-            ->order('id desc')
-            ->limit(10)
-            ->select();
-        foreach ($list as &$v){
-            $v['member_name'] = Db::name('store_member')->where('id',$v['m_id'])->value('name');
-        }
-        $this->success('成功',$list);
-    }
-
-
-}

+ 0 - 238
application/api/controller/Index.php

@@ -1,238 +0,0 @@
-<?php
-
-
-namespace app\api\controller;
-use app\common\library\Jiyan;
-use think\cache\driver\Redis;
-use think\Db;
-/**
- * @title 首页、详情
- * @controller Index
- * @package app\api\controller
- */
-class Index extends Base
-{
-
-    public function initialize(){
-        //parent::check_login();
-    }
-
-    /**
-     * @title 获取轮播图
-     * @desc  获取轮播图
-     * @author  Gavin
-     * @url /api/Index/getBanner
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     *
-     */
-    public function getBanner()
-    {
-
-
-
-        $list =  Db::table('store_banner')
-            ->field('id,name,cover')
-            ->where(['is_deleted'=>0])
-            ->order('sort desc ,id desc')
-            ->select();
-        $this->success('ok',$list);
-    }
-
-    /**
-     * @title 首页藏品列表
-     * @desc 首页藏品列表
-     * @author  Gavin
-     * @url /api/Index/indexCollectionList
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @return name:name type:string default:-- desc:藏品名称
-     * @return name:cover type:string default:-- desc:藏品图
-     * @return name:label type:string default:-- desc:标签
-     * @return name:price type:DECIMAL default:-- desc:价格
-     * @return name:inventory type:int default:-- desc:库存
-     * @return name:now_inventory type:int default:-- desc:剩余库存
-     * @return name:state type:float default:-- desc:藏品状态(1:进行中2:即将开售3:已售罄)
-     * @return name:sell_time type:string default:-- desc:发行时间
-     * @return name:is_remind type:string default:-- desc:是否设置提醒true:已设置false:未设置
-     */
-    public function indexCollectionList(){
-        checkCollectionState();
-        parent::set_uid();
-        $type = input('type',1);
-        $list = Db::name('store_collection')
-            ->where('is_deleted',0)
-            ->where('status',1)
-            ->whereIn('type',$type)
-            ->field('id,cover,name,label,price,inventory,now_inventory,state,sell_time,detail_img,sold_out,buy_count')
-            ->order('state asc,sell_time desc')
-            ->select();
-        foreach ($list as &$v){
-            $now_inventory = getCollectionInventory($v['id']);
-            $v['now_inventory'] = $now_inventory<=0 ? 0 : $now_inventory;
-            if (!$v['sold_out']){
-                $v['state'] =3;
-                $v['now_inventory'] = 0;
-            }
-            $v['id'] = (string)$v['id'];
-            $v['is_remind'] = getRemind($this->uid,$v['id']) ? true : false;
-        }
-       $this->success('成功',$list);
-    }
-
-    /**
-     * @title 发售日历
-     * @desc 发售日历
-     * @author  Gavin
-     * @url /api/Index/CollectionCalendar
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @return name:name type:string default:-- desc:藏品名称
-     * @return name:cover type:string default:-- desc:藏品图
-     * @return name:label type:string default:-- desc:标签
-     * @return name:price type:DECIMAL default:-- desc:价格
-     * @return name:inventory type:int default:-- desc:库存
-     * @return name:now_inventory type:int default:-- desc:剩余库存
-     * @return name:state type:float default:-- desc:藏品状态(1:进行中2:即将开售3:已售罄)
-     * @return name:sell_time type:string default:-- desc:发行时间
-     * @return name:date type:string default:-- desc:日期
-     * @return name:time type:string default:-- desc:时间
-     * @return name:is_remind type:string default:-- desc:是否设置提醒true:已设置false:未设置
-     */
-    public function CollectionCalendar(){
-        checkCollectionState();
-        parent::set_uid();
-        $datelist = Db::name('store_collection')
-            ->where('is_deleted',0)
-            ->where('status',1)
-            ->where('state',2)
-            ->whereIn('type','1,3')
-            ->where('date','>=',date('Y-m-d',time()))
-            ->group('date')
-            ->order('date asc')
-            ->column('date');
-        if ($datelist){
-            foreach ($datelist as $k=>&$v){
-                $array[$k]['date'] = $v;
-                $list = Db::name('store_collection')
-                    ->where('is_deleted',0)
-                    ->where('status',1)
-                    ->where('state',2)
-                    ->where('date',$v)
-                    ->field('id,cover,name,label,price,inventory,now_inventory,state,sell_time,date,detail_img,sold_out,buy_count')
-                    ->order('state asc,sell_time asc')
-                    ->select();
-                foreach ($list as &$a){
-                    $a['time'] = date('H:i',strtotime($a['sell_time']));
-                    $a['is_remind'] = getRemind($this->uid,$a['id']) ? true : false;
-                    $now_inventory = getCollectionInventory($a['id']);
-                    $a['now_inventory'] = $now_inventory<=0 ? 0 : $now_inventory;
-                    if (!$a['sold_out']){
-                        $a['state'] =3;
-                        $a['now_inventory'] = 0;
-                    }
-                    $a['id'] = (string)$a['id'];
-                }
-                $array[$k]['list'] = $list;
-            }
-        }else $array=[];
-        $this->success('成功',$array);
-    }
-
-
-
-    /**
-     * @title 藏品详情
-     * @desc 藏品详情
-     * @author  Gavin
-     * @url /api/Index/CollectionDetail
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param name:id type:string require:1 default:-- desc:藏品ID
-     *
-     * @return name:name type:string default:-- desc:藏品名称
-     * @return name:cover type:string default:-- desc:藏品图
-     * @return name:label type:string default:-- desc:标签
-     * @return name:price type:DECIMAL default:-- desc:价格
-     * @return name:inventory type:int default:-- desc:库存
-     * @return name:now_inventory type:int default:-- desc:剩余库存
-     * @return name:state type:float default:-- desc:藏品状态(1:进行中2:即将开售3:已售罄)
-     * @return name:sell_time type:string default:-- desc:发行时间
-     * @return name:describe type:string default:-- desc:商品描述
-     * @return name:buy_count type:int default:1 desc:限购数量
-     * @return name:instructions type:int default:1 desc:权益说明
-     * @return name:buy_notice type:int default:1 desc:购买须知
-     * @return name:warm_prompt type:int default:1 desc:温馨提示
-     * @return name:auth_img type:int default:1 desc:作者头像
-     * @return name:auth_name type:int default:1 desc:作者姓名
-     * @return name:is_remind type:string default:-- desc:是否设置提醒true:已设置false:未设置
-     * @return name:share_img type:string default:-- desc:分享二维码
-     */
-    public function CollectionDetail(){
-        parent::set_uid();
-        $collect_id = input('id');
-        if (!$collect_id) $this->error('参数错误');
-        checkCollectionState($collect_id);
-        $info = Db::name('store_collection')
-            //->where('is_deleted',0)
-            //->where('status',1)
-            ->whereIn('type','1,3')
-            ->where('id',$collect_id)
-            ->field('id,cover,name,label,price,inventory,now_inventory,state,sell_time,describe,buy_count,instructions,buy_notice,warm_prompt,auth_img,auth_name,share_img,intro,detail_img,format,sold_out')
-            ->find();
-        if (!$info) $this->error('藏品不存在');
-        $info['describe'] = explode('|',$info['describe']);
-        $info['is_remind'] = getRemind($this->uid,$info['id']) ? true : false;
-        $now_inventory = getCollectionInventory($info['id']);
-        $info['now_inventory'] = $now_inventory<=0 ? 0 : $now_inventory;
-        if (!$info['sold_out']){
-            $info['state'] =3;
-            $info['now_inventory'] = 0;
-        }
-        $info['id'] = (string)$info['id'];
-        $this->success('成功',$info);
-    }
-
-
-    /**
-     * @title 设置提醒
-     * @desc 设置提醒
-     * @author  Gavin
-     * @url /api/Index/setRemind
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param name:id type:string require:1 default:-- desc:藏品ID
-     */
-    public function setRemind(){
-        parent::check_login();
-        $id = input('id');
-        if (!$id) $this->error('参数错误');
-        $remind = Db::name('store_collection_remind')
-            ->where('mid',$this->uid)
-            ->where('c_id',$id)
-            ->count();
-        if ($remind) $this->error('已设置过');
-        $data = [
-            'c_id'=>$id,
-            'mid'=>$this->uid,
-            'mobile'=>Db::name('store_member')->where('id',$this->uid)->value('phone')
-        ];
-        if (Db::name('store_collection_remind')->insert($data)) $this->success('设置成功');
-        $this->error('设置失败');
-    }
-
-    public function jytest(){
-        $lot_number = input('lot_number');
-        $captcha_output = input('captcha_output');
-        $pass_token = input('pass_token');
-        $gen_time = input('gen_time');
-        $jy = new Jiyan();
-        $jy->jy($lot_number,$captcha_output,$pass_token,$gen_time,2);
-    }
-
-
-}

+ 0 - 301
application/api/controller/Login.php

@@ -1,301 +0,0 @@
-<?php
-
-// +----------------------------------------------------------------------
-// | ThinkAdmin
-// +----------------------------------------------------------------------
-// | 版权所有 2014~2019 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
-// +----------------------------------------------------------------------
-// | 官方网站: http://demo.thinkadmin.top
-// +----------------------------------------------------------------------
-// | 开源协议 ( https://mit-license.org )
-// +----------------------------------------------------------------------
-// | gitee 代码仓库:https://gitee.com/zoujingli/ThinkAdmin
-// | github 代码仓库:https://github.com/zoujingli/ThinkAdmin
-// +----------------------------------------------------------------------
-
-namespace app\api\controller;
-
-use app\common\library\AliPay3;
-use app\common\library\HuijuH5Pay;
-use app\common\library\HuijuKjPay;
-use think\cache\driver\Redis;
-use think\Db;
-use Firebase\JWT\JWT;
-use think\facade\Validate;
-
-/**
- * @title 用户登录
- * @controller Login
- * @group worker
- */
-class Login extends Base
-{
-    /**
-     * @title 注册
-     * @desc 注册
-     * @url /api/Login/Register
-     * @method POST
-     * @tag 基础
-     * @header
-     * @param  name:phone type:string require:1 desc:手机号
-     * @param  name:ver_code type:string require:1 desc:验证码
-     * @param  name:password type:string require:1 desc:密码
-     * @param  name:confirm_password type:string require:1 desc:确认密码
-     * @param  name:second_password type:string require:1 desc:二级密码
-     * @param  name:confirm_second_password type:string require:1 desc:二级确认密码
-     * @param  name:invite_code type:string require:0 desc:邀请码
-     *
-     */
-    public function Register(){
-        $phone = input('phone');
-        $ver_code = input('ver_code');
-        //$password = input('password');
-      //  $confirm_password = input('confirm_password');
-        $second_password = input('second_password');
-        $confirm_second_password = input('confirm_second_password');
-        $invite_code = input('invite_code');
-        if (!$phone || !$ver_code  || !$second_password || !$confirm_second_password){
-            $this->error('参数错误');
-        }
-
-        if (!Validate::regex($phone, "^1\d{10}$")) {
-            $this->error('手机号格式错误');
-        }
-
-//        //验证短信验证码
-//        $time = time()-60;
-//        $sms = Db::name('store_sms')->where(['mobile' => $phone, 'event' => 'register'])
-//            ->where('createtime','>',$time)
-//            ->order('id', 'DESC')
-//            ->find();
-//        if (!$sms || $sms['code'] != $ver_code) $this->error('短信验证码不正确!');
-
-        $user = Db::name('store_member')
-            ->where('is_deleted',0)
-            ->where('phone',$phone)
-            ->find();
-        if ($user) $this->error('手机号已注册');
-       // if (!preg_match('/^[0-9a-z]{6,12}$/i',$password)) $this->error('密码格式错误,请输入6-12位数字+字母');
-       // if ($password!=$confirm_password) $this->error('密码与确认密码不一致');
-        if (!preg_match('/^[0-9]{6}$/i',$second_password)) $this->error('二级密码格式错误,请输入6位纯数字');
-        if ($second_password!=$confirm_second_password) $this->error('二级密码与确认密码不一致');
-        if ($invite_code){
-            $isset = Db::name('store_member')->where('is_deleted',0)->where('invite_code',$invite_code)->find();
-            if (!$isset) $this->error('邀请码不存在');
-            $invitecode = $isset['id'];
-        }else{
-            $invitecode = 0;
-        }
-        $wallet_address = '';
-        $accountName = '';
-        $data = [
-            'phone'=>$phone,
-            'pid'=>$invitecode,
-            //'password'=>md5($password),
-            'second_password'=>md5($second_password),
-            'wallet_address'=>$wallet_address,
-            'accountName'=>$accountName,
-            'reg_ip'=>request()->ip()
-        ];
-        $member_id = Db::name('store_member')->insertGetId($data);
-        if ($member_id){
-            $code = get32Str(8);
-            $invite_img = setintivecode($code);
-            $invite_address = getintiveaddress($code);
-            Db::name('store_member')->where('id',$member_id)->update(['name'=>'收藏者'.$member_id,'invite_img'=>$invite_img,'invite_address'=>$invite_address,'invite_code'=>$code]);
-            //邀请好友送积分
-            if ($invite_code>0){
-                $invite_friends_integral = getConfigValue('invite_friends_integral');
-                memberMoneyChange($invite_friends_integral,1,$invite_code,'邀请好友',1,$member_id);
-            }
-            $this->success('注册成功');
-        }
-        $this->error('注册失败');
-    }
-
-    /**
-     * @title 登录
-     * @desc 登录
-     * @url /api/Login/passwordLogin
-     * @method POST
-     * @tag 基础
-     * @header
-     * @param name:phone type:int require:1 default:-- desc:手机号
-     * @param name:password type:string require:1 default:-- desc:密码
-     * @param  name:ver_code type:string require:1 desc:验证码
-     * @return name:token type:string default:-- desc:用户登录成功后的token值
-     */
-    public function passwordLogin()
-    {
-        $phone = input('phone');
-
-      //  $password = input('password');
-        $ver_code = input('ver_code');
-        if (empty($ver_code) || empty($phone)) {
-            $this->error('参数错误');
-        }
-        $member = Db::name('store_member')
-            ->where('phone', $phone)
-            ->where('is_deleted',0)
-            ->find();
-        if (!$member) $this->error('手机号未注册');
-
-        //验证短信验证码
-//        if ($phone!='15801075991'){
-//            $time = time()-60;
-//            $sms = Db::name('store_sms')->where(['mobile' => $phone, 'event' => 'login'])
-//                ->where('createtime','>',$time)
-//                ->order('id', 'DESC')
-//                ->find();
-//            if (!$sms || $sms['code'] != $ver_code) $this->error('短信验证码不正确!');
-//        }
-
-
-       // if ($member['password']!=md5($password)) $this->error('密码错误');
-        $token = self::create_jwt($member['id']);
-        setMemberInfoHash($member['id']);
-
-        Db::name('store_member')->where('id',$member['id'])->update(['ip'=>request()->ip()]);
-        LoginLog($member['id']);
-
-        $this->success('登录成功', $token);
-    }
-
-    //token加密
-    public function create_jwt($uid)
-    {
-        $key = md5(config('app.jwt')); //jwt的签发密钥,验证token的时候需要用到
-        $time = time(); //签发时间
-        $expire = $time + config('app.jwt_time'); //过期时间
-        $token = array(
-            "uid" => $uid,
-            "iss" => "https://zain.com",//签发组织
-            "aud" => "https://zain.com", //签发作者
-            "iat" => $time,
-            "nbf" => $time,
-            "exp" => $expire
-        );
-        $jwt = JWT::encode($token, $key);
-        return $jwt;
-    }
-
-
-    /**
-     * @title 找回密码
-     * @desc 找回密码
-     * @url /api/Login/ForgetPassword
-     * @method POST
-     * @tag 基础
-     * @header
-     * @param name:phone type:int require:1 default:-- desc:手机号
-     * @param name:ver_code type:string require:1 desc:验证码
-     * @param name:password type:string require:1 default:-- desc:密码
-     * @param  name:confirm_password type:string require:1 desc:确认密码
-     */
-    public function ForgetPassword(){
-
-        $phone = input('phone');
-        $ver_code = input('ver_code');
-        $password = input('password');
-        $confirm_password = input('confirm_password');
-        if (!$phone || !$ver_code || !$password || !$confirm_password) $this->error('参数错误');
-        $member = Db::name('store_member')
-            ->where('phone', $phone)
-            ->where('is_deleted',0)
-            ->find();
-        if (!$member) $this->error('手机号未注册');
-        //验证短信验证码
-        $time = time()-60;
-        $sms = Db::name('store_sms')->where(['mobile' => $phone, 'event' => 'forgetpwd'])
-            ->where('createtime','>',$time)
-            ->order('id', 'DESC')
-            ->find();
-        if (!$sms || $sms['code'] != $ver_code) $this->error('短信验证码不正确!');
-
-        if (!preg_match('/^[0-9a-z]{6,12}$/i',$password)) $this->error('密码格式错误,请输入6-12位数字+字母');
-        if ($password!=$confirm_password) $this->error('密码与确认密码不一致');
-        $data = [
-            'password'=>md5($password),
-            'update_at'=>date('Y-m-d H:i:s')
-        ];
-        if (Db::name('store_member')->where('id',$member['id'])->update($data)) $this->success('修改成功');
-        $this->error('修改失败');
-    }
-
-
-    public function test(){
-
-
-
-        //获取奖励列表
-        $ids = Db::name('store_collection')
-            ->where('is_deleted',0)
-            ->where('pull_new',1)
-            ->column('id');
-        dump($ids);
-        if ($ids){
-            $array = [];
-            foreach ($ids as &$v){
-                $now_inventory = getCollectionInventory($v);
-                if ($now_inventory>0){
-                   array_push($array,$v);
-                }
-            }
-            if ($array){
-                $id = array_rand($array);
-                echo $array[$id];
-            }
-        }
-        dump($array);die;
-        die;
-
-
-
-        $callback_url = 'http://'.$_SERVER['SERVER_NAME'].'/pages/mine/order-list?num=1';
-        $huiju = new HuijuH5Pay();
-        $notify_url = 'http://'.$_SERVER['SERVER_NAME'].'/index.php/api/Pay/ylOrderNotify';//回调地址
-        $huiju->ylh5Pay(get_order_sn(),$callback_url,$notify_url,"测试藏品","0.01",'100000',1);
-
-        //$huiju = new HuijuKjPay();
-        //$huiju->sms();
-        //$huiju->signing();
-        // $huiju->kuaijiePay();
-        die;
-
-
-
-
-        require_once env('root_path').'application/common/library/lib/YopRequest.php';
-        require_once env('root_path').'application/common/library/lib/YopClient3.php';
-        require_once env('root_path').'application/common/library/lib/YopRsaClient.php';
-        $private_key ="MIIEvAIBADANBgkqhkiG9w0BAQEFAASCBKYwggSiAgEAAoIBAQCSBUBO99o0ZCGp8/6qbaSW2MIeHKg/4RZEIexS11rW5wxFH9arHM16yZXObtm1qO1xNnRyofBkKvcOes63yNGqiulDjJbx2gxXzQdq6g0ckO06YZsb6v4AmkCLwu/kFPYTd2zu3nM6VCBsppkjXe2kcdgeKH55PSqTLcqe4TCeCQxxTjmixX/qFdKva7uJxXbdNjE+GERMTPsn9FBGjrv2/6RCz62eZljRcQf2zY9aooXnYaYOOkeYxJaFu4M8k1kEfL/A2ftDGa+9zyWUUp/PskIcSUCLtdd+yR1ZvNldBW7iaeTuZ4YQXg6N3BqFBacBmkHztpqbrg1+C46Hp9C5AgMBAAECggEAHxpGPevWSzWO5BwIQTYUilsGUhKpld20d/O/2k9r1n2lY+3ptE3wyLg6lBuRfPvMA8LlH+u1gCiUsj1fXc9FNa3cDNrb5g0bdvJBo7jR7SVDmp1ixBoUW31/xSVTIsKCPdhA2EqCwchclbgQw3NE5LOpJJdchSeNs4bb82alC+wwDaYnrag/OuehknazOQWqWQVaPI9zJ+eXPNW3etWte1OLDyVoNiSrAdr/BWnBxSxcoANuzypkKN/Sw5W3vgkIHyylReiOLP2JLDNpnDlwgNIaxYOF7p0VGLC1bAqZTjuR4nMKZhohC4FtNC1cy9ZV2c2KV3bD8OXoMPIQB1a8OQKBgQDJnVxK2Mwk/2jitP7mA6JpBFeioJLRzj4gKK56M4InYaRRVZj6UWJd5Jt0uEs6XMlus8T24cfSoglCnXIvTMx8okTbusxn72Ff+/+f0GRLI/VO/cyhSWFl+0P3XTCT+zUVI3+kWvZQ6Tj7l5BWubqLObBdrNDhpbYhQptnm+KHJQKBgQC5aMwHmtE5Cs6+z2zGkIvVw4dOQcvo9E+gGCsjbSdeFvcrOpg/NNQ0dmu54F8CF6z9VkoitL8NTI63V4LqLnZ9BK+K/0L8UMzbbhCqT9+JTrjNraby77akxldKTUZZHiC1edWT/Ll8t6xT6oVw02yZz8Flpc7DnNXuJGGxQIlpBQKBgHinh3fzThhGEUq67mBQhH08cAWO+s48EsnEDsZq1NUkheV2yFnlImz2RmIPeFWw+YsaYiEs9RyEg+4tswvDdgyQP40PuQvqIegDMvM9Dwg4uLFRCYjsFTGmsQHz7wJgL2A7IkQFe6roJ4XJKkP8Wjq/h2BH76laNiipZ78VdvdRAoGAKqgnuOAvnrYT1uaWGiELawTvTlvo9BGxeB3XXvEwC3+xIir6+B/JasCMDFnIwgx8alS9/boj8oVYmGnz3rkN3bmEQbB00uQsHZf3EZgKz+Zisj9vl5j7JnHTh2677qj10YrUTpXofv8rEKt2Q/0AkWqxDhfVuD+PIJkSONumQZkCgYACVSnvt+kizEIwdshvGzAkzZaMBR6Xf1d//cuIWzU1bO7pkCQogq9MXv9hCZx2N1B51VSvwazJ6B029uzgYzr0iTeZBfB5ntb53/vEycLMhB9r9Bc+0x7bxrQZeWNwLlQFxhDeSO9le0ETjfGPt/nS2QbFL7bNHwRGE+AzxwH0aA==";
-        $request = new \YopRequest("app_10086863938", $private_key);
-
-        $request->addParam('requestNo',get_order_sn());
-        $request->addParam('parentMerchantNo','10086863938');
-        $request->addParam('merchantNo','10086863938');
-        $request->addParam('name','宋星伟');
-        $request->addParam('cardNo','371324199210037710');
-        $request->addParam('cardType','ID');
-        $request->addParam('returnUrl','https://'.$_SERVER['SERVER_NAME'].'/web/h5/pages/mine/order-list?num=1');
-        $request->addParam('notifyUrl','https://'.$_SERVER['SERVER_NAME'].'/api/Pay/re');
-
-        $response = \YopRsaClient::post("/rest/v1.0/auth/face-auth", $request);
-        dump(json_decode(json_encode($response,true),true));
-        die;
-
-
-
-
-
-//        require_once env('root_path').'application/common/library/lib/YopRequest.php';
-//        require_once env('root_path').'application/common/library/lib/YopClient3.php';
-//        require_once env('root_path').'application/common/library/lib/YopRsaClient.php';
-//        $private_key ="MIIEvAIBADANBgkqhkiG9w0BAQEFAASCBKYwggSiAgEAAoIBAQCSBUBO99o0ZCGp8/6qbaSW2MIeHKg/4RZEIexS11rW5wxFH9arHM16yZXObtm1qO1xNnRyofBkKvcOes63yNGqiulDjJbx2gxXzQdq6g0ckO06YZsb6v4AmkCLwu/kFPYTd2zu3nM6VCBsppkjXe2kcdgeKH55PSqTLcqe4TCeCQxxTjmixX/qFdKva7uJxXbdNjE+GERMTPsn9FBGjrv2/6RCz62eZljRcQf2zY9aooXnYaYOOkeYxJaFu4M8k1kEfL/A2ftDGa+9zyWUUp/PskIcSUCLtdd+yR1ZvNldBW7iaeTuZ4YQXg6N3BqFBacBmkHztpqbrg1+C46Hp9C5AgMBAAECggEAHxpGPevWSzWO5BwIQTYUilsGUhKpld20d/O/2k9r1n2lY+3ptE3wyLg6lBuRfPvMA8LlH+u1gCiUsj1fXc9FNa3cDNrb5g0bdvJBo7jR7SVDmp1ixBoUW31/xSVTIsKCPdhA2EqCwchclbgQw3NE5LOpJJdchSeNs4bb82alC+wwDaYnrag/OuehknazOQWqWQVaPI9zJ+eXPNW3etWte1OLDyVoNiSrAdr/BWnBxSxcoANuzypkKN/Sw5W3vgkIHyylReiOLP2JLDNpnDlwgNIaxYOF7p0VGLC1bAqZTjuR4nMKZhohC4FtNC1cy9ZV2c2KV3bD8OXoMPIQB1a8OQKBgQDJnVxK2Mwk/2jitP7mA6JpBFeioJLRzj4gKK56M4InYaRRVZj6UWJd5Jt0uEs6XMlus8T24cfSoglCnXIvTMx8okTbusxn72Ff+/+f0GRLI/VO/cyhSWFl+0P3XTCT+zUVI3+kWvZQ6Tj7l5BWubqLObBdrNDhpbYhQptnm+KHJQKBgQC5aMwHmtE5Cs6+z2zGkIvVw4dOQcvo9E+gGCsjbSdeFvcrOpg/NNQ0dmu54F8CF6z9VkoitL8NTI63V4LqLnZ9BK+K/0L8UMzbbhCqT9+JTrjNraby77akxldKTUZZHiC1edWT/Ll8t6xT6oVw02yZz8Flpc7DnNXuJGGxQIlpBQKBgHinh3fzThhGEUq67mBQhH08cAWO+s48EsnEDsZq1NUkheV2yFnlImz2RmIPeFWw+YsaYiEs9RyEg+4tswvDdgyQP40PuQvqIegDMvM9Dwg4uLFRCYjsFTGmsQHz7wJgL2A7IkQFe6roJ4XJKkP8Wjq/h2BH76laNiipZ78VdvdRAoGAKqgnuOAvnrYT1uaWGiELawTvTlvo9BGxeB3XXvEwC3+xIir6+B/JasCMDFnIwgx8alS9/boj8oVYmGnz3rkN3bmEQbB00uQsHZf3EZgKz+Zisj9vl5j7JnHTh2677qj10YrUTpXofv8rEKt2Q/0AkWqxDhfVuD+PIJkSONumQZkCgYACVSnvt+kizEIwdshvGzAkzZaMBR6Xf1d//cuIWzU1bO7pkCQogq9MXv9hCZx2N1B51VSvwazJ6B029uzgYzr0iTeZBfB5ntb53/vEycLMhB9r9Bc+0x7bxrQZeWNwLlQFxhDeSO9le0ETjfGPt/nS2QbFL7bNHwRGE+AzxwH0aA==";
-//        $request = new \YopRequest("app_10086863938", $private_key);
-//        $request->addFile("merQual", "C:\Users\xk\Pictures\΢�Ž�ͼ_20220316150041.png");
-//        $response = \YopRsaClient::upload("/yos/v1.0/sys/merchant/qual/upload", $request);
-//        dump($response);
-    }
-
-}

+ 0 - 557
application/api/controller/Order.php

@@ -1,557 +0,0 @@
-<?php
-namespace app\api\controller;
-use app\common\library\AliPay;
-use app\common\library\AliPay3;
-use app\common\library\HuijuH5Pay;
-use app\common\library\Jiyan;
-use think\cache\driver\Redis;
-use think\Db;
-use think\Exception;
-use EasyWeChat\Factory;
-use think\Session;
-use function Sodium\add;
-
-
-/**
- * @title 订单
- * @controller GoodsOrder
- * @group base
- */
-class Order extends Base
-{
-    public function initialize()
-    {
-        parent::initialize();
-        parent::check_login();
-    }
-
-    /**
-     * @title 生成订单(立即购买 )
-     * @desc  生成订单(立即购买 )
-     * @author  Gavin
-     * @url /api/Order/createOrder
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param name:id type:int require:1 default:-- desc:藏品id
-     * @param name:num type:int require:1 default:1 desc:数量
-     * @param name:pay_type type:string require:1 default:wx desc:wx:微信zfb:支付宝
-     * @param name:from type:string require:1 default:wx desc:wx:微信公众号h5:网页
-     *
-     * @return  name:order_no type:int require:0 default:0 desc:订单号
-     * @return  name:pay type:string require:0 default:0 desc:支付信息
-     */
-    public function createOrder()
-    {
-        $redis = new Redis([ 'select'=> 2]);
-        $redis_value = $redis->get('order_buy'.$this->uid);
-        if ($redis_value){
-            $this->error('请求过快,请稍后重试');
-        }else{
-            $redis->set('order_buy'.$this->uid,1,1);
-        }
-
-        $id = input('id');
-        $num = input('num',1);
-        $pay_type = input('pay_type','wx');
-        $from = input('from','wx');
-
-        if (!$id || !$num) $this->error('参数错误');
-        //极验数据
-//        $lot_number = input('lot_number');
-//        $captcha_output = input('captcha_output');
-//        $pass_token = input('pass_token');
-//        $gen_time = input('gen_time');
-//        if (!$lot_number || !$captcha_output || !$pass_token || !$gen_time) $this->error('参数错误');
-//
-//        $jy = new Jiyan();
-//        $result = $jy->jy($lot_number,$captcha_output,$pass_token,$gen_time,2);
-//        if ($result['result']=='fail') $this->error('校验失败,请稍后重试');
-
-        $user = getMemberInfoHash($this->uid); //获取用户信息
-        if ($user['is_auth']==0) $this->error('请实名认证后购买!');
-        $coll_info = getCollectionInfoHash($id);
-        if ($coll_info['is_deleted']==1 || $coll_info['status']==0) $this->error('藏品已下架');
-
-        $inventory = getCollectionInventory($id);
-        if ($coll_info['state']!=1) $this->error('状态错误');
-        if ($inventory<$num) $this->error('库存不足');
-        if ($inventory<1) $this->error('还有未支付的订单,您有可能捡漏哦!');
-        if (!$coll_info['sold_out']) $this->error('已售罄');
-
-
-        $sell_time = strtotime($coll_info['sell_time']);
-        if ($sell_time>time()) $this->error('商品还未开始售卖!请耐心等待');
-
-        //获取用户已经购买数量
-        $userByCount = getByCount($this->uid,$id);
-        if ($coll_info['buy_count']<($userByCount+$num)) $this->error('每人限购'.$coll_info['buy_count'].'个');
-
-        //获取是否已经铸造hash
-        //$hashCount = getLenCollection($id);
-        $hash = Db::name('hash2')->where('goods_id',$id)->where('success',1)->count();
-        if (!$hash) $this->error('nft未上架,无法购买');
-       // if (!$hashCount || $hashCount<$num) $this->error('hash未铸造,无法购买');
-
-        if ($from=='wx'){
-            if (!$user['openid']) $this->error('微信未授权,无法购买');
-        }
-
-        //先减掉库存
-        loseCollectionInventory($id,$num);
-        //先增加购买数量
-        IncrByCount($this->uid,$id,$num);
-
-
-        $order_no = get_order_sn();
-        $total_fee = bcmul($coll_info['price'],$num,2);
-
-        $redis_data = [
-            'mid'=>$this->uid,
-            'c_id'=>$id,
-            'order_no'=>$order_no,
-            'inventory'=>$coll_info['inventory'],
-            'num'=>$num,
-            'pro_info'=>json_encode($coll_info),
-            'status'=>0,
-            'create_at'=>date('Y-m-d H:i:s'),
-            'pay_price'=>$total_fee,
-            'pay_type'=>$pay_type
-        ];
-        $com = true;
-        $retrun_data['order_no'] = $order_no;
-        $retrun_data['pay'] = '';
-
-        if ($com){
-            $redis = new Redis();
-            //收集下单用户id
-            setCollectionBuyUser($this->uid);
-            $redis->hMSet('order_not_pay_'.$this->uid,[$order_no=>json_encode($redis_data,true)]); //存入redis
-            $this->success('成功',$retrun_data);
-        }else{
-            //加上库存
-            addCollectionInventory($id,$num);
-            //减少用户购买数量
-            DecrByCount($this->uid,$id,$num);
-
-            $this->error('服务器繁忙,请稍后重试');
-        }
-
-    }
-
-
-    /**
-     * @title 我的订单-待支付、已购买
-     * @desc  我的订单-待支付、已购买
-     * @author  Gavin
-     * @url /api/Order/getMyOrderList
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param  name:status type:int  : default:0 desc:0:待支付1:已购买
-     * @param  name:page type:int  : default:1 desc:页数
-     * @param  name:page_num type:int  : default:20 desc:每页数
-     *
-     * @return  name:order_no type:string default:-- desc:订单号
-     * @return  name:num type:int default:-- desc:数量
-     * @return  name:pay_price type:string default:-- desc:订单金额
-     * @return  name:status type:int default:-- desc:类型0:待支付1:已支付
-     * @return  name:cancel_time type:string default:-- desc:待支付自动取消时间
-     * @return  name:pay_type type:string default:-- desc:支付方式wx:微信zfb:支付宝
-     * @return  name:create_at type:string default:-- desc:创建时间
-     * @return name:pro_info@name type:string default:-- desc:藏品名称
-     * @return name:pro_info@cover type:string default:-- desc:藏品图片
-     * @return name:pro_info@price type:string default:-- desc:藏品单价
-     * @return name:pro_info@auth_img type:string default:-- desc:藏品作者头像
-     * @return name:pro_info@auth_name type:string default:-- desc:藏品作者名称
-     */
-    public function getMyOrderList(){
-        $status = input('status',0);
-
-        if ($status==0){
-            $redis = new Redis();
-            $key = 'order_not_pay_'.$this->uid;
-            $count = $redis->hGetLen($key);
-            $list = $redis->hGetvals($key);
-            if ($list){
-                //自动取消分钟数
-                $cancel_time = getCancelTime();
-                foreach ($list as $k=>&$v){
-                    $info = json_decode($v,true);
-                    $info['pro_info'] = json_decode($info['pro_info'],true);
-                    $info['cancel_time'] = date('Y-m-d H:i:s',strtotime($info['create_at'])+($cancel_time*60));
-                    $list[$k] = $info;
-                }
-            }
-        }else{
-            $where = [
-                'is_deleted'=>0,
-                'status'=>$status,
-                'mid'=>$this->uid
-            ];
-            $count = Db::name('store_order')->where($where)->count();
-            $list = Db::name('store_order')
-                ->where($where)
-                ->field('id,c_id,order_no,num,pro_info,status,create_at,pay_price,pay_type')
-                ->order('id desc')
-                ->limit($this->off_set,$this->page_num)
-                ->select();
-            foreach ($list as &$v){
-                $v['pro_info'] = json_decode($v['pro_info'],true);
-            }
-        }
-        $this->success('成功',compact('count','list'));
-    }
-
-    /**
-     * @title 待支付、已购买订单详情
-     * @desc  待支付、已购买订单详情
-     * @author  Gavin
-     * @url /api/Order/MyOrderListDetail
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param  name:order_no type:string default:0 desc:订单号
-     * @param  name:type type:int default:1 desc:1:待支付2:已支付
-     *
-     * @return  name:order_no type:string default:-- desc:订单号
-     * @return  name:num type:int default:-- desc:数量
-     * @return  name:pay_price type:string default:-- desc:订单金额
-     * @return  name:status type:int default:-- desc:类型0:待支付1:已支付
-     * @return  name:cancel_time type:string default:-- desc:待支付自动取消时间
-     * @return  name:create_at type:string default:-- desc:创建时间
-     * @return  name:pay_at type:string default:-- desc:支付时间
-     * @return  name:pay_type type:string default:-- desc:支付方式wx:微信zfb:支付宝
-     * @return name:pro_info@name type:string default:-- desc:藏品名称
-     * @return name:pro_info@cover type:string default:-- desc:藏品图片
-     * @return name:pro_info@price type:string default:-- desc:藏品单价
-     * @return name:pro_info@auth_img type:string default:-- desc:藏品作者头像
-     * @return name:pro_info@auth_name type:string default:-- desc:藏品作者名称
-     */
-    public function MyOrderListDetail(){
-        $order_no = input('order_no');
-        $type = input('type',1);
-        if (!$order_no) $this->error('参数错误');
-        if ($type==1){
-            $redis = new Redis();
-            $key = 'order_not_pay_'.$this->uid;
-            $order = $redis->hGet($key,$order_no);
-            $order = json_decode($order,true);
-        }else{
-            $order = Db::name('store_order')
-                ->where('order_no',$order_no)
-                ->where('mid',$this->uid)
-                ->where('is_deleted',0)
-                ->find();
-        }
-        if (!$order) $this->error('订单不存在');
-        $order['pro_info'] = json_decode($order['pro_info'],true);
-        //自动取消分钟数
-        $cancel_time = getCancelTime();
-        if ($order['status']==0){
-            $order['cancel_time'] = date('Y-m-d H:i:s',strtotime($order['create_at'])+($cancel_time*60));
-        }
-        $this->success('成功',$order);
-    }
-
-
-    /**
-     * @title 待支付订单支付
-     * @desc  待支付订单支付
-     * @author  Gavin
-     * @url /api/Order/payOrder
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param name:order_no type:string require:1 default:-- desc:订单号
-     * @param name:from type:string require:1 default:wx desc:wx:微信公众号h5:网页
-     *
-     * @return  name:order_no type:int require:0 default:0 desc:订单号
-     * @return  name:pay type:string require:0 default:0 desc:支付信息
-     */
-    public function payOrder(){
-        $user = getMemberInfoHash($this->uid); //获取用户信息
-        $order_no = input('order_no');   //订单号
-        $from = input('from','wx');
-        if (!$order_no) $this->error('参数错误');
-
-
-        $redis = new Redis();
-        $key = 'order_not_pay_'.$this->uid;
-        $order = $redis->hGet($key,$order_no);
-        if (!$order) $this->error('订单不存在');
-        $order = json_decode($order,true);
-        if ($order['status']!=0) $this->error('订单已支付或已取消');
-        $order_no = $order['order_no'];
-        $total_fee = $order['pay_price'];
-        $pay_type = $order['pay_type'];
-        $body = 'top艺术购买藏品';
-        $com = true;
-        switch ($pay_type){
-            case 'wx':
-                $config = retrunWxConfig();
-                $total_fee = $total_fee * 100;
-                $config['notify_url'] = $this->request->root(true).'/api/Pay/WxOrderNotify';
-                $app = Factory::payment($config);
-
-                $post_data = [
-                    'body' => $body,
-                    'out_trade_no' => $order_no,
-                    'total_fee' => $total_fee,
-                    'attach'=>$this->uid,     //自定义传值
-                ];
-                //trade_type   SAPI--JSAPI支付(或小程序支付)、NATIVE--Native支付、APP--app支付,MWEB--H5支付
-                if ($from=='wx'){
-                    $post_data['openid'] = $user['openid'];
-                    $post_data['trade_type'] = 'JSAPI';
-                }elseif ($from=='h5'){
-                    $post_data['trade_type'] = 'MWEB';
-                }
-
-                $result = $app->order->unify($post_data);
-                if ($result['return_msg']=='OK'){
-                    if ($result['result_code']=='FAIL'){
-                        $com = false;
-                    }else{
-                        $order1 = $app->jssdk->bridgeConfig($result['prepay_id']);//执行二次签名返回参数
-                        $redis_data['wx_order'] = $order1;
-                        $retrun_data['order_no'] = $order_no;
-                        $retrun_data['pay'] = json_decode($order1,true);
-                    }
-                }else{
-                    $com = false;
-                }
-                break;
-            case 'zfb':
-
-                $order_nos = get_order_sn();
-                $order['order_no'] = $order_nos;
-                $redis->hMSet($key,[$order_nos=>json_encode($order,true)]); //存入redis
-               //存入redis
-                $redis->hdel($key,$order_no);
-
-                $zfb = new AliPay3();
-                $notify_url = 'https://'.$_SERVER['SERVER_NAME'].'/index.php/api/Pay/alipayOrderNotify';//回调地址
-                $callback_url = 'https://'.$_SERVER['SERVER_NAME'].'/pages/mine/order-list?num=1';
-                $order = $zfb->aliPay($body,$total_fee,$order_nos,$notify_url,$this->uid,$callback_url);
-                $retrun_data['order_no'] = $order_nos;
-                $retrun_data['pay'] = $order['pay_url'];
-                break;
-            case 'ylh5':
-                $order_nos = get_order_sn();
-                $order['order_no'] = $order_nos;
-                $redis->hMSet($key,[$order_nos=>json_encode($order,true)]); //存入redis
-                //存入redis
-                $redis->hdel($key,$order_no);
-
-                $callback_url = 'https://'.$_SERVER['SERVER_NAME'].'/pages/mine/order-list?num=1';
-                $huiju = new HuijuH5Pay();
-                $notify_url = 'https://'.$_SERVER['SERVER_NAME'].'/index.php/api/Pay/ylOrderNotify';//回调地址
-                $pro_info = json_decode($order['pro_info'],true);
-                $result = $huiju->ylh5Pay($order_nos,$callback_url,$notify_url,$pro_info['name'],$total_fee,$this->uid,2);
-                if ($result['ra_Code']=='100'){
-                    $retrun_data['order_no'] = $order_nos;
-                    $retrun_data['pay'] = $result['rc_Result'];
-                }else{
-                    $com = false;
-                }
-                break;
-            case 'zfbh5':
-                $order_nos = get_order_sn();
-                $order['order_no'] = $order_nos;
-                $redis->hMSet($key,[$order_nos=>json_encode($order,true)]); //存入redis
-                //存入redis
-                $redis->hdel($key,$order_no);
-
-                $callback_url = 'https://'.$_SERVER['SERVER_NAME'].'/pages/mine/order-list?num=1';
-                $huiju = new HuijuH5Pay();
-                $notify_url = 'https://'.$_SERVER['SERVER_NAME'].'/index.php/api/Pay/ylOrderNotify';//回调地址
-                $pro_info = json_decode($order['pro_info'],true);
-                $result = $huiju->ylh5Pay($order_nos,$callback_url,$notify_url,$pro_info['name'],$total_fee,$this->uid,1);
-                if ($result['ra_Code']=='100'){
-                    $retrun_data['order_no'] = $order_nos;
-                    $retrun_data['pay'] = $result['rc_Result'];
-                }else{
-                    $com = false;
-                }
-                break;
-        }
-        if ($com){
-            $this->success('成功',$retrun_data);
-        }else{
-            $this->error('调起支付失败,请稍后重试');
-        }
-    }
-
-
-    /**
-     * @title 取消订单
-     * @desc  取消订单
-     * @author  Gavin
-     * @url /api/Order/cancelOrder
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param name:order_no type:string require:1 default:-- desc:订单号
-     */
-    public function cancelOrder(){
-        $order_no = input('order_no');
-        if (!$order_no) $this->error('参数错误');
-        $redis = new Redis();
-        $key = 'order_not_pay_'.$this->uid;
-        $order = $redis->hGet($key,$order_no);
-        if (!$order) $this->error('订单不存在');
-        $order = json_decode($order,true);
-        if ($order['status']!=0) $this->error('订单已支付或已取消');
-        $com = true;
-        Db::startTrans();
-        try {
-            $order['status'] = 2;
-            $order['cancel_at'] = date('Y-m-d H:i:s');
-            $order['cancel_state'] = 2;
-            Db::name('store_order')->insert($order);
-            Db::commit();
-        }catch (\Exception $e){
-            $com=false;
-            Db::rollback();
-        }
-        if ($com){
-            //加上库存
-            addCollectionInventory($order['c_id'],$order['num']);
-            //减少用户购买数量
-            DecrByCount($this->uid,$order['c_id'],$order['num']);
-            //删除数据
-            $redis->hdel($key,$order_no);
-
-            $this->success('取消成功');
-        }else{
-            $this->error('取消失败,请稍后重试');
-        }
-    }
-
-
-
-    /**
-     * @title 我的订单-转赠
-     * @desc  我的订单-转赠
-     * @author  Gavin
-     * @url /api/Order/getMySendList
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param  name:page type:int  : default:1 desc:页数
-     * @param  name:page_num type:int  : default:20 desc:每页数
-     *
-     * @return  name:order_no type:string default:-- desc:订单号
-     * @return name:over_time type:string default:-- desc:转赠时间
-     * @return name:status type:int default:-- desc:类型2:赠出3:获赠
-     * @return name:send_name type:string default:-- desc:转赠者/受赠者
-     * @return name:collectors_hash type:string default:-- desc:hash
-     * @return name:pro_info@name type:string default:-- desc:藏品名称
-     * @return name:pro_info@price type:string default:-- desc:藏品价格
-     * @return name:pro_info@price type:string default:-- desc:藏品单价
-     * @return name:pro_info@auth_img type:string default:-- desc:藏品作者头像
-     * @return name:pro_info@auth_name type:string default:-- desc:藏品作者名称
-     */
-    public function getMySendList(){
-        $where = [
-            'mid'=>$this->uid,
-        ];
-        $count = Db::name('store_order_info')->where($where)->whereIn('status','2,3')->count();
-        $list = Db::name('store_order_info')
-            ->where($where)
-            ->whereIn('status','2,3')
-            ->field('id,order_no,pro_info,over_time,create_at,status,to_mid,collectors_hash')
-            ->order('id desc')
-            ->limit($this->off_set,$this->page_num)
-            ->select();
-        foreach ($list as &$v){
-            $v['pro_info'] = json_decode($v['pro_info'],true);
-            $v['send_name'] = Db::name('store_member')->where('id',$v['to_mid'])->value('name');
-        }
-        $this->success('成功',compact('count','list'));
-    }
-
-
-    /**
-     * @title 转赠订单详情
-     * @desc  转赠订单详情
-     * @author  Gavin
-     * @url /api/Order/getMySendListDetail
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param  name:order_id type:int  : default:1 desc:订单ID
-     *
-     * @return  name:order_no type:string default:-- desc:订单号
-     * @return name:over_time type:string default:-- desc:转赠时间
-     * @return name:status type:int default:-- desc:类型2:赠出3:获赠
-     * @return name:send_name type:string default:-- desc:转赠者/受赠者
-     * @return name:collectors_hash type:string default:-- desc:hash
-     * @return name:pro_info@name type:string default:-- desc:藏品名称
-     * @return name:pro_info@price type:string default:-- desc:藏品价格
-     * @return name:pro_info@price type:string default:-- desc:藏品单价
-     * @return name:pro_info@auth_img type:string default:-- desc:藏品作者头像
-     * @return name:pro_info@auth_name type:string default:-- desc:藏品作者名称
-     */
-    public function getMySendListDetail(){
-        $order_id = input('order_id');   //订单id
-        if (!$order_id) $this->error('参数错误');
-        $order = Db::name('store_order_info')
-            ->where('id',$order_id)
-            ->where('mid',$this->uid)
-            ->find();
-        if (!$order) $this->error('订单不存在');
-        $order['pro_info'] = json_decode($order['pro_info'],true);
-        $order['send_name'] = Db::name('store_member')->where('id',$order['to_mid'])->value('name');
-        $this->success('成功',$order);
-    }
-
-
-
-
-
-
-
-
-    function savetest($order_no){
-
-        $result['out_trade_no'] = $order_no;
-        $order = Db::name('store_order')->where('order_no',$result['out_trade_no'])->find();
-        if ($order['status']==0){
-            Db::startTrans();
-            try {
-                Db::name('store_order')
-                    ->where('order_no',$result['out_trade_no'])
-                    ->update(['status'=>1,'pay_at'=>date('Y-m-d H:i:s'),'return_success_info'=>json_encode($result,true)]);
-
-                $array = [];
-                for ($i=0;$i<$order['num'];$i++){
-                    //获取排名
-                    $rank = getRanking($order['c_id'])+1;
-                    $tag = getTag($order['c_id'],$rank,$order['inventory']);
-                    saveRanking($order['c_id']);
-                    $company = '象寻数字科技(上海)有限公司';
-                    $company_hash = '';
-                    $company_hash_time = '';
-                    $collectors_hash = '';
-                    $date = [
-                        'order_id'=>$order['id'],
-                        'order_no'=>get_order_sn(),
-                        'tag'=>$tag,
-                        'mid'=>$order['mid'],
-                        'pro_info'=>$order['pro_info'],
-                        'company'=>$company,
-                        'company_hash'=>$company_hash,
-                        'company_hash_time'=>$company_hash_time,
-                        'collectors_hash'=>$collectors_hash,
-                        'collectors_hash_time'=>date('Y-m-d H:i:s')
-                    ];
-                    $array[] = $date;
-                }
-                Db::name('store_order_info')->insertAll($array);
-                Db::commit();
-                // return true;
-            } catch (\Exception $e){
-                Db::rollback();
-                //return false;
-            }
-        }
-    }
-
-
-
-}

+ 0 - 502
application/api/controller/Pay.php

@@ -1,502 +0,0 @@
-<?php
-
-// +----------------------------------------------------------------------
-// | ThinkAdmin
-// +----------------------------------------------------------------------
-// | 版权所有 2014~2019 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
-// +----------------------------------------------------------------------
-// | 官方网站: http://demo.thinkadmin.top
-// +----------------------------------------------------------------------
-// | 开源协议 ( https://mit-license.org )
-// +----------------------------------------------------------------------
-// | gitee 代码仓库:https://gitee.com/zoujingli/ThinkAdmin
-// | github 代码仓库:https://github.com/zoujingli/ThinkAdmin
-// +----------------------------------------------------------------------
-
-namespace app\api\controller;
-use app\common\library\AliPay3;
-use think\cache\driver\Redis;
-use EasyWeChat\Factory;
-use think\Controller;
-use think\Db;
-use think\Exception;
-
-
-use AlibabaCloud\Client\AlibabaCloud;
-use AlibabaCloud\Client\Exception\ClientException;
-use AlibabaCloud\Client\Exception\ServerException;
-use function AlibabaCloud\Client\value;
-
-/**
- * 支付管理类
- * Class Refund
- * @package app\api\controller\Refund
- */
-class Pay extends Controller
-{
-
-
-
-    public function test(){
-        $data = "{\"memberid\":220431411,\"orderid\":\"220431411OR29DAEDEEACBBF11820220602161239\",\"amount\":\"0.1000\",\"successdate\":\"2022-06-02 16:13:24\",\"bankcode\":\"953\",\"status\":\"success\",\"attach\":\"100000\",\"buyer_id\":\"2088012861214283\",\"out_trade_id\":\"202206021612394516457329\",\"notifydate\":\"2022-06-02 16:13:24\",\"num\":1,\"sign\":\"BC0568D0BA0E38DCB3246790C31570BA\"}";
-        $result= json_decode($data,true);
-        if ($result['status'] == 'success') {
-            $result['out_trade_no'] = $result['out_trade_id'];
-            $return = $this->dealData($result);
-            echo $return;
-        }
-    }
-    /**
-     * 微信支付--商品支付成功回调订单
-     */
-    public function WxOrderNotify(){
-        $payXml = file_get_contents("php://input");
-        //将xml格式转化为json格式
-        $jsonXml = json_encode(simplexml_load_string($payXml, 'SimpleXMLElement', LIBXML_NOCDATA));
-        //将json格式转成数组格式 $result['out_trade_no']
-        $result = json_decode($jsonXml, true);
-        file_put_contents("wx_pay_return.txt", json_encode($result) . "\n" . "\n", FILE_APPEND);
-        if ($result['return_code'] == 'SUCCESS' && $result['result_code'] == 'SUCCESS') {
-            $return = $this->dealData($result);
-            if ($return){
-                $arr = array(
-                    'return_code' => 'SUCCESS',
-                    'return_msg'  => 'OK',
-                );
-                return $this->arrayToXml($arr);
-            }else{
-                file_put_contents("order_pay_error.txt", file_get_contents("php://input") . "\n" . json_encode($result) . "\n" . "\n", FILE_APPEND);
-            }
-        }
-    }
-
-//    /**
-//     * 支付宝支付--支付成功回调订单
-//     */
-//    public function alipayOrderNotify(){
-//        $result    = input('post.');
-//        file_put_contents("zfb_pay_return.txt", json_encode($result) . "\n" . "\n", FILE_APPEND);
-//        if ($result['trade_status'] == 'TRADE_SUCCESS' || $result['trade_status'] == 'TRADE_FINISHED') {
-//            $return = $this->dealData($result);
-//            if ($return){
-//                echo 'success';
-//            }else{
-//                file_put_contents("order_alipay_error.txt", file_get_contents("php://input") . "\n" . json_encode($result) . "\n" . "\n", FILE_APPEND);
-//            }
-//        }
-//    }
-
-    /**
-     * 支付宝支付--支付成功回调订单
-     */
-    public function alipayOrderNotify(){
-        $results    = input('post.');
-        $zfb = new AliPay3();
-        $result= json_decode($zfb->sslDeReturn($results['notifyData']),true);
-        file_put_contents("zfb_pay_return.txt", json_encode($result,true) . "\n" . "\n", FILE_APPEND);
-        if ($result['status'] == 'success')
-        {
-            $result['out_trade_no'] = $result['out_trade_id'];
-            $return = $this->dealData($result);
-            if ($return){
-                echo 'success';
-            }else{
-                file_put_contents("order_alipay_error.txt", file_get_contents("php://input") . "\n" . json_encode($result) . "\n" . "\n", FILE_APPEND);
-            }
-        }
-    }
-
-    /**
-     * 汇聚支付支付宝h5,银联h5
-     */
-    public function ylOrderNotify(){
-        $result  = input();
-        debug($result);
-        if ($result['r6_Status'] == '100'){
-            $result['out_trade_no'] = $result['r2_OrderNo'];
-            $result['attach'] = $result['r5_Mp'];
-            $return = $this->dealData($result);
-            if ($return){
-                echo 'success';
-            }else{
-                file_put_contents("order_alipay_error.txt", json_encode($result) . "\n" . "\n", FILE_APPEND);
-            }
-        }
-    }
-
-
-    /**
-     * 处理数据库信息
-     * @param $result
-     * @return bool
-     */
-    function dealData($result){
-        Db::startTrans();
-        $redis = new Redis();
-        $key = 'order_not_pay_'.$result['attach'];
-        $com = true;
-        try {
-            $order = $redis->hGet($key,$result['out_trade_no']);
-            if (!$order) return false;
-            $order = json_decode($order,true);
-            $is_order = Db::name('store_order')->where('order_no',$result['out_trade_no'])->find();
-            if (isset($is_order) && $is_order['status']==1) return false;
-
-            $order['status'] = 1;
-            $order['pay_at'] = date('Y-m-d H:i:s');
-            $order['return_success_info'] = json_encode($result,true);
-            $order_id = Db::name('store_order')->insertGetId($order);
-
-            $array = [];
-            $pro_info = json_decode($order['pro_info'],true);
-            $is_nft = Db::name('hash2')->where('goods_id',$order['c_id'])->where('success',1)->find();
-            for ($i=0;$i<$order['num'];$i++){
-                //获取排名
-                $rank = getRanking($order['c_id'])+1;
-                $tag = getTag($order['c_id'],$rank,$order['inventory']);
-                saveRanking($order['c_id']);
-                $collectors_hash = '';
-                $date = [
-                    'order_id'=>$order_id,
-                    'order_no'=>get_order_sn(),
-                    'tag'=>$tag,
-                    'mid'=>$order['mid'],
-                    'c_id'=>$order['c_id'],
-                    'name'=>$pro_info['name'],
-                    'cover'=>$pro_info['cover'],
-                    'pro_info'=>$order['pro_info'],
-                    'type'=>$pro_info['type'],
-                    'tokenid'=>$is_nft['class_id'],
-                    'nfttype'=>$is_nft['operationId'],
-                    'collectors_hash'=>$collectors_hash
-                ];
-                $array[] = $date;
-            }
-            Db::name('store_order_info')->insertAll($array);
-            //送积分
-//            $by_collection_integral = getConfigValue('by_collection_integral');
-//            if ($by_collection_integral){
-//                $by_collection_integral = bcmul($by_collection_integral,$order['num']);
-//                memberMoneyChange($by_collection_integral,1,$order['mid'],'购买藏品',1,$order['id']);
-//            }
-            Db::commit();
-        } catch (\Exception $e){
-            $com = false;
-            Db::rollback();
-        }
-        if ($com){
-            $redis->hdel($key,$result['out_trade_no']);
-            return true;
-        }else{
-            return false;
-        }
-    }
-
-
-    /**
-     * 微信支付--充值盲盒成功回调订单
-     */
-    public function BlindRechargeNotify(){
-        $payXml = file_get_contents("php://input");
-        //将xml格式转化为json格式
-        $jsonXml = json_encode(simplexml_load_string($payXml, 'SimpleXMLElement', LIBXML_NOCDATA));
-        //将json格式转成数组格式 $result['out_trade_no']
-        $result = json_decode($jsonXml, true);
-        if ($result['return_code'] == 'SUCCESS' && $result['result_code'] == 'SUCCESS') {
-            $return = $this->dealBox($result);
-            if ($return){
-                $arr = array(
-                    'return_code' => 'SUCCESS',
-                    'return_msg'  => 'OK',
-                );
-                return $this->arrayToXml($arr);
-            }else{
-                file_put_contents("order_pay_error.txt", file_get_contents("php://input") . "\n" . json_encode($result) . "\n" . "\n", FILE_APPEND);
-            }
-        }
-    }
-
-    /**
-     * 支付宝支付--充值盲盒回调订单
-     */
-    public function alipayBlindRechargeNotify(){
-        $result    = input('post.');
-        if ($result['trade_status'] == 'TRADE_SUCCESS' || $result['trade_status'] == 'TRADE_FINISHED') {
-            $return = $this->dealBox($result);
-            if ($return){
-                echo 'success';
-            }else{
-                file_put_contents("order_alipay_error.txt", file_get_contents("php://input") . "\n" . json_encode($result) . "\n" . "\n", FILE_APPEND);
-            }
-        }
-    }
-
-
-    /**
-     * 盲盒充值次数处理数据库信息
-     * @param $result
-     * @return bool
-     */
-    function dealBox($result){
-        $com = true;
-        Db::startTrans();
-        try {
-            $order = Db::name('store_blind_recharge')->where('order_no',$result['out_trade_no'])->find();
-            if ($order['status']==1) return true;
-            Db::name('store_blind_recharge')
-                ->where('order_no',$result['out_trade_no'])
-                ->update(['status'=>1,'pay_at'=>date('Y-m-d H:i:s'),'return_success_info'=>json_encode($result,true)]);
-            //用户加次数
-            Db::name('store_member')->where('id',$order['m_id'])->setInc('lottery_number',$order['num']);
-            Db::commit();
-        } catch (\Exception $e){
-            $com = false;
-            Db::rollback();
-        }
-        if ($com){
-            setMemberInfoHash($order['m_id']);
-            return true;
-        }else{
-            return false;
-        }
-    }
-
-
-
-
-
-
-    /**
-     * 微信支付--二级市场回调订单
-     */
-    public function SecondaryWxOrderNotify(){
-        $payXml = file_get_contents("php://input");
-        //将xml格式转化为json格式
-        $jsonXml = json_encode(simplexml_load_string($payXml, 'SimpleXMLElement', LIBXML_NOCDATA));
-        //将json格式转成数组格式 $result['out_trade_no']
-        $result = json_decode($jsonXml, true);
-        if ($result['return_code'] == 'SUCCESS' && $result['result_code'] == 'SUCCESS') {
-            $return = $this->dealSecondary($result);
-            if ($return){
-                $arr = array(
-                    'return_code' => 'SUCCESS',
-                    'return_msg'  => 'OK',
-                );
-                return $this->arrayToXml($arr);
-            }else{
-                file_put_contents("order_pay_error.txt", file_get_contents("php://input") . "\n" . json_encode($result) . "\n" . "\n", FILE_APPEND);
-            }
-        }
-    }
-
-    /**
-     * 支付宝支付--二级市场回调订单
-     */
-    public function alipaySecondaryNotify(){
-        $results    = input('post.');
-        $zfb = new AliPay3();
-        $result= json_decode($zfb->sslDeReturn($results['notifyData']),true);
-        file_put_contents("zfbse_pay_return.txt", json_encode($result) . "\n" . "\n", FILE_APPEND);
-        if ($result['status'] == 'success') {
-            $result['out_trade_no'] = $result['out_trade_id'];
-            $return = $this->dealSecondary($result);
-            if ($return){
-                echo 'success';
-            }else{
-                file_put_contents("order_alipay_error.txt", file_get_contents("php://input") . "\n" . json_encode($result) . "\n" . "\n", FILE_APPEND);
-            }
-        }
-    }
-
-    /**
-     * 杉德支付--二级市场回调订单
-     */
-    public function shandeSecondaryNotify(){
-        $data   = stripslashes($_POST['data']); //支付数据
-        file_put_contents("shandepay.txt", $data . "\n" , FILE_APPEND);
-        $data = json_decode($data,true);
-        if ($data['body']['orderStatus']==1){
-            //$data['body']['orderCode']
-            $return = $this->dealSecondary($data,'sd');
-            if ($return){
-                return 'respCode=000000';
-            }else{
-                file_put_contents("shandepay_error.txt", $data . "\n" . json_encode($data) . "\n" . "\n", FILE_APPEND);
-            }
-        }
-    }
-
-
-    /**
-     * 二级市场-汇聚支付支付宝h5,银联h5
-     */
-    public function ylSecondaryNotify(){
-        $result  = input();
-        debug($result);
-        if ($result['r6_Status'] == '100'){
-            $return = $this->dealSecondary($result,'huijuh5');
-            if ($return){
-                echo 'success';
-            }else{
-                file_put_contents("order_error.txt", json_encode($result) . "\n" . "\n", FILE_APPEND);
-            }
-        }
-    }
-
-    /**
-     * 二级市场处理数据库信息
-     * @param $result
-     * @return bool
-     */
-    function dealSecondary($result,$from=''){
-        $com = true;
-        Db::startTrans();
-        try {
-            if ($from=='sd'){
-                $out_trade_no = $result['body']['orderCode'];
-            }elseif ($from=='sd'){
-                $out_trade_no = $result['out_trade_no'];
-            } elseif($from=='huijuh5'){
-                $out_trade_no = $result['r2_OrderNo'];;
-            }
-            $order = Db::name('store_order_info_order')->where('order_no',$out_trade_no)->find();
-            if ($order['status']==1) return false;
-
-            if (!$order) return false;
-
-            $resale_status = Db::name('store_order_info')->where('id',$order['info_id'])->value('resale_status');
-            if ($resale_status!=2){
-
-            }else{
-                Db::name('store_order_info_order')
-                    ->where('order_no',$out_trade_no)
-                    ->update(['status'=>1,'pay_at'=>date('Y-m-d H:i:s'),'return_success_info'=>json_encode($result,true)]);
-                //藏品修改状态
-                Db::name('store_order_info')->where('id',$order['info_id'])->update([
-                    'status'=>2,
-                    'resale_status'=>3,
-                    'selling_time'=>date('Y-m-d H:i:s')
-                ]);
-                $info = Db::name('store_order_info')->where('id',$order['info_id'])->find();
-                //增加一条记录
-                $to_date = [
-                    'order_id'=>$info['order_id'],
-                    'order_no'=>get_order_sn(),
-                    'tag'=>$info['tag'],
-                    'mid'=>$order['mid'],
-                    'c_id'=>$info['c_id'],
-                    'name'=>$info['name'],
-                    'cover'=>$info['cover'],
-                    'pro_info'=>$info['pro_info'],
-                    'type'=>$info['type'],
-                    'status'=>3,
-                    'from'=>2,
-                    'to_mid'=>$info['mid'],
-                    'over_time'=>date('Y-m-d H:i:s'),
-                    'tokenid'=>$info['tokenid'],
-                    'nfttype'=>$info['nfttype'],
-                    'collectors_hash'=>'',
-                    'collectors_hash_time'=>date('Y-m-d H:i:s')
-                ];
-                Db::name('store_order_info')->insert($to_date);
-                //增加用户余额
-                memberMoneyChange($order['to_account'],3,$info['mid'],'出售藏品',1,$order['id']);
-                Db::commit();
-            }
-        } catch (\Exception $e){
-            $com = false;
-            Db::rollback();
-        }
-        if ($com){
-            setMemberInfoHash($order['mid']);
-            return true;
-        }else{
-            return false;
-        }
-    }
-
-
-
-
-    /**
-     * 余额充值--汇聚云闪付,支付宝h5支付回调
-     */
-    public function ylrechargeNotify(){
-        $result  = input();
-        debug($result);
-        if ($result['r6_Status'] == '100'){
-            $return = $this->dealRecharge($result,'huijuh5');
-            if ($return){
-                echo 'success';
-            }else{
-                file_put_contents("recharge_error.txt", json_encode($result) . "\n" . "\n", FILE_APPEND);
-            }
-        }
-    }
-
-
-    //处理充值
-    function dealRecharge($result,$from=''){
-        $com = true;
-        Db::startTrans();
-        try {
-            if($from=='huijuh5'){
-                $out_trade_no = $result['r2_OrderNo'];;
-            }
-            $order = Db::name('store_member_recharge')->where('order_no',$out_trade_no)->find();
-            if (!$order || $order['status']==1) return false;
-
-            //增加用户余额
-            $re = memberMoneyChange($order['pay_price'],3,$order['m_id'],'余额充值',1,$order['id']);
-            if ($re){
-                Db::name('store_member_recharge')
-                    ->where('order_no',$out_trade_no)
-                    ->update(['status'=>1,'pay_at'=>date('Y-m-d H:i:s'),'return_success_info'=>json_encode($result,true)]);
-                Db::commit();
-            }else{
-                $com = false;
-                Db::rollback();
-            }
-
-        } catch (\Exception $e){
-            $com = false;
-            Db::rollback();
-        }
-        if ($com){
-            setMemberInfoHash($order['m_id']);
-            return true;
-        }else{
-            return false;
-        }
-    }
-
-
-
-
-
-
-
-
-
-
-
-    /**
-     * 数组转xml
-     * @ApiInternal
-     */
-    public function arrayToXml($arr)
-    {
-        $xml = "<xml>";
-        foreach ($arr as $key => $val) {
-            if (is_numeric($val)) {
-                $xml .= "<" . $key . ">" . $val . "</" . $key . ">";
-            } else
-                $xml .= "<" . $key . "><![CDATA[" . $val . "]]></" . $key . ">";
-        }
-        $xml .= "</xml>";
-        return $xml;
-    }
-
-
-
-}

+ 0 - 153
application/api/controller/Publics.php

@@ -1,153 +0,0 @@
-<?php
-
-namespace app\api\controller;
-
-use think\cache\driver\Redis;
-use think\Db;
-use think\facade\Validate;
-use think\Request;
-use OSS\OssClient;
-use OSS\Core\OssException;
-use Zxing\Qrcode\Decoder\DataBlock;
-
-/**
- * @title 公共类
- * @controller Publics
- */
-class Publics extends Base
-{
-    /**
-     * @title 上传图片
-     * @desc 上传图片
-     * @url /api/Publics/uploadLocality
-     * @method POST
-     * @tag 基础
-     *
-     * @param  name:file type:file require:1 desc:上传
-     * @return name:data@url type:string desc:图片地址
-     **/
-    public function uploadLocality(){
-        $file = request()->file('file');
-        $dir = dirname(realpath(dirname($_SERVER['SCRIPT_FILENAME']))) . '/public/upload';
-        if(!file_exists($dir)){
-            //检查是否有该文件夹,如果没有就创建,并给予最高权限
-            mkdir($dir, 0777,true);
-        }
-        $ossClient = new OssClient(getConfigValue('storage_oss_keyid'), getConfigValue('storage_oss_secret'), getConfigValue('storage_oss_endpoint'));
-        $info = $file->move($dir);
-        if($info){
-            $newName = $info->getSaveName();
-            $storage_type = getConfigValue('storage_type');
-            if ($storage_type == 'oss'){
-                $file_path = dirname($_SERVER['SCRIPT_FILENAME']) . "/upload/".$newName;
-                $result = $ossClient->uploadFile(getConfigValue('storage_oss_bucket'), $newName, $file_path);
-                $data['url'] =  $result['info']['url'];
-                unlink($file_path);
-            }elseif ($storage_type=='local'){
-                //压缩图片
-                //image_png_size_add(ROOT_PATH . 'public' . DS . 'uploads/images/'.$newName,ROOT_PATH . 'public' . DS . 'uploads/images/'.$newName);
-                $data['url'] =  'http://'.$_SERVER['SERVER_NAME']."/upload/{$newName}";
-            }
-        }else{
-            $this->error($file->getError());
-        }
-        $this->success('上传成功',$data);
-    }
-
-
-    /**
-     * @title 获取系统配置
-     * @desc 获取系统配置
-     * @url /api/Publics/config_info
-     * @method POST
-     * @tag 基础
-     *
-     * @return name:agreement type:string desc:使用条款
-     * @return name:privacy type:string desc:隐私协议
-     * @return name:platform_agreement type:string desc:违规处罚
-     * @return name:about_us type:string desc:关于我们
-     * @return name:registration_agreement type:string desc:用户注册协议
-     * @return name:terms_service type:string desc:联通统一认证服务条款
-     * @return name:chain_on_query type:string desc:链上查询
-     * @return name:examples_illustrate type:string desc:转赠说明
-     * @return name:android_version type:string desc:安卓当前版本号
-     * @return name:android_package type:string desc:安卓包地址
-     * @return name:ios_package type:string desc:ios地址
-     **/
-    public function config_info(){
-        $nameArray = [
-            'agreement',
-            'privacy',
-            'platform_agreement',
-            'about_us',
-            'registration_agreement',
-            'terms_service',
-            'chain_on_query',
-            'examples_illustrate',
-            'android_version',
-            'android_package',
-            'ios_package',
-            'free_lucky_number',
-            'lucky_recharge_price',
-            'service_fee',
-            'royalties',
-            'consignment',
-            'statement',
-            'invitation_background_img',
-            'share_background_img',
-            'new_instructions',
-            'share_switch'
-        ];
-        $array = getConfig($nameArray);
-        $this->success('成功',$array);
-    }
-
-
-    /**
-     * @title 获取分享的签名
-     * @desc 获取分享的签名
-     * @url /api/Publics/getWechatSign
-     * @method POST
-     * @tag 基础
-     *
-     **/
-    public function getWechatSign(){
-        $urls = input('url');
-        $appid = getConfigValue('wechat_appid');
-        $secret = getConfigValue('wechat_appsecret');
-
-        $redis = new Redis();
-        $access_token = $redis->get('access_token');
-        if (!$access_token){
-            $access_token = '';
-            $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$appid&secret=$secret";
-            $res=curlRequest($url);
-            $res = json_decode($res,true);
-            if (isset($res['access_token'])){
-                $redis->set('access_token',$res['access_token'],'7000');
-                $access_token = $res['access_token'];
-            }
-        }
-        $url2 ="https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=".$access_token."&type=jsapi";
-        $res2=curlRequest($url2);
-
-        $res2 = json_decode($res2,true);
-        if (!isset($res2) || $res2['errcode']!=0){
-            $this->error('获取ticket失败');
-        }
-        $timestamp = time();
-        $noncestr = get32Str(15);
-//        $urls = 'http://jybl.hdlkeji.com/web/h5/';
-        $string = "jsapi_ticket=".$res2['ticket']."&noncestr=$noncestr&timestamp=$timestamp&url=".$urls;
-        $sign = sha1($string);
-        $return = [
-            'appid'=>$appid,
-            'noncestr'=>$noncestr,
-            'timestamp'=>$timestamp,
-            'url'=>$urls,
-            'sign'=>$sign,
-            'ticket'=>$res2['ticket']
-        ];
-        $this->success('成功',$return);
-    }
-}

+ 0 - 103
application/api/controller/Recharge.php

@@ -1,103 +0,0 @@
-<?php
-namespace app\api\controller;
-use AlibabaCloud\Client\AlibabaCloud;
-use AlibabaCloud\Client\Exception\ClientException;
-use AlibabaCloud\Client\Exception\ServerException;
-use app\common\library\AliPay2;
-use app\common\library\HuijuH5Pay;
-use think\cache\driver\Redis;
-use think\Db;
-/**
- * @title 充值余额
- * @controller UserCenter
- * @group base
- */
-class Recharge extends Base
-{
-    public function initialize()
-    {
-        parent::initialize();
-        parent::check_login();
-    }
-
-    /**
-     * @title 余额充值
-     * @desc 余额充值
-     * @author Gavin
-     * @url /api/Recharge/recharge
-     * @method POST
-     * @tag 余额充值
-     * @header name:Authorization require:1 desc:Token
-     * @param  name:price type:string  : default: desc:充值金额
-     * @param  name:pay_type type:string require:1 default:wx desc:wx:微信zfb:支付宝
-     */
-    public function recharge()
-    {
-        //redis原子锁
-        if (redisSetNx('recharge'.$this->uid,2)){
-
-            $v = getConfigValue('recharge_switch');
-            if (!$v) $this->error('维护中,暂时关闭');
-
-            $price = input('price');
-            $pay_type = input('pay_type');
-            if (!$price || !$pay_type) $this->error('参数错误');
-            if (!isAmount($price)) $this->error('金额错误');
-            $order_no = get_order_sn();
-            $data = [
-                'order_no'=>$order_no,
-                'm_id'=>$this->uid,
-                'price'=>$price,
-                'pay_price'=>$price,
-                'pay_type'=>$pay_type
-            ];
-            if (Db::name('store_member_recharge')->insert($data)){
-                $com = true;
-                switch ($pay_type){
-                    case 'ylh5':
-                        $callback_url = 'https://'.$_SERVER['SERVER_NAME'].'/pages/mine/qianbao';
-                        $huiju = new HuijuH5Pay();
-                        $notify_url = 'https://'.$_SERVER['SERVER_NAME'].'/index.php/api/Pay/ylrechargeNotify';//回调地址
-                        $result = $huiju->ylh5Pay($order_no,$callback_url,$notify_url,'余额充值',$price,$this->uid,2);
-                        if ($result['ra_Code']=='100'){
-                            $retrun_data['order_no'] = $order_no;
-                            $retrun_data['pay'] = $result['rc_Result'];
-                        }else{
-                            $com = false;
-                        }
-                        break;
-                    case 'zfbh5':
-                        $callback_url = 'https://'.$_SERVER['SERVER_NAME'].'/pages/mine/qianbao';
-                        $huiju = new HuijuH5Pay();
-                        $notify_url = 'https://'.$_SERVER['SERVER_NAME'].'/index.php/api/Pay/ylrechargeNotify';//回调地址
-                        $result = $huiju->ylh5Pay($order_no,$callback_url,$notify_url,'余额充值',$price,$this->uid,1);
-                        if ($result['ra_Code']=='100'){
-                            $retrun_data['order_no'] = $order_no;
-                            $retrun_data['pay'] = $result['rc_Result'];
-                        }else{
-                            $com = false;
-                        }
-                        break;
-                    default:
-                        $com = false;
-                        break;
-                }
-                if ($com){
-                    $this->success('成功',$retrun_data);
-                }else{
-                    $this->error('调起支付失败,请稍后重试');
-                }
-            }else{
-                $this->error('失败,请稍后重试');
-            }
-        }else{
-            $this->error('请求过快');
-        }
-    }
-
-
-
-
-
-
-}

+ 0 - 850
application/api/controller/Secondary.php

@@ -1,850 +0,0 @@
-<?php
-
-
-namespace app\api\controller;
-
-use Alipay\EasySDK\Kernel\Util\ResponseChecker;
-use app\common\library\AliPay;
-use app\common\library\AliPay3;
-use app\common\library\HuijuH5Pay;
-use app\common\library\Shande;
-use EasyWeChat\Factory;
-use think\cache\driver\Redis;
-use think\Db;
-use function EasyWeChat\Kernel\Support\get_client_ip;
-use function Symfony\Component\String\length;
-
-
-/**
- * @title 二级市场
- * @controller secondary
- * @package app\api\controller
- */
-class Secondary extends Base
-{
-
-    public function initialize(){
-        parent::initialize();
-        parent::check_login();
-    }
-
-    /**
-     * @title 藏品出售
-     * @desc  藏品出售
-     * @author  Gavin
-     * @url /api/Secondary/sell
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param name:id type:int require:1 default:1 desc:藏品ID
-     * @param name:resale_price type:decimal require:1 default:1 desc:出售价格
-     * @param name:second_password type:int require:1 default:-- desc:二级密码
-     *
-     */
-    public function sell(){
-        $this->checkSwitch(1);
-        $id = input('id');
-        $user = getMemberInfoHash($this->uid); //获取用户信息
-        if ($user['is_auth']==0) $this->error('请先实名认证!');
-        $resale_price = input('resale_price');
-        $second_password = input('second_password');
-        if (!$id || !$resale_price) $this->error('参数错误');
-        //if ($resale_price<'1') $this->error('最低1元');
-        if ($resale_price<'0.1') $this->error('最低0.1元');
-        if ($resale_price>'99999') $this->error('最高99999元');
-        $info = Db::name('store_order_info')
-            ->where('mid',$this->uid)
-            ->where('id',$id)
-            ->find();
-        if (!$info || $info['status']==2) $this->error('藏品不存在');
-        if ($info['resale_status']!=1) $this->error('挂售状态错误');
-
-        $is_sell = Db::name('store_collection')->where('id',$info['c_id'])->value('is_sell');
-        if (!$is_sell) $this->error('该藏品不支持寄售');
-
-        if ($user['second_password']!=md5($second_password)) $this->error('密码错误');
-        $update_data = [
-            'resale_status'=>2,
-            'resale_time'=>date('Y-m-d H:i:s'),
-            'resale_price'=>$resale_price
-        ];
-        if (Db::name('store_order_info')->where('id',$id)->update($update_data)){
-            $this->success('成功');
-        }
-        $this->error('失败');
-    }
-
-    /**
-     * @title 藏品取消出售
-     * @desc  藏品取消出售
-     * @author  Gavin
-     * @url /api/Secondary/cancel_sell
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param name:id type:int require:1 default:1 desc:藏品ID
-     */
-    public function cancel_sell(){
-        $this->checkSwitch(1);
-        $id = input('id');
-        if (!$id) $this->error('参数错误');
-        $info = Db::name('store_order_info')
-            ->where('mid',$this->uid)
-            ->where('id',$id)
-            ->find();
-        if (!$info || $info['status']==2) $this->error('藏品不存在');
-        if ($info['resale_status']!=2) $this->error('挂售状态错误');
-        //判断是否有待支付订单
-        $count = Db::name('store_order_info_order')->where('info_id',$id)->where('status',0)->count();
-        if ($count) $this->error('支付中,无法取消');
-
-        $update_data = [
-            'resale_status'=>1,
-        ];
-        if (Db::name('store_order_info')->where('id',$id)->update($update_data)){
-            $this->success('成功');
-        }
-        $this->error('失败');
-    }
-
-
-    /**
-     * @title 标签列表
-     * @desc  标签列表
-     * @author  Gavin
-     * @url /api/Secondary/label_list
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     */
-    public function label_list(){
-        $list = Db::name('store_collection')->whereNotIn('label','测试,测试勿拍')->group('label')->column('label');
-        $list = array_merge(['全部'],$list);
-        $this->success('成功',['label_list'=>$list]);
-    }
-
-
-    /**
-     * @title 二级市场列表
-     * @desc  二级市场列表
-     * @author  Gavin
-     * @url /api/Secondary/sell_list
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param  name:page type:int  : default:1 desc:页数
-     * @param  name:page_num type:int  : default:20 desc:每页数
-     *
-     * @param name:keyword type:string require:0 default: desc:关键词
-     * @param name:label type:string require:0 default: desc:标签
-     * @param name:time_order type:string require:0 default: desc:时间排序(asc:正序desc:倒序)
-     * @param name:price_order type:string require:0 default: desc:价格排序(asc:正序desc:倒序)
-     *
-     * @return  name:name type:string require:0 default:0 desc:藏品名称
-     * @return  name:cover type:string require:0 default:0 desc:图片
-     * @return  name:member_name type:string require:0 default:0 desc:出售人名称
-     * @return  name:member_headimg type:string require:0 default:0 desc:出售人头像
-     * @return  name:resale_price type:string require:0 default:0 desc:出售价格
-     */
-    public function sell_list(){
-        $keyword = input('keyword');
-        $label = input('label');
-        $time_order = input('time_order');
-        $price_order = input('price_order');
-        $count = Db::name('store_order_info')
-            ->where('status','neq',2)
-            ->where('resale_status',2)
-            ->where('is_destruction',1)
-            ->when($keyword,function ($query) use ($keyword){
-                $query->whereLike('name','%'.$keyword.'%');
-            })
-            ->when($label,function ($query) use ($label){
-                if ($label!='全部'){
-                    $ids = Db::name('store_collection')->where('label',$label)->column('id');
-                    $query->whereIn('c_id',$ids);
-                }
-            })
-            ->count();
-        $list = Db::name('store_order_info')
-            ->where('status','neq',2)
-            ->where('resale_status',2)
-            ->where('is_destruction',1)
-            ->when($keyword,function ($query) use ($keyword){
-                $query->whereLike('name','%'.$keyword.'%');
-            })
-            ->when($label,function ($query) use ($label){
-                if ($label!='全部'){
-                    $ids = Db::name('store_collection')->where('label',$label)->column('id');
-                    $query->whereIn('c_id',$ids);
-                }
-            })
-            ->when($price_order,function ($query) use ($price_order){
-                $query->order('resale_price '.$price_order);
-            })
-            ->when($time_order,function ($query) use ($time_order){
-                $query->order('resale_time '.$time_order);
-            })
-            ->limit($this->off_set,$this->page_num)
-            ->select();
-        foreach ($list as &$v){
-            $member = getMemberInfoHash($v['mid']); //获取用户信息
-            $v['member_name'] = $member['name'];
-            $v['member_headimg'] = $member['headimg'];
-            $v['pro_info'] = json_decode($v['pro_info'],true);
-            $count = Db::name('store_order_info_order')->where('info_id',$v['id'])->where('status',0)->count();
-            $v['is_buy'] = $count>0 ? 1 : 0;
-        }
-        $this->success('成功',compact('count','list'));
-    }
-
-
-    /**
-     * @title 二级市场详情
-     * @desc  二级市场详情
-     * @author  Gavin
-     * @url /api/Secondary/sell_list_detail
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param  name:id type:int  : default: desc:id
-     */
-    public function sell_list_detail(){
-        $id = input('id');
-        if (!$id) $this->error('参数错误');
-        $info = Db::name('store_order_info')
-            ->where('status','neq',2)
-            ->where('resale_status',2)
-            ->where('is_destruction',1)
-            ->where('id',$id)
-            ->find();
-        if (!$info) $this->error('藏品不存在');
-        $member = getMemberInfoHash($info['mid']); //获取用户信息
-        $info['member_name'] = $member['name'];
-        $info['member_headimg'] = $member['headimg'];
-        $info['pro_info'] = json_decode($info['pro_info'],true);
-        //判断是否有待支付订单
-        $count = Db::name('store_order_info_order')->where('info_id',$id)->where('status',0)->count();
-        $info['is_buy'] = $count>0 ? 1 : 0;
-        $this->success('成功',$info);
-    }
-
-
-
-    /**
-     * @title 购买
-     * @desc  购买
-     * @author  Gavin
-     * @url /api/Secondary/createOrder
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param name:id type:int require:1 default: desc:主键ID
-     * @param name:pay_type type:string require:1 default:wx desc:wx:微信zfb:支付宝sd:杉德h5
-     * @param name:from type:string require:1 default:wx desc:wx:微信公众号h5:网页
-     *
-     * @return  name:order_no type:int require:0 default:0 desc:订单号
-     * @return  name:pay type:string require:0 default:0 desc:支付信息
-     */
-    public function createOrder(){
-        $this->checkSwitch(3);
-        $redis = new Redis([ 'select'=> 2]);
-        $redis_value = $redis->get('secondary_buy'.$this->uid);
-        if ($redis_value){
-            $this->error('请求过快,请稍后重试');
-        }else{
-            $redis->set('secondary_buy'.$this->uid,1,1);
-        }
-
-        $id = input('id');
-        $pay_type = input('pay_type','wx');
-
-        $this->checkSwitch(2,$pay_type);
-
-        $from = input('from','wx');
-        $user = getMemberInfoHash($this->uid); //获取用户信息
-        if (!$id) $this->error('参数错误');
-        if ($user['is_auth']==0) $this->error('请先实名认证!');
-        $info = Db::name('store_order_info')->where('id',$id)->find();
-        if (!$info) $this->error('藏品不存在');
-        if ($info['resale_status']==3) $this->error('藏品已出售');
-        if ($info['resale_status']==1) $this->error('藏品已撤销出售');
-        if ($info['mid']==$this->uid) $this->error('不能购买自己出售的藏品');
-
-       // if (isset($user['buy_time']) && $user['buy_time']>date('Y-m-d H:i:s')) $this->error('一小时取消3次以上,24小时内禁止下单');
-
-        //判断是否有未支付订单
-        $order_count = Db::name('store_order_info_order')->where('mid',$this->uid)->where('status',0)->count();
-        if ($order_count) $this->error('有未支付订单,无法下单');
-
-        //判断是否有待支付订单
-        $count = Db::name('store_order_info_order')->where('info_id',$id)->where('status',0)->count();
-        if ($count) $this->error('支付中,无法下单');
-
-        $service_fee = getConfigValue('service_fee');
-        $royalties = getConfigValue('royalties');
-        $com = true;
-        Db::startTrans();
-        try {
-            $order_no = get_order_sn();
-            //获取价格
-            $price = $info['resale_price'];
-            $num = 1;
-            $proportion = sprintf("%.2f",$price *($service_fee/100));    //四舍五入保留两位小数点
-            $roya = sprintf("%.2f",$price *($royalties/100));    //四舍五入保留两位小数点
-            $total_fee = bcmul($price,$num,2);
-            $real_money = $price-$proportion-$roya;
-            $data = [
-                'order_no'=>$order_no,
-                'mid'=>$this->uid,
-                'info_id'=>$id,
-                'num'=>$num,
-                'pro_info'=>json_encode($info,true),
-                'pay_price'=>$total_fee,
-                'service_fee'=>$service_fee,
-                'royalties'=>$royalties,
-                'to_account'=>$real_money,
-                'pay_type'=>$pay_type
-            ];
-            $id = Db::name('store_order_info_order')->insertGetId($data);
-
-            $retrun_data['order_no'] = $order_no;
-            $retrun_data['id'] = $id;
-            $retrun_data['pay'] = '';
-            Db::commit();
-//            $body = 'top艺术购买二级市场藏品';
-//            switch ($pay_type){
-//                case 'wx':
-//                    $config = retrunWxConfig();
-//                    $total_fee = $total_fee * 100;
-//                    $config['notify_url'] = 'https://'.$_SERVER['SERVER_NAME'].'/api/Pay/SecondaryWxOrderNotify';
-//                    $app = Factory::payment($config);
-//
-//                    $post_data = [
-//                        'body' => $body,
-//                        'out_trade_no' => $order_no,
-//                        'total_fee' => $total_fee,
-//                        'attach'=>$this->uid,     //自定义传值
-//                    ];
-//                    //trade_type   SAPI--JSAPI支付(或小程序支付)、NATIVE--Native支付、APP--app支付,MWEB--H5支付
-//                    if ($from=='wx'){
-//                        $post_data['openid'] = $user['openid'];
-//                        $post_data['trade_type'] = 'JSAPI';
-//                    }elseif ($from=='h5'){
-//                        $post_data['trade_type'] = 'MWEB';
-//                    }
-//                    $result = $app->order->unify($post_data);
-//
-//                    if ($result['return_msg']=='OK'){
-//                        if ($result['result_code']=='FAIL'){
-//                            $com = false;
-//                            Db::rollback();
-//                        }else{
-//                            $order1 = $app->jssdk->bridgeConfig($result['prepay_id']);//执行二次签名返回参数
-//                            $retrun_data['order_no'] = $order_no;
-//                            $retrun_data['id'] = $id;
-//                            $retrun_data['pay'] = json_decode($order1,true);
-//                            Db::commit();
-//                        }
-//                    }else{
-//                        $com = false;
-//                        Db::rollback();
-//                    }
-//                    break;
-//                case 'zfb':
-//
-//                    $zfb = new AliPay3();
-//                    $notify_url = $this->request->root(true).'/index.php/api/Pay/alipaySecondaryNotify';//回调地址
-//                    $callback_url = 'https://'.$_SERVER['SERVER_NAME'].'/web/h5/pages/shop/order';
-//                    $order = $zfb->aliPay($body,$total_fee,$order_no,$notify_url,$this->uid,$callback_url);
-//                    $retrun_data['order_no'] = $order_no;
-//                    $retrun_data['id'] = $id;
-//                    $retrun_data['pay'] = $order['pay_url'];
-//                    Db::commit();
-//                    break;
-//                case 'sd':
-//                    $client = new Shande();
-//                    $notify_url = 'https://'.$_SERVER['SERVER_NAME'].'/index.php/api/Pay/shandeSecondaryNotify';//回调地址
-//                    $total_fee = $total_fee*100;
-//                    $lenth = strlen($total_fee);
-//                    $total_fee = get0number($lenth).$total_fee;
-//                    $result = $client->orderPay($order_no,$total_fee,$body,$notify_url,'https://'.$_SERVER['SERVER_NAME'].'/web/h5/pages/shop/order');
-//                    $retrun_data['order_no'] = $order_no;
-//                    $retrun_data['id'] = $id;
-//                    $retrun_data['pay'] = json_decode($result['data'],true);
-//                    Db::commit();
-//                    break;
-//                default:
-//                    $retrun_data['order_no'] = $order_no;
-//                    $retrun_data['id'] = $id;
-//                    $retrun_data['pay'] = '';
-//                    Db::commit();
-//                    break;
-//
-//            }
-        }catch (\Exception $e){
-            $com=false;
-            Db::rollback();
-        }
-        if ($com){
-            $this->success('成功',$retrun_data);
-        }
-        $this->error('失败,请稍后重试');
-    }
-
-
-        /**
-     * @title 二级市场我的转售列表
-     * @desc  二级市场我的转售列表
-     * @author  Gavin
-     * @url /api/Secondary/my_sell_list
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param  name:page type:int  : default:1 desc:页数
-     * @param  name:page_num type:int  : default:20 desc:每页数
-     *
-     * @param name:keyword type:string require:0 default: desc:关键词
-     * @param name:time_order type:string require:0 default: desc:时间排序(asc:正序desc:倒序)
-     * @param name:price_order type:string require:0 default: desc:价格排序(asc:正序desc:倒序)
-     *
-     * @return  name:name type:string require:0 default:0 desc:藏品名称
-     * @return  name:cover type:string require:0 default:0 desc:图片
-     * @return  name:member_name type:string require:0 default:0 desc:出售人名称
-     * @return  name:member_headimg type:string require:0 default:0 desc:出售人头像
-     * @return  name:resale_price type:string require:0 default:0 desc:出售价格
-     */
-    public function my_sell_list(){
-        $keyword = input('keyword');
-        $time_order = input('time_order');
-        $price_order = input('price_order');
-        $count = Db::name('store_order_info')
-            ->where('mid',$this->uid)
-            ->where('resale_status','neq',1)
-            ->when($keyword,function ($query) use ($keyword){
-                $query->whereLike('name','%'.$keyword.'%');
-            })
-            ->count();
-        $list = Db::name('store_order_info')
-            ->where('mid',$this->uid)
-            ->where('resale_status','neq',1)
-            ->when($keyword,function ($query) use ($keyword){
-                $query->whereLike('name','%'.$keyword.'%');
-            })
-
-            ->when($price_order,function ($query) use ($price_order){
-                $query->order('resale_price '.$price_order);
-            })
-            ->when($time_order,function ($query) use ($time_order){
-                $query->order('resale_time '.$time_order);
-            })
-            ->order('resale_status asc')
-            ->limit($this->off_set,$this->page_num)
-            ->select();
-        foreach ($list as &$v){
-            $member = getMemberInfoHash($v['mid']); //获取用户信息
-            $v['member_name'] = $member['name'];
-            $v['member_headimg'] = $member['headimg'];
-            $v['pro_info'] = json_decode($v['pro_info'],true);
-        }
-        $this->success('成功',compact('count','list'));
-    }
-
-
-
-
-
-    /**
-     * @title 二级市场订单
-     * @desc  二级市场订单
-     * @author  Gavin
-     * @url /api/Secondary/secondaryOrderList
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param  name:page type:int  : default:1 desc:页数
-     * @param  name:page_num type:int  : default:20 desc:每页数
-     *
-     * @param name:status type:string require:0 default: desc:0:待支付1:已购买2:转售中3:已转售
-     *
-     * @return  name:name type:string require:0 default:0 desc:藏品名称
-     * @return  name:cover type:string require:0 default:0 desc:图片
-     * @return  name:member_name type:string require:0 default:0 desc:出售人名称
-     * @return  name:member_headimg type:string require:0 default:0 desc:出售人头像
-     * @return  name:pay_price type:string require:0 default:0 desc:出售价格(已购买、待支付使用)
-     * @return  name:resale_price type:string require:0 default:0 desc:出售价格(转售中、已转售使用)
-     */
-    public function secondaryOrderList(){
-        $status = input('status',0);
-        switch ($status){
-            case 0:case 1:
-                $count =  Db::name('store_order_info_order')
-                    ->where('mid',$this->uid)
-                    ->where('status',$status)
-                    ->count();
-                $list = Db::name('store_order_info_order')
-                    ->where('mid',$this->uid)
-                    ->where('status',$status)
-                    ->limit($this->off_set,$this->page_num)
-                    ->select();
-                //自动取消分钟数
-                $cancel_time = getCancelTime();
-                foreach ($list as &$v){
-                    $v['pro_info'] = json_decode($v['pro_info'],true);
-                    $member = getMemberInfoHash($v['mid']); //获取用户信息
-                    $v['member_name'] = $member['name'];
-                    $v['member_headimg'] = $member['headimg'];
-
-                    if ($v['status']==0){
-                        $v['cancel_time'] = date('Y-m-d H:i:s',strtotime($v['create_at'])+($cancel_time*60));
-                    }
-                }
-                break;
-            case 2:case 3:
-                $count = Db::name('store_order_info')
-                    ->where('mid',$this->uid)
-                    ->where('resale_status',$status)
-                    ->where('is_destruction',1)
-                    ->count();
-                $list = Db::name('store_order_info')
-                    ->where('mid',$this->uid)
-                    ->where('resale_status',$status)
-                    ->where('is_destruction',1)
-                    ->limit($this->off_set,$this->page_num)
-                    ->select();
-                foreach ($list as &$v){
-                    $v['pro_info'] = json_decode($v['pro_info'],true);
-                    $member = getMemberInfoHash($v['mid']); //获取用户信息
-                    $v['member_name'] = $member['name'];
-                    $v['member_headimg'] = $member['headimg'];
-                }
-                break;
-        }
-        $this->success('成功',compact('count','list'));
-    }
-
-    /**
-     * @title 订单详情
-     * @desc  订单详情
-     * @author  Gavin
-     * @url /api/Secondary/orderDetail
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param name:status type:string require:0 default: desc:0:待支付1:已购买2:转售中3:已转售
-     * @param  name:order_no type:string default:0 desc:订单号
-     */
-    public function orderDetail(){
-        $order_no = input('order_no');
-        $status = input('status',0);
-        if (!$order_no) $this->error('参数错误');
-        switch ($status){
-            case 0:case 1:
-                 $order = Db::name('store_order_info_order')
-                    ->where('mid',$this->uid)
-                    ->where('status',$status)
-                    ->where('order_no',$order_no)
-                    ->find();
-                //自动取消分钟数
-                $cancel_time = getCancelTime();
-                $order['pro_info'] = json_decode($order['pro_info'],true);
-                $member = getMemberInfoHash($order['mid']); //获取用户信息
-                $order['member_name'] = $member['name'];
-                $order['member_headimg'] = $member['headimg'];
-                if ($order['status']==0){
-                    $order['cancel_time'] = date('Y-m-d H:i:s',strtotime($order['create_at'])+($cancel_time*60));
-                }
-                break;
-            case 2:case 3:
-                $order = Db::name('store_order_info')
-                    ->where('mid',$this->uid)
-                    ->where('order_no',$order_no)
-                    ->where('resale_status',$status)
-                    ->where('is_destruction',1)
-                    ->find();
-                $order['pro_info'] = json_decode($order['pro_info'],true);
-                $member = getMemberInfoHash($order['mid']); //获取用户信息
-                $v['member_name'] = $member['name'];
-                $v['member_headimg'] = $member['headimg'];
-                break;
-        }
-        $this->success('成功',$order);
-    }
-
-
-    /**
-     * @title 取消订单
-     * @desc  取消订单
-     * @author  Gavin
-     * @url /api/Secondary/cancelOrder
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param name:order_no type:string require:1 default:-- desc:订单号
-     */
-    public function cancelOrder(){
-        $order_no = input('order_no');
-        if (!$order_no) $this->error('参数错误');
-        $order = Db::name('store_order_info_order')
-            ->where('order_no',$order_no)
-            ->where('mid',$this->uid)
-            ->find();
-        if (!$order) $this->error('订单不存在');
-        if ($order['status']!=0) $this->error('订单已支付或已取消');
-        $com = true;
-        Db::startTrans();
-        try {
-            $up_data = [
-                'status'=>2,
-                'cancel_at'=>date('Y-m-d H:i:s'),
-                'cancel_state'=>2
-            ];
-            Db::name('store_order_info_order')->where('order_no',$order_no)->update($up_data);
-
-            $cancle = [
-                'mid'=>$this->uid,
-                'order_id'=>$order['id']
-            ];
-            Db::name('store_order_info_cancel_log')->insert($cancle);
-
-            $time = date('Y-m-d H:i:s',time()-(60*60));
-            $count = Db::name('store_order_info_cancel_log')->where('mid',$this->uid)->where('create_at','gt',$time)->count();
-            if ($count>2){
-                $buy_time = date('Y-m-d H:i:s',time()+(24*60*60));
-                Db::name('store_member')->where('id',$this->uid)->update(['buy_time'=>$buy_time]);
-            }
-
-            Db::commit();
-        }catch (\Exception $e){
-            $com=false;
-            Db::rollback();
-        }
-        if ($com){
-            setMemberInfoHash($this->uid);
-            $this->success('取消成功');
-        }else{
-            $this->error('取消失败,请稍后重试');
-        }
-    }
-
-    /**
-     * @title 待支付订单支付
-     * @desc  待支付订单支付
-     * @author  Gavin
-     * @url /api/Secondary/payOrder
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     * @param name:order_no type:string require:1 default:-- desc:订单号
-     * @param name:from type:string require:1 default:wx desc:wx:微信公众号h5:网页
-     *
-     * @return  name:order_no type:int require:0 default:0 desc:订单号
-     * @return  name:pay type:string require:0 default:0 desc:支付信息
-     */
-    public function payOrder(){
-        $this->checkSwitch(1);
-        $user = getMemberInfoHash($this->uid); //获取用户信息
-        $order_no = input('order_no');   //订单号
-        $id = input('id');
-        $from = input('from','wx');
-        if (!$order_no) $this->error('参数错误');
-        if (!$id) $this->error('参数错误');
-        $order = Db::name('store_order_info_order')
-           // ->where('order_no',$order_no)
-           ->where('id',$id)
-            ->where('mid',$this->uid)
-            ->find();
-        $order_no = $order['order_no'];
-        $pay_type = $order['pay_type'];
-        $this->checkSwitch(2,$pay_type);
-        if (!$order) $this->error('订单不存在');
-        if ($order['status']!=0) $this->error('订单已支付或已取消');
-        $info = Db::name('store_order_info')->where('id',$order['info_id'])->find();
-        if ($info['resale_status']!=2) $this->error('藏品已出售或已撤销出售');
-        $com = true;
-        Db::startTrans();
-        try {
-            //获取价格
-            $total_fee = $order['pay_price'];
-            $body = 'top艺术购买二级市场藏品';
-            switch ($pay_type){
-                case 'wx':
-                    $config = retrunWxConfig();
-                    $total_fee = $total_fee * 100;
-                    $config['notify_url'] = 'https://'.$_SERVER['SERVER_NAME'].'/api/Pay/SecondaryWxOrderNotify';
-                    $app = Factory::payment($config);
-
-                    $post_data = [
-                        'body' => $body,
-                        'out_trade_no' => $order_no,
-                        'total_fee' => $total_fee,
-                        'attach'=>$this->uid,     //自定义传值
-                    ];
-                    //trade_type   SAPI--JSAPI支付(或小程序支付)、NATIVE--Native支付、APP--app支付,MWEB--H5支付
-                    if ($from=='wx'){
-                        $post_data['openid'] = $user['openid'];
-                        $post_data['trade_type'] = 'JSAPI';
-                    }elseif ($from=='h5'){
-                        $post_data['trade_type'] = 'MWEB';
-                    }
-                    $result = $app->order->unify($post_data);
-
-                    if ($result['return_msg']=='OK'){
-                        if ($result['result_code']=='FAIL'){
-                            $com = false;
-                            Db::rollback();
-                        }else{
-                            $order1 = $app->jssdk->bridgeConfig($result['prepay_id']);//执行二次签名返回参数
-                            $retrun_data['order_no'] = $order_no;
-                            $retrun_data['id'] = $order['id'];
-                            $retrun_data['pay'] = json_decode($order1,true);
-                            Db::commit();
-                        }
-                    }else{
-                        $com = false;
-                        Db::rollback();
-                    }
-                    break;
-                case 'zfb':
-                    $order_nos = get_order_sn();
-                    if (Db::name('store_order_info_order')
-                        ->where('order_no',$order_no)
-                        ->where('mid',$this->uid)
-                        ->update(['order_no'=>$order_nos])){
-                        $zfb = new AliPay3();
-                        $notify_url = $this->request->root(true).'/index.php/api/Pay/alipaySecondaryNotify';//回调地址
-                        $callback_url = 'https://'.$_SERVER['SERVER_NAME'].'/web/h5/pages/shop/order';
-                        $order_result = $zfb->aliPay($body,$total_fee,$order_nos,$notify_url,$this->uid,$callback_url);
-                        $retrun_data['order_no'] = $order_nos;
-                        $retrun_data['id'] = $order['id'];
-                        $retrun_data['pay'] = $order_result['pay_url'];
-                        Db::commit();
-                    }else{
-                        $com=false;
-                        Db::rollback();
-                    }
-                    break;
-                case 'sd':
-                    $client = new Shande();
-                    $notify_url = 'https://'.$_SERVER['SERVER_NAME'].'/index.php/api/Pay/shandeSecondaryNotify';//回调地址
-                    $total_fee = $total_fee*100;
-                    $lenth = strlen($total_fee);
-                    $total_fee = get0number($lenth).$total_fee;
-                    $order_nos = get_order_sn();
-                    if (Db::name('store_order_info_order')
-                        ->where('order_no',$order_no)
-                        ->where('mid',$this->uid)
-                        ->update(['order_no'=>$order_nos])){
-                        $result = $client->orderPay($order_nos,$total_fee,$body,$notify_url,'https://'.$_SERVER['SERVER_NAME'].'/web/h5/pages/shop/order');
-                        $retrun_data['order_no'] = $order_nos;
-                        $retrun_data['id'] = $order['id'];
-                        $retrun_data['pay'] = json_decode($result['data'],true);
-                        Db::commit();
-                    }else{
-                        $com=false;
-                        Db::rollback();
-                    }
-                    break;
-                case 'ylh5':
-                    $order_nos = get_order_sn();
-                    if (Db::name('store_order_info_order')->where('order_no',$order_no)->where('mid',$this->uid)->update(['order_no'=>$order_nos])){
-                            $callback_url = 'https://'.$_SERVER['SERVER_NAME'].'/pages/shop/order';
-                            $huiju = new HuijuH5Pay();
-                            $notify_url = 'https://'.$_SERVER['SERVER_NAME'].'/index.php/api/Pay/ylSecondaryNotify';//回调地址
-                            $result = $huiju->ylh5Pay($order_nos,$callback_url,$notify_url,$info['name'],$total_fee,$this->uid,2);
-                            if ($result['ra_Code']=='100'){
-                                $retrun_data['order_no'] = $order_nos;
-                                $retrun_data['id'] = $order['id'];
-                                $retrun_data['pay'] = $result['rc_Result'];
-                                Db::commit();
-                            }else{
-                                $com = false;
-                                Db::rollback();
-                            }
-                    }else{
-                        $com = false;
-                        Db::rollback();
-                    }
-                    break;
-                case 'zfbh5':
-                    $order_nos = get_order_sn();
-                    if (Db::name('store_order_info_order')
-                        ->where('order_no',$order_no)
-                        ->where('mid',$this->uid)
-                        ->update(['order_no'=>$order_nos])){
-
-                        $callback_url = 'https://'.$_SERVER['SERVER_NAME'].'/pages/shop/order';
-                        $huiju = new HuijuH5Pay();
-                        $notify_url = 'https://'.$_SERVER['SERVER_NAME'].'/index.php/api/Pay/ylSecondaryNotify';//回调地址
-                        $result = $huiju->ylh5Pay($order_nos,$callback_url,$notify_url,$info['name'],$total_fee,$this->uid,1);
-                        if ($result['ra_Code']=='100'){
-                            $retrun_data['order_no'] = $order_nos;
-                            $retrun_data['id'] = $order['id'];
-                            $retrun_data['pay'] = $result['rc_Result'];
-                            Db::commit();
-                        }else{
-                            $com = false;
-                            Db::rollback();
-                        }
-                    }else{
-                        $com = false;
-                        Db::rollback();
-                    }
-                    break;
-
-            }
-        }catch (\Exception $e){
-            $com=false;
-            Db::rollback();
-        }
-        if ($com){
-            $this->success('成功',$retrun_data);
-        }
-        $this->error('失败,请稍后重试');
-    }
-
-
-    /**
-     * @param 判断开关
-     * @param string $pay_type
-     * @return bool
-     * @throws \think\db\exception\DataNotFoundException
-     * @throws \think\db\exception\ModelNotFoundException
-     * @throws \think\exception\DbException
-     */
-    public function checkSwitch($type,$pay_type=''){
-        if ($type==1){
-            $v = getConfigValue('secondary_sell_switch');
-            if (!$v){
-                $this->error('功能暂时关闭');
-            }else{
-                $start = getConfigValue('shelves_start_time');
-                $end = getConfigValue('shelves_end_time');
-                if (time()>strtotime($start) && time()<=strtotime($end)){
-
-                }else{
-                    $this->error('出售时间为:'.$start.'-'.$end);
-                }
-            }
-        }elseif ($type==2){
-            $nameArray = ['secondary_wx_switch','secondary_zfb_switch','secondary_sd_switch'];
-            $values = getConfig($nameArray);
-            if ($pay_type=='wx'){
-                if (!$values['secondary_wx_switch']) $this->error('微信支付暂时关闭');
-            }elseif ($pay_type=='zfb'){
-                if (!$values['secondary_zfb_switch']) $this->error('支付宝支付暂时关闭');
-            }elseif ($pay_type=='sd'){
-                if (!$values['secondary_sd_switch']) $this->error('杉德支付暂时关闭');
-            }
-        }elseif ($type==3){
-            $v = getConfigValue('secondary_buy_switch');
-            if (!$v){
-                $this->error('功能暂时关闭');
-            }else{
-                $start = getConfigValue('buy_start_time');
-                $end = getConfigValue('buy_end_time');
-                if (time()>strtotime($start) && time()<=strtotime($end)){
-
-                }else{
-                    $this->error('时间时间为:'.$start.'-'.$end);
-                }
-            }
-        }
-        return true;
-    }
-
-
-
-
-
-}

+ 0 - 130
application/api/controller/Sms.php

@@ -1,130 +0,0 @@
-<?php
-
-namespace app\api\controller;
-
-use app\common\library\Common;
-use app\common\library\Jiyan;
-use think\Db;
-use think\facade\Validate;
-use think\Request;
-use AlibabaCloud\Client\AlibabaCloud;
-
-/**
- * @title 发送短信
- * @controller Sms
-
- */
-class Sms extends Base
-{
-    /**
-     * @title 发送短信
-     * @desc 发送短信
-     * @url /api/Sms/send
-     * @method POST
-     * @tag 基础
-     * @header
-     * @param  name:phone type:string require:1 default:-- desc:手机号
-     * @param  name:event type:string require:0 default:register desc:发送类型register:注册forgetpwd:找回密码login:找回密码
-     */
-    public function send()
-    {
-        $this->error('没有短信验证吗');
-
-        $phone = input("phone");
-        $event = input("event",'register');
-        if (!$phone || !Validate::regex($phone, "^1\d{10}$")) {
-            $this->error('手机号不正确');
-        }
-
-//        $lot_number = input('lot_number');
-//        $captcha_output = input('captcha_output');
-//        $pass_token = input('pass_token');
-//        $gen_time = input('gen_time');
-//        if (!$lot_number || !$captcha_output || !$pass_token || !$gen_time) $this->error('参数错误');
-//
-//        $jy = new Jiyan();
-//        $result = $jy->jy($lot_number,$captcha_output,$pass_token,$gen_time,1);
-//        if ($result['result']=='fail') $this->error('校验失败,请稍后重试');
-
-        $last = Db::name('store_sms')->where(['mobile' => $phone, 'event' => $event])
-            ->order('id', 'DESC')
-            ->find();
-        if ($last && (time() - $last['createtime'])< 60) {
-            $this->error('发送频繁!');
-        }
-//        $ipSendTotal = Db::name('store_sms')->where(['ip' => request()->ip()])->whereTime('createtime', '-1 hours')->count();
-//        if ($ipSendTotal >= 5) {
-//            $this->error('发送频繁!');
-//        }
-
-        $member = Db::name('store_member')
-            ->where('phone',$phone)
-            ->where('is_deleted',0)
-            ->count();
-        switch ($event){
-            case 'register':
-                if ($member) $this->error('手机号已注册');
-                break;
-            case 'forgetpwd': case 'login':
-                if (!$member) $this->error('手机号未注册');
-                break;
-        }
-
-        //发送阿里云短信
-        $ret = $this->accessKeyClient($event, $phone, mt_rand(100000, 999999));
-        if ($ret['Code'] === 'OK') {
-            $this->success('发送成功!');
-        } elseif ($ret['Code'] === 'isv.BUSINESS_LIMIT_CONTROL') {
-            $this->error('发送太过频繁!');
-        } else {
-            $this->error($ret['msg']);
-        }
-    }
-
-    function accessKeyClient($event, $mobile, $num)
-    {
-        $sett = [
-            'ali_accesskey',
-            'ali_accesskey_secret',
-            'templateCode',
-            'sign_name'
-        ];
-        $array = getConfig($sett);
-
-        $ali_accesskey = $array['ali_accesskey'];
-        $ali_accesskey_secret = $array['ali_accesskey_secret'];
-        $templateCode = $array['templateCode'];
-        AlibabaCloud::accessKeyClient($ali_accesskey, $ali_accesskey_secret)
-            ->regionId('cn-hangzhou')
-            ->asDefaultClient();
-
-        try {
-            $result = AlibabaCloud::rpc()
-                ->product('Dysmsapi')
-                // ->scheme('https') // https | http
-                ->version('2017-05-25')
-                ->action('SendSms')
-                ->method('POST')
-                ->host('dysmsapi.aliyuncs.com')
-                ->options([
-                    'query' => [
-                        'PhoneNumbers' => $mobile,
-                        'SignName' => $array['sign_name'],
-                        'TemplateCode' => $templateCode,
-                        'TemplateParam' => '{"code":' . $num . '}',
-                    ],
-                ])
-                ->request();
-            $info = $result->toArray();
-            if ($info['Code'] == 'OK') {
-                $ip = request()->ip();
-                Db::name('store_sms')->insert(['event' => $event, 'mobile' => $mobile, 'createtime'=>time(),'code' => $num, 'ip' => $ip]);
-            }
-            return $info;
-        } catch (ClientException $e) {
-            echo $e->getErrorMessage() . PHP_EOL;
-        } catch (ServerException $e) {
-            echo $e->getErrorMessage() . PHP_EOL;
-        }
-    }
-}

+ 0 - 247
application/api/controller/Synthetic.php

@@ -1,247 +0,0 @@
-<?php
-
-
-namespace app\api\controller;
-use app\common\library\AliPay;
-use EasyWeChat\Factory;
-use think\cache\driver\Redis;
-use think\Db;
-/**
- * @title 合成藏品
- * @controller secondary
- * @package app\api\controller
- */
-class Synthetic extends Base
-{
-
-    public function initialize(){
-        parent::initialize();
-        parent::check_login();
-    }
-
-
-    /**
-     * @title 合成藏品列表
-     * @desc  合成藏品列表
-     * @author  Gavin
-     * @url /api/Synthetic/synList
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     *
-     *
-     * @return name:name type:string default:-- desc:藏品名称
-     * @return name:cover type:string default:-- desc:藏品图
-     * @return name:label type:string default:-- desc:标签
-     * @return name:price type:DECIMAL default:-- desc:价格
-     * @return name:inventory type:int default:-- desc:库存
-     * @return name:now_inventory type:int default:-- desc:剩余库存
-     * @return name:sy_state type:float default:-- desc:藏品状态(1:进行中2:即将开售3:已结束4:已售罄)
-     * @return name:sell_time type:string default:-- desc:发行时间
-     * @return name:end_time type:string default:-- desc:结束时间
-     */
-    public function synList(){
-        checkSynCollectionState();
-        $list = Db::name('store_collection')
-            ->where('is_deleted',0)
-            ->where('status',1)
-            ->where('type',2)
-            ->field('id,cover,name,label,price,inventory,now_inventory,sy_state,sell_time,end_time')
-            ->order('sy_state asc,sell_time asc')
-            ->select();
-        foreach ($list as &$v) {
-            $v['now_inventory'] = getCollectionInventory($v['id']);
-            $v['id'] = (string)$v['id'];
-        }
-        $this->success('成功',$list);
-    }
-
-    /**
-     * @title 藏品详情
-     * @desc 藏品详情
-     * @author  Gavin
-     * @url /api/Synthetic/CollectionDetail
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param name:id type:string require:1 default:-- desc:藏品ID
-     *
-     * @return name:name type:string default:-- desc:藏品名称
-     * @return name:cover type:string default:-- desc:藏品图
-     * @return name:label type:string default:-- desc:标签
-     * @return name:price type:DECIMAL default:-- desc:价格
-     * @return name:inventory type:int default:-- desc:库存
-     * @return name:now_inventory type:int default:-- desc:剩余库存
-     * @return name:sy_state type:float default:-- desc:藏品状态(1:进行中2:即将开售3:已结束4:已售罄)
-     * @return name:sell_time type:string default:-- desc:发行时间
-     * @return name:end_time type:string default:-- desc:结束时间
-     * @return name:describe type:string default:-- desc:商品描述
-     * @return name:instructions type:int default:1 desc:权益说明
-     * @return name:buy_notice type:int default:1 desc:购买须知
-     * @return name:warm_prompt type:int default:1 desc:温馨提示
-     * @return name:auth_img type:int default:1 desc:作者头像
-     * @return name:auth_name type:int default:1 desc:作者姓名
-     * @return name:is_exchange type:int default:1 desc:材料是否够(1:够,可以合成0:不够)
-     * @return name:material@name type:string default:-- desc:材料名称
-     * @return name:material@cover type:string default:-- desc:材料图片
-     * @return name:material@num type:string default:-- desc:所需数量
-     * @return name:material@now_num type:string default:-- desc:当前所有数量
-     */
-    public function CollectionDetail(){
-        $collect_id = input('id');
-        if (!$collect_id) $this->error('参数错误');
-        checkSynCollectionState($collect_id);
-        $info = Db::name('store_collection')
-            ->where('is_deleted',0)
-            ->where('status',1)
-            ->where('type',2)
-            ->where('id',$collect_id)
-            ->field('id,cover,name,label,price,inventory,now_inventory,sy_state,sell_time,end_time,describe,buy_count,instructions,buy_notice,warm_prompt,auth_img,auth_name,share_img,intro')
-            ->find();
-        if (!$info) $this->error('藏品不存在');
-        $info['describe'] = explode('|',$info['describe']);
-        $info['now_inventory'] = getCollectionInventory($info['id']);
-        $material = Db::name('store_collection_material')
-            ->alias('a')
-            ->join('store_collection b','a.c_id=b.id')
-            ->where('a.cid',$collect_id)
-            ->field('a.id,a.c_id,a.num,b.name,b.cover')
-            ->select();
-        $info['is_exchange'] = $this->check_exchange($collect_id,$this->uid);
-        foreach ($material as &$v){
-            $v['now_num'] = Db::name('store_order_info')
-                ->where('c_id',$v['c_id'])
-                ->where('mid',$this->uid)
-                ->where('status','neq',2)
-                ->where('is_destruction',1)
-                ->count();
-        }
-        $info['material'] = $material;
-        $info['id'] = (string)$info['id'];
-        $this->success('成功',$info);
-    }
-
-
-
-
-    /**
-     * 判断材料是否足够可以兑换
-     */
-    public function check_exchange($id,$mid){
-        $list = Db::name('store_collection_material')
-            ->alias('a')
-            ->join('store_collection b','a.c_id=b.id')
-            ->where('a.cid',$id)
-            ->field('a.id,a.c_id,a.num,b.name,b.cover')
-            ->select();
-        $is_exchange = 1;
-        foreach ($list as &$v){
-            $user_count = Db::name('store_order_info')
-                ->where('c_id',$v['c_id'])
-                ->where('mid',$mid)
-                ->where('status','neq',2)
-                ->where('is_destruction',1)
-                ->count();
-            if ($user_count<$v['num']){
-                $is_exchange = 0;
-                break;
-            }
-        }
-        return $is_exchange;
-
-    }
-
-    /**
-     * @title 合成藏品
-     * @desc  合成藏品
-     * @author  Gavin
-     * @url /api/Synthetic/synCollection
-     * @method POST
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param name:id type:int require:1 default:1 desc:藏品ID
-     */
-    public function synCollection(){
-        $id = input('id');
-        if (!$id) $this->error('参数错误');
-        $info = Db::name('store_collection')
-            ->where('is_deleted',0)
-            ->where('status',1)
-            ->where('type',2)
-            ->where('id',$id)
-            ->find();
-        if (!$info) $this->error('藏品不存在');
-        $now_inventory = getCollectionInventory($id);
-        if ($now_inventory<=0) $this->error('已售罄');
-        if (strtotime($info['sell_time'])>time()) $this->error('未开始,无法合成');
-        if (strtotime($info['end_time'])<time())  $this->error('已结束,无法合成');
-
-//        $info_count = Db::name('store_order_info')->where('mid',$this->uid)->where('c_id',$id)->count();
-//        if ($info_count) $this->error('已合成过,只能合成一次');
-
-        //获取是否已经铸造hash
-        $is_nft = Db::name('hash2')->where('goods_id',$id)->where('success',1)->find();
-        if (!$is_nft) $this->error('nft未上架,无法合成');
-        $is_exchange = $this->check_exchange($id,$this->uid);
-        if (!$is_exchange) $this->error('材料不足,无法合成');
-        $com = true;
-        Db::startTrans();
-        try {
-            $material = Db::name('store_collection_material')
-                ->where('cid',$id)
-                ->select();
-            foreach ($material as &$v){
-                Db::name('store_order_info')
-                    ->where('c_id',$v['c_id'])
-                    ->where('mid',$this->uid)
-                    ->where('status','neq',2)
-                    ->where('is_destruction',1)
-                    ->limit($v['num'])
-                    ->order('id asc')
-                    ->update(['is_destruction'=>0]);
-            }
-
-            //获取排名
-            $rank = getRanking($id)+1;
-            $tag = getTag($id,$rank,$info['inventory']);
-            saveRanking($id);
-            $collectors_hash = '';
-            $date = [
-                'order_id'=>0,
-                'order_no'=>get_order_sn(),
-                'tag'=>$tag,
-                'mid'=>$this->uid,
-                'c_id'=>$id,
-                'name'=>$info['name'],
-                'cover'=>$info['cover'],
-                'pro_info'=>json_encode($info,true),
-                'type'=>$info['type'],
-                'tokenid'=>$is_nft['class_id'],
-                'nfttype'=>$is_nft['operationId'],
-                'collectors_hash'=>$collectors_hash,
-                'status'=>5
-            ];
-            Db::name('store_order_info')->insert($date);
-
-            Db::commit();
-        }catch (\Exception $e){
-            $com=false;
-            Db::rollback();
-        }
-        if ($com){
-            setMemberInfoHash($this->uid);
-            //减掉库存
-            loseCollectionInventory($id,1);
-
-            $this->success('合成成功');
-        }
-        $this->error('合成失败,请稍后重试');
-
-
-
-    }
-
-
-
-
-
-}

+ 0 - 29
application/api/controller/Test.php

@@ -1,29 +0,0 @@
-<?php
-
-
-namespace app\api\controller;
-use AlibabaCloud\Client\AlibabaCloud;
-use AlibabaCloud\Client\Exception\ClientException;
-use AlibabaCloud\Client\Exception\ServerException;
-use app\common\library\PHPExcelService;
-use think\cache\driver\Redis;
-use think\Controller;
-use think\Db;
-use think\Exception;
-use function AlibabaCloud\Client\value;
-
-/**
- * @title 定时任务
- * Class Timedtask
- * @controller Timedtask
- * @group base
- */
-class Test extends Base
-{
-    public function index(){
-         $PHPExcel=new \PHPExcel();
-        // $objPHPExcel = PHPExcel_IOFactory::load($inputFileName);
-
-    }
-
-}

+ 0 - 436
application/api/controller/Timedtask.php

@@ -1,436 +0,0 @@
-<?php
-
-
-namespace app\api\controller;
-use AlibabaCloud\Client\AlibabaCloud;
-use AlibabaCloud\Client\Exception\ClientException;
-use AlibabaCloud\Client\Exception\ServerException;
-use think\cache\driver\Redis;
-use think\Db;
-use think\Exception;
-use function AlibabaCloud\Client\value;
-
-/**
- * @title 定时任务
- * Class Timedtask
- * @controller Timedtask
- * @group base
- */
-class Timedtask
-{
-    /**
-     * @title 取消订单定时任务
-     * @desc  未支付的自动取消
-     * @author  Gavin
-     * @url /api/Timedtask/cancelGoodsOrder
-     * @method GET
-     */
-    public function cancelGoodsOrder(){
-        $CancelTime = getCancelTime();
-        if ($CancelTime<=0){
-            die(1);
-        }
-
-
-        $redis = new Redis();
-        $users = $redis->hkeys('buyUserInfo');
-        if ($users){
-            foreach ($users as &$value){
-                $key = 'order_not_pay_'.$value;
-                $len = $redis->hGetLen($key);
-                if ($len){
-                    $list = $redis->hGetvals($key);
-                    foreach ($list as &$a){
-                        $info = json_decode($a,true);
-
-                        $cancel_time = strtotime($info['create_at'])+($CancelTime*60);
-                        if ($cancel_time<time()){
-                            $info['status'] = 2;
-                            $info['cancel_at'] = date('Y-m-d H:i:s');
-                            Db::name('store_order')->insert($info);
-                            //加上库存
-                            addCollectionInventory($info['c_id'],$info['num']);
-                            //减少用户购买数量
-                            DecrByCount($info['mid'],$info['c_id'],$info['num']);
-                            //删除数据
-                            $redis->hdel($key,$info['order_no']);
-                        }
-                    }
-                }else{
-                    $redis->hdel('buyUserInfo',$value);
-                }
-            }
-        }
-    }
-
-
-    /**
-     * @title 二级市场未支付的自动取消
-     * @desc  二级市场未支付的自动取消
-     * @author  Gavin
-     * @url /api/Timedtask/SecondaryancelGoodsOrder
-     * @method GET
-     */
-    public function SecondaryancelGoodsOrder(){
-        $CancelTime = getConfigValue('secondary_cancel_time');
-        if ($CancelTime<=0){
-            die;
-        }
-        $list = Db::name('store_order_info_order')->where('status',0)->select();
-        foreach ($list as &$v){
-            $cancel_time = strtotime($v['create_at'])+($CancelTime*60);
-            if ($cancel_time<time()){
-                $info['status'] = 2;
-                $info['cancel_at'] = date('Y-m-d H:i:s');
-                Db::name('store_order_info_order')->where('id',$v['id'])->update($info);
-
-                $cancle = [
-                    'mid'=>$v['mid'],
-                    'order_id'=>$v['id']
-                ];
-                Db::name('store_order_info_cancel_log')->insert($cancle);
-
-                $time = date('Y-m-d H:i:s',time()-(60*60));
-                $count = Db::name('store_order_info_cancel_log')->where('mid',$v['mid'])->where('create_at','gt',$time)->count();
-                if ($count>2){
-                    $buy_time = date('Y-m-d H:i:s',time()+(24*60*60));
-                    Db::name('store_member')->where('id',$v['mid'])->update(['buy_time'=>$buy_time]);
-                }
-            }
-        }
-    }
-
-    /**
-     * @title 创建链账户
-     * @desc  创建链账户
-     * @author  Gavin
-     * @url /api/Timedtask/createAddress
-     * @method GET
-     */
-    public function createAddress(){
-        set_time_limit(0);
-        $member = Db::name('store_member')
-            ->where('wallet_address','eq','')
-            //->whereNull('wallet_address')
-            ->field('id,offline_account,phone,wallet_address')
-            ->order('id asc')
-            ->limit(30)
-            ->select();
-        foreach ($member as &$v){
-            $name = $v['phone'];
-            $operationId = $v['phone'];
-            $operationId .= rand(10000,99999);
-            $url = getIpAddress()."customNFT/createAccount?name=".$name."&operationId=".$operationId;
-            $offlineaccount = file_get_contents($url);
-            $offline_account = json_decode($offlineaccount,true);
-            if (isset($offline_account) && isset($offline_account['account'])){
-                Db::name('store_member')->where('id',$v['id'])
-                    ->update(['accountName'=>$operationId,'wallet_address'=>$offline_account['account'],'offline_account'=>$offlineaccount]);
-            }
-        }
-    }
-
-
-
-    /**
-     * 查询链上架回执
-     * @url /api/Timedtask/setNftCheck
-     */
-    public function setNftCheck(){
-        Db::name('hash2')->where('success',0)->chunk(30,function ($list){
-            foreach ($list as &$v){
-                $result =$this->checkhashSuccess($v['operationId']);
-                $data['result'] = json_encode($result,true);
-                if (isset($result) && $result['status']==1){
-                    $data['success'] = 1;
-                    $data['class_id'] =$result['class_id'];
-                }
-                Db::name('hash2')->where('id',$v['id'])->update($data);
-            }
-        },'id','asc');
-    }
-
-
-    /**
-     * 创建nft
-     * @url /api/Timedtask/createNft
-     */
-    public function createNft(){
-        Db::name('store_order_info')
-            ->whereIn('status','1,4,5')
-            ->where('collectors_hash','eq','')
-            ->whereNull('collectors_hash2')
-            ->chunk(30,function ($list){
-                foreach ($list as &$v){
-                    $name = get32Str(10);
-                    $operationId = $v['id'];
-                    $operationId .= rand(1000000,9999999);
-                    $to =  Db::name('store_member')->where('id',$v['mid'])->value('wallet_address');
-                    $url = getIpAddress().'customNFT/createNft?classId='.$v['tokenid'].'&name='.$name.'&operationId='.$operationId.'&recipient='.$to;
-                    $res=curlRequest($url);
-                    $result=json_decode($res,true);
-                    if (isset($result) && isset($result['task_id'])){
-                        Db::name('store_order_info')->where('id',$v['id'])->update(['collectors_hash2'=>$result['task_id'],'nfttype'=>$operationId]);
-                    }
-                }
-            },'id','asc');
-    }
-
-    /**
-     * 判断创建的nft是否成功
-     * @url /api/Timedtask/checkcreateNft
-     */
-    public function checkcreateNft(){
-        Db::name('store_order_info')
-            ->whereIn('status','1,4,5')
-            ->where('collectors_hash','eq','')
-            ->whereNotNull('collectors_hash2')
-            ->chunk(30,function ($list){
-                foreach ($list as &$v){
-                    $result = $this->checkhashSuccess($v['collectors_hash2']);
-                    $data['result'] = json_encode($result,true);
-                    if (isset($result) && $result['status']==1){
-                        $data['tokenid'] = $result['class_id'];
-                        $data['collectors_hash'] = $result['tx_hash'];
-                        $data['nftid'] = $result['nft_id'];
-                        $data['collectors_hash_time'] = date('Y-m-d H:i:s');
-                    }
-
-                    Db::name('store_order_info')->where('id',$v['id'])->update($data);
-                }
-            },'id','asc');
-    }
-
-    /**
-     *
-     * @url /api/Timedtask/checkrepetition
-     */
-    public function checkrepetition(){
-        $list = Db::query('select count(collectors_hash) as count,collectors_hash from store_order_info  group by collectors_hash having count(*)>1');
-        foreach ($list as &$v){
-            $list2 =  Db::name('store_order_info')->where('collectors_hash',$v['collectors_hash'])->select();
-            foreach ($list2 as &$a){
-                $result = json_decode($a['result'],true);
-                if ($result['status']!=1){
-                    Db::name('store_order_info')->where('id',$a['id'])->update(['collectors_hash'=>'']);
-                }
-            }
-        }
-    }
-
-
-    /**
-     * 转移nft
-     * @url /api/Timedtask/judgeHash
-     */
-    public function judgeHash(){
-        Db::name('store_order_info')
-            ->where('status',3)
-            ->where('collectors_hash','eq','')
-            ->whereNull('collectors_hash2')
-            ->chunk(30,function ($list){
-                foreach ($list as &$v){
-                    $operationId = $v['id'];
-                    $operationId .= rand(10000000,99999999);
-                    $add = Db::name('store_member')->where('id',$v['to_mid'])->value('wallet_address');
-                    $to =  Db::name('store_member')->where('id',$v['mid'])->value('wallet_address');
-                    $url = getIpAddress().'customNFT/transfer?classId='.$v['tokenid'].'&NFTId='.$v['nftid'].'&operationId='.$operationId.'&owner='.$add.'&recipient='.$to;
-                    echo $url;
-                    $res=curlRequest($url);
-                    $result=json_decode($res,true);
-                    dump($result);
-                    if (isset($result) && isset($result['task_id'])){
-                        Db::name('store_order_info')->where('id',$v['id'])->update(['collectors_hash2'=>$result['task_id'],'nfttype'=>$operationId]);
-                    }
-                }
-            },'id','asc');
-    }
-
-    /**
-     * 判断转移的nft是否成功
-     * @url /api/Timedtask/checkjudgeNft
-     */
-    public function checkjudgeNft(){
-        Db::name('store_order_info')
-            ->where('status',3)
-            ->where('collectors_hash','eq','')
-            ->whereNotNull('collectors_hash2')
-            ->chunk(30,function ($list){
-                foreach ($list as &$v){
-                    $result = $this->checkhashSuccess($v['collectors_hash2']);
-                    $data['result'] = json_encode($result,true);
-                    if (isset($result) && $result['status']==1){
-                        $data['tokenid'] = $result['class_id'];
-                        $data['collectors_hash'] = $result['tx_hash'];
-                        $data['nftid'] = $result['nft_id'];
-                    }
-                    Db::name('store_order_info')->where('id',$v['id'])->update($data);
-                }
-            },'id','asc');
-    }
-
-
-
-
-
-
-
-
-    /**
-     * 查询交易是否成功
-     * @url /api/Timedtask/checkhashSuccess
-     */
-    public function checkhashSuccess($operationId){
-        $url = getIpAddress().'customNFT/queryDealResult?operationId='.$operationId;
-        $res=curlRequest($url);
-        $result=json_decode($res,true);
-        return $result;
-    }
-
-
-
-
-    /**
-     * 判断转移的数据是否属于当前转移用户
-     * @url /api/Timedtask/checkjudgeHashOwer
-     */
-    public function checkjudgeHashOwer(){
-        $list = Db::name('store_order_info')
-            ->where('status',3)
-            ->where('collectors_hash','eq','')
-            ->whereNull('collectors_hash2')
-            ->order('id asc')
-            ->limit(30)
-            ->select();
-        foreach ($list as &$v){
-            if (time()>strtotime($v['collectors_hash_time'])+(1*60*60)){
-                $url = getIpAddress().'customNFT/sNFT?classId='.$v['tokenid'].'&NFTId='.$v['nftid'];
-                $res=json_decode(curlRequest($url),true);
-                if (isset($res)){
-                    dump($res);
-                    $add = Db::name('store_member')->where('id',$v['to_mid'])->value('wallet_address');
-                    echo $add."<br />";
-                    if ($add != $res['owner']){
-                        $operationId = $v['id'];
-                        $operationId .= rand(10000000,99999999);
-                        $adds = $res['owner'];
-                        $tos =  $add;
-                        $url = getIpAddress().'customNFT/transfer?classId='.$v['tokenid'].'&NFTId='.$v['nftid'].'&operationId='.$operationId.'&owner='.$adds.'&recipient='.$tos;
-                        $ress = json_decode(curlRequest($url),true);
-                        dump($ress);
-
-                    }
-                }
-            }
-        }
-    }
-
-
-
-
-    /**
-     * redis 加锁
-     */
-    function redisCreateSetNx($id){
-        $redis = new Redis();
-        $key = 'hash_'.$id;
-        $exptime = 450;
-        $is_lock = $redis->setnx($key,time()+$exptime);
-        if ($is_lock){
-            return true;
-        }else{
-            //加锁失败的情况下,判断锁是否已经存在,如果存在切已经过期,删除锁,重新加锁
-            $val = $redis->get($key);
-            if ($val && $val<time()){
-                $redis->del($key);
-            }
-            return $redis->setnx($key,time()+$exptime);
-        }
-    }
-
-
-    /**
-     * redis  nonce加锁
-     */
-    function redisNonceSetNx(){
-        $redis = new Redis();
-        $key = 'noncenx';
-        $exptime = 10;
-        $is_lock = $redis->setnx($key,time()+$exptime);
-        if ($is_lock){
-            return true;
-        }else{
-            //加锁失败的情况下,判断锁是否已经存在,如果存在切已经过期,删除锁,重新加锁
-            $val = $redis->get($key);
-            if ($val && $val<time()){
-                $redis->del($key);
-            }
-            return $redis->setnx($key,time()+$exptime);
-        }
-    }
-
-
-    /**
-     * 预约藏品前十五分钟发送短信
-     * /api/Timedtask/sendSms
-     */
-    public function sendSms(){
-        Db::name('store_collection_remind')->where('is_send',0)->chunk(50,function ($list){
-            foreach ($list as &$v){
-                $sell_time = Db::name('store_collection')->where('id',$v['c_id'])->value('sell_time');
-                $t = (strtotime($sell_time)-time())/60;
-                if ($t<=15 && $t>0){
-                    $result = $this->accessKeyClient($v['mobile'],$v['mid'],$v['c_id']);
-                    if ($result['Code'] === 'OK') {
-                        Db::name('store_collection_remind')->where('id',$v['id'])->update(['is_send'=>1]);
-                    }
-                }
-            }
-        },'id','asc');
-    }
-
-    function accessKeyClient($mobile,$mid,$cid)
-    {
-        $ali_accesskey = 'LTAI5tSTBuRP5AnPBHDz8gTF';
-        $ali_accesskey_secret = '7RVjRKv8cCaKW4hMMVZ1SFPkqeIbn4';
-        $templateCode = 'SMS_243370550';
-        AlibabaCloud::accessKeyClient($ali_accesskey, $ali_accesskey_secret)
-            ->regionId('cn-hangzhou')
-            ->asDefaultClient();
-
-        $user = getMemberInfoHash($mid); //获取用户信息
-        $coll_info = getCollectionInfoHash($cid);
-        $post = [
-            'name'=>$user['name'],
-            'goodname'=>$coll_info['name'],
-            'pubtime'=>$coll_info['sell_time']
-        ];
-        $TemplateParam = json_encode($post,true);
-
-        try {
-            $result = AlibabaCloud::rpc()
-                ->product('Dysmsapi')
-                // ->scheme('https') // https | http
-                ->version('2017-05-25')
-                ->action('SendSms')
-                ->method('POST')
-                ->host('dysmsapi.aliyuncs.com')
-                ->options([
-                    'query' => [
-                        'PhoneNumbers' => $mobile,
-                        'SignName' => '同质科技',
-                        'TemplateCode' => $templateCode,
-                        'TemplateParam' => $TemplateParam
-                    ],
-                ])
-                ->request();
-            $info = $result->toArray();
-            return $info;
-        } catch (ClientException $e) {
-            echo $e->getErrorMessage() . PHP_EOL;
-        } catch (ServerException $e) {
-            echo $e->getErrorMessage() . PHP_EOL;
-        }
-    }
-
-}

+ 0 - 298
application/api/controller/Timedtask1.php

@@ -1,298 +0,0 @@
-<?php
-
-
-namespace app\api\controller;
-use AlibabaCloud\Client\AlibabaCloud;
-use AlibabaCloud\Client\Exception\ClientException;
-use AlibabaCloud\Client\Exception\ServerException;
-use think\cache\driver\Redis;
-use think\Db;
-use think\Exception;
-
-/**
- * @title 定时任务
- * Class Timedtask
- * @controller Timedtask
- * @group base
- */
-class Timedtask1
-{
-    /**
-     * @title 取消订单定时任务
-     * @desc  未支付的自动取消
-     * @author  Gavin
-     * @url /api/Timedtask/cancelGoodsOrder
-     * @method GET
-     */
-    public function cancelGoodsOrder(){
-        $CancelTime = getCancelTime();
-        if ($CancelTime<=0){
-            die;
-        }
-        $redis = new Redis();
-        $users = $redis->hkeys('buyUserInfo');
-        if ($users){
-            foreach ($users as &$value){
-                $key = 'order_not_pay_'.$value;
-                $len = $redis->hGetLen($key);
-                if ($len){
-                    $list = $redis->hGetvals($key);
-                    foreach ($list as &$a){
-                        $info = json_decode($a,true);
-                        $cancel_time = strtotime($info['create_at'])+($CancelTime*60);
-                        if ($cancel_time<time()){
-                            $info['status'] = 2;
-                            $info['cancel_at'] = date('Y-m-d H:i:s');
-                            Db::name('store_order')->insert($info);
-                            //加上库存
-                            addCollectionInventory($info['c_id'],$info['num']);
-                            //减少用户购买数量
-                            DecrByCount($info['mid'],$info['c_id'],$info['num']);
-                            //删除数据
-                            $redis->hdel($key,$info['order_no']);
-                        }
-                    }
-                }else{
-                    $redis->hdel('buyUserInfo',$value);
-                }
-            }
-        }
-    }
-
-
-    /**
-     * @title 二级市场未支付的自动取消
-     * @desc  二级市场未支付的自动取消
-     * @author  Gavin
-     * @url /api/Timedtask/SecondaryancelGoodsOrder
-     * @method GET
-     */
-    public function SecondaryancelGoodsOrder(){
-        $CancelTime = getConfigValue('secondary_cancel_time');
-        if ($CancelTime<=0){
-            die;
-        }
-        $list = Db::name('store_order_info_order')->where('status',0)->select();
-        foreach ($list as &$v){
-            $cancel_time = strtotime($v['create_at'])+($CancelTime*60);
-            if ($cancel_time<time()){
-                $info['status'] = 2;
-                $info['cancel_at'] = date('Y-m-d H:i:s');
-                Db::name('store_order_info_order')->where('id',$v['id'])->update($info);
-
-                $cancle = [
-                    'mid'=>$v['mid'],
-                    'order_id'=>$v['id']
-                ];
-                Db::name('store_order_info_cancel_log')->insert($cancle);
-
-                $time = date('Y-m-d H:i:s',time()-(60*60));
-                $count = Db::name('store_order_info_cancel_log')->where('mid',$v['mid'])->where('create_at','gt',$time)->count();
-                if ($count>2){
-                    $buy_time = date('Y-m-d H:i:s',time()+(24*60*60));
-                    Db::name('store_member')->where('id',$v['mid'])->update(['buy_time'=>$buy_time]);
-                }
-            }
-        }
-    }
-
-    /**
-     * 藏品铸造hash 定时任务
-     * @url /api/Timedtask/castingHash
-     */
-    public function castingHash(){
-        set_time_limit(0);
-        $redis = new Redis();
-        $list = Db::name('store_collection')->where('is_deleted',0)->select();
-        $id = 0;
-        $set_count = 0;
-        foreach ($list as &$v){
-            $count = $redis->get('castingHash_'.$v['id']);
-            if ($count && $count>0){
-                $id = $v['id'];
-                $set_count = $count;
-                break;
-            }
-        }
-        if ($id){
-            $address = '0x3153052307c15c46abb7b3667cdbcd48a7e2a341';
-            for ($i=0;$i<$set_count;$i++){
-                if ($this->redisNonceSetNx()){
-                    $str=$id.'-'.rand(100000000,999999999);
-                    $url='http://47.111.246.47:8083/ddc/createHashAutoNonce?address='.$address.'&ddcURI='.$str;
-                    $res=curlRequest($url);
-                    $result=json_decode($res,true);
-                    if($result['code']){
-                        continue;
-                    }else{
-                        $data['goods_id']=$id;
-                        $data['hash']=$res;
-                        $data['ddcURI'] = $str;
-
-                        if (Db::name('hash')->insert($data)){
-                            $redis->del('noncenx');
-                            $redis->Decr('castingHash_'.$id);  //减一
-                        }
-                    }
-                }
-            }
-        }
-
-    }
-
-    /**
-     * 铸造hash判断回执 定时任务
-     * @url /api/Timedtask/transactionReceipt
-     */
-    public function transactionReceipt(){
-        set_time_limit(0);
-        Db::name('hash')->where('success',0)
-            ->chunk(50,function ($list){
-            $redis = new Redis();
-            foreach ($list as &$v){
-                $url = 'http://47.111.246.47:8083/ddc/getTransactionReceipt?hash='.$v['hash'];
-                $res=curlRequest($url);
-                Db::name('hash')->where('id',$v['id'])->update(['result'=>$res]);
-                $result3=json_decode($res,true);
-                if (isset($result3['status']) && $result3['status']=='0x1'){
-                    $url4='http://47.111.246.47:8083/ddc/createDdcid?hash='.$v['hash'];
-                    $ddcid=curlRequest($url4);
-                    $result4=json_decode($ddcid,true);
-                    if($result4['code']){
-
-                    }else{
-                        $update_data['success'] = 1;
-                        $update_data['ddcid'] = $ddcid;
-                        if (Db::name('hash')->where('id',$v['id'])->update($update_data)){
-                            //存入reids list
-                            $redis_data = ['hash'=>$v['hash'],'ddcid'=>$ddcid,'create_at'=>date('Y-m-d H:i:s')];
-                            $redis->rPush('collectionHash_'.$v['goods_id'],json_encode($redis_data));
-                        }
-                    }
-                }
-            }
-        },'id', 'asc');
-
-    }
-
-    /**
-     * 发放hash
-     * @url /api/Timedtask/sendHash
-     */
-    public function sendHash(){
-        set_time_limit(0);
-        Db::name('store_order_info')
-            ->whereNotNull('company_hash')
-            ->whereIn('status','1,3')
-            ->where('company_hash','neq','')
-            ->where('type',1)
-            ->where('collectors_hash','eq','')
-            ->chunk('20',function ($list){
-                $from = '0x3153052307c15c46abb7b3667cdbcd48a7e2a341';
-                $redis = new Redis();
-                foreach ($list as &$v){
-                    if ($v['status']==1){
-                        $mid = $v['mid'];
-                    }elseif ($v['status']==3){
-                        $from = Db::name('store_member')->where('id',$v['to_mid'])->value('wallet_address');
-                        $mid = $v['to_mid'];
-                    }
-
-                    $to = Db::name('store_member')->where('id',$mid)->value('wallet_address');
-                    if (empty($to) || $to == ''){
-                        continue;
-                    }
-                    if ($this->redisNonceSetNx()){
-                        $ddcid = $v['ddcid'];
-                        $url = "http://47.111.246.47:8083/ddc/transferAutoNonce?from=$from&to=$to&ddcid=".$ddcid;
-                        $res=curlRequest($url);
-                        $result=json_decode($res,true);
-                        if($result['code']){
-                            continue;
-                        }else{
-                            Db::name('store_order_info')
-                                ->where('id',$v['id'])
-                                ->update(['collectors_hash'=>$res,'collectors_hash_time'=>date('Y-m-d H:i:s')]);
-                            $redis->del('noncenx');
-                        }
-                    }
-                }
-            },'id','desc');
-    }
-
-
-    /**
-     * @title 创建链账户
-     * @desc  创建链账户
-     * @author  Gavin
-     * @url /api/Timedtask/createAddress
-     * @method GET
-     */
-    public function createAddress(){
-        set_time_limit(0);
-        $member = Db::name('store_member')
-            ->whereNull('wallet_address')
-            ->field('id,offline_account,phone,wallet_address')->order('id asc')->limit(30)->select();
-        foreach ($member as &$v){
-            $url = 'http://47.111.246.47:8083/ddc/createAccount';
-            $offlineaccount = file_get_contents($url);
-            echo $offlineaccount;
-            $offline_account = json_decode($offlineaccount,true);
-            $address = $offline_account['address'];
-            $phone =$v['phone'];
-            //$phone .= rand(10000,99999);
-            $url = "http://47.111.246.47:8083/ddc/createAddress?name=".$phone."&account=".$address;
-            $res=curlRequest($url);
-            $laddress = json_decode($res,true);
-            dump($laddress);
-            if ($laddress['code']==0){
-                $wallet_address = $laddress['data']['opbChainClientAddress'];
-                Db::name('store_member')->where('id',$v['id'])
-                    ->update(['accountName'=>$phone,'wallet_address'=>$wallet_address,'offline_account'=>$offlineaccount]);
-            }
-        }
-
-    }
-
-    /**
-     * redis 加锁
-     */
-    function redisCreateSetNx($id){
-        $redis = new Redis();
-        $key = 'hash_'.$id;
-        $exptime = 450;
-        $is_lock = $redis->setnx($key,time()+$exptime);
-        if ($is_lock){
-            return true;
-        }else{
-            //加锁失败的情况下,判断锁是否已经存在,如果存在切已经过期,删除锁,重新加锁
-            $val = $redis->get($key);
-            if ($val && $val<time()){
-                $redis->del($key);
-            }
-            return $redis->setnx($key,time()+$exptime);
-        }
-    }
-
-
-    /**
-     * redis  nonce加锁
-     */
-    function redisNonceSetNx(){
-        $redis = new Redis();
-        $key = 'noncenx';
-        $exptime = 10;
-        $is_lock = $redis->setnx($key,time()+$exptime);
-        if ($is_lock){
-            return true;
-        }else{
-            //加锁失败的情况下,判断锁是否已经存在,如果存在切已经过期,删除锁,重新加锁
-            $val = $redis->get($key);
-            if ($val && $val<time()){
-                $redis->del($key);
-            }
-            return $redis->setnx($key,time()+$exptime);
-        }
-    }
-
-}

+ 0 - 151
application/api/controller/Upload.php

@@ -1,151 +0,0 @@
-<?php
-
-// +----------------------------------------------------------------------
-// | ThinkAdmin
-// +----------------------------------------------------------------------
-// | 版权所有 2014~2019 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
-// +----------------------------------------------------------------------
-// | 官方网站: http://demo.thinkadmin.top
-// +----------------------------------------------------------------------
-// | 开源协议 ( https://mit-license.org )
-// +----------------------------------------------------------------------
-// | gitee 代码仓库:https://gitee.com/zoujingli/ThinkAdmin
-// | github 代码仓库:https://github.com/zoujingli/ThinkAdmin
-// +----------------------------------------------------------------------
-
-namespace app\api\controller;
-
-use library\File;
-
-/**
- * @title OSS对象存储
- * @controller Upload
- * @group common
- */
-class Upload extends Base
-{
-    protected $id= 'LTAI5t76oDeTRvdNWZjs4oGd';
-    protected $key= '8Z1zyFjtaF4v9kdjJeWnlFVx3xhtEF';
-    protected $host = 'https://shuzisc.oss-cn-beijing.aliyuncs.com';
-
-    /**
-     * @title 文件上传
-     * @desc 文件上传
-     * @author qc
-     * @url /api/Upload/upload
-     * @method POST
-     * @tag 文件上传
-     */
-
-    public function upload()
-    {
-        if (!($file = $this->getUploadFile()) || empty($file)) {
-            $this->error('文件上传异常,文件可能过大或未上传!');
-        }
-        if (!$file->checkExt(strtolower(sysconf('storage_local_exts')))) {
-            $this->error('文件上传类型受限,请在后台配置!');
-        }
-        if ($file->checkExt('php,sh')) {
-            $this->error('可执行文件禁止上传到本地服务器!');
-        }
-        $this->safe = boolval(input('safe'));
-        $this->uptype = $this->getUploadType();
-        $this->extend = pathinfo($file->getInfo('name'), PATHINFO_EXTENSION);
-        $name = File::name($file->getPathname(), $this->extend, '', 'md5_file');
-        $info = File::instance($this->uptype)->save($name, file_get_contents($file->getRealPath()), $this->safe);
-        if (is_array($info) && isset($info['url'])) {
-            $url = $this->safe ? $name : $info['url'];
-            $this->success('上传成功',$url);
-        } else {
-            $this->error('文件处理失败,请稍候再试!');
-        }
-    }
-    /**
-     * 获取本地文件对象
-     * @return \think\File
-     */
-    private function getUploadFile()
-    {
-        try {
-            return $this->request->file('file');
-        } catch (\Exception $e) {
-            $this->error(lang($e->getMessage()));
-        }
-    }
-
-    /**
-     * 获取文件上传方式
-     * @return string
-     * @throws \think\Exception
-     * @throws \think\exception\PDOException
-     */
-    private function getUploadType()
-    {
-        $this->uptype = input('uptype');
-        if (!in_array($this->uptype, ['local', 'oss', 'qiniu'])) {
-            $this->uptype = sysconf('storage_type');
-        }
-        return $this->uptype;
-    }
-    /**
-     * @title 获取配置
-     * @desc 获取配置
-     * @author QGF
-     * @url /api/Upload/getSignedUrl
-     * @method GET
-     * @tag 配置信息
-     * @param name:type type:string require:1 default:-- desc:
-     */
-    public function getSignedUrl(){
-
-        $type=$this->request->get('type');
-        $data=$this->getPolicy($type.'/');
-        $this->success('操作成功',$data);
-    }
-
-    public function getPolicy($path,$maxSize=5000000){
-        $now = time();
-        $expire = 600; //设置该policy超时时间是10s. 即这个policy过了这个有效时间,将不能访问
-        $end = $now + $expire;
-        $expiration = $this->_gmt_iso8601($end);
-        $policy = [
-            'expiration'=>$expiration,
-            'conditions'=>[
-                ['content-length-range', 1, $maxSize],
-                ['starts-with', '$key', $path],
-            ]
-        ];
-        $policy = json_encode($policy);
-        $policy = base64_encode($policy);
-        $signature = base64_encode(hash_hmac('sha1', $policy, $this->key, true));
-
-        $response = array();
-        $response['OSSAccessKeyId'] = $this->id;
-        $response['policy'] = $policy;
-        $response['Signature'] = $signature;
-        $response['host'] = $this->host;
-        $response['expire'] = $end;
-        $response['success_action_status'] = 200;
-        //这个参数是设置用户上传指定的前缀
-        $response['key'] = $path;
-        return $response;
-    }
-    protected function _gmt_iso8601($time) {
-        $dtStr = date("c", $time);
-        $mydatetime = new \DateTime($dtStr);
-        $expiration = $mydatetime->format(\DateTime::ISO8601);
-        $pos = strpos($expiration, '+');
-        $expiration = substr($expiration, 0, $pos);
-        return $expiration."Z";
-    }
-
-
-    public function getSysDirection()
-    {
-        $data = [
-            'film_notice'=>htmlspecialchars_decode(sysconf('film_notice')),
-            'film_direction'=>htmlspecialchars_decode(sysconf('film_direction'))
-        ];
-        $this->success('获取成功',$data);
-    }
-}

+ 0 - 1279
application/api/controller/UserCenter.php

@@ -1,1279 +0,0 @@
-<?php
-namespace app\api\controller;
-use AlibabaCloud\Client\AlibabaCloud;
-use AlibabaCloud\Client\Exception\ClientException;
-use AlibabaCloud\Client\Exception\ServerException;
-use app\common\library\AliPay2;
-use think\cache\driver\Redis;
-use think\Db;
-/**
- * @title 会员个人中心
- * @controller UserCenter
- * @group base
- */
-class UserCenter extends Base
-{
-    public function initialize()
-    {
-        parent::initialize();
-//        parent::check_login();
-    }
-
-    /**
-     * @title 获取个人信息
-     * @desc 个人信息
-     * @author Gavin
-     * @url /api/User_center/getUserInfo
-     * @method POST
-     * @tag 个人信息
-     * @header name:Authorization require:1 desc:Token
-     * @return name:id type:int default:-- desc:ID(邀请ID)
-     * @return name:phone type:string default:-- desc:手机号
-     * @return name:name type:string default:-- desc:昵称
-     * @return name:headimg type:string default:-- desc:头像地址
-     * @return name:integral type:int default:-- desc:积分
-     * @return name:snap_card type:int default:-- desc:抢购卡
-     * @return name:wallet_address type:int default:-- desc:钱包地址
-     * @return name:true_name type:string default:-- desc:真实姓名
-     * @return name:id_card type:string default:-- desc:身份证号
-     * @return name:is_auth type:int default:-- desc:是否认证(0否1是)
-     * @return name:auth_at type:string default:-- desc:认证时间
-     * @return name:vip_name type:int default:-- desc:身份
-     * @return name:is_order_no_paid type:string default:-- desc:是否有未支付订单true:有false:没有
-     * @return name:is_sign type:string default:-- desc:今日是否已经签到true:已签到false:未签到
-     * @return name:invite_img type:string default:-- desc:邀请二维码
-     * @return name:invite_address type:string default:-- desc:邀请地址
-     * @return name:lucky_number type:int default:-- desc:剩余抽奖次数
-     * @return name:money type:string default:-- desc:余额
-     */
-    public function getUserInfo()
-    {
-        parent::check_login();
-        $uid = $this->uid;
-        $user_info = Db::name('store_member')
-            ->field('password,second_password',true)
-            ->where('id',$uid)
-            ->find();
-        if(empty($user_info)) $this->error('用户信息不正确');
-        $user_info['vip_name'] = $user_info['vip']==1 ? "藏友" : "创世勋章";
-        //是否有待支付订单
-        $order = Db::name('store_order')->where('status',0)->where('is_deleted',0)->where('mid',$uid)->count();
-        $user_info['is_order_no_paid'] = $order ? true : false;
-        //今日是否签到
-        $date = date('Y-m-d');
-        $sign = Db::name('store_member_sign')->where('mid',$uid)->where('date',$date)->count();
-        $user_info['is_sign'] = $sign ? true : false;
-        //获取每日免费次数
-        $free_number = getConfigValue('free_lucky_number');
-        //获取当日免费抽奖记录
-        $date = date('Y-m-d');
-        $now_date_count = Db::name('store_blind_box_log')->where('m_id',$this->uid)->where('date',$date)->where('is_free',0)->count();
-        $lucky_number = $user_info['lottery_number'] + ($free_number-$now_date_count);
-        $user_info['lucky_number'] =$lucky_number<=0 ? 0 : $lucky_number;
-        $user_info['id'] = (string)$user_info['id'];
-
-        //生成邀请码
-
-        if (!$user_info['invite_img'] || !$user_info['invite_address']){
-            $code = $user_info['invite_code'];
-            $invite_img = setintivecode($code);
-            $invite_address = getintiveaddress($code);
-            Db::name('store_member')->where('id',$this->uid)->update(['invite_img'=>$invite_img,'invite_address'=>$invite_address]);
-        }
-
-        $user_info['invite_img'] = str_replace('http:','https:',$user_info['invite_img']);
-
-        if (!$user_info['wallet_address']){
-            $name = $user_info['phone'];
-            $operationId = $user_info['phone'];
-            $operationId .= rand(10000,99999);
-            $url = getIpAddress()."customNFT/createAccount?name=".$name."&operationId=".$operationId;
-            $offlineaccount = file_get_contents($url);
-            $offline_account = json_decode($offlineaccount,true);
-            if (isset($offline_account) && isset($offline_account['account'])){
-                Db::name('store_member')->where('id',$user_info['id'])
-                    ->update(['accountName'=>$operationId,'wallet_address'=>$offline_account['account'],'offline_account'=>$offlineaccount]);
-            }
-        }
-
-        $this->success('获取成功',$user_info);
-    }
-
-    /**
-     * @title 绑定opendid
-     * @desc 绑定opendid
-     * @author Gavin
-     * @url /api/User_center/bindOpenid
-     * @method POST
-     * @tag 编辑信息
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param name:code type:string require:0 default:-- desc:code
-     */
-    public function bindOpenid()
-    {
-        parent::check_login();
-        $code = input('code');
-        if(empty($code)) $this->error('参数错误');
-        $appid = getConfigValue('wechat_appid');
-        $secret = getConfigValue('wechat_appsecret');
-        $res = http_get('https://api.weixin.qq.com/sns/oauth2/access_token?appid='.$appid.'&secret='.$secret.'&code='.$code.'&grant_type=authorization_code');
-        $res = json_decode($res,true);
-        if (isset($res['openid'])){
-            $update_data['openid'] = $res['openid'];
-            $update_data['update_at'] = date('Y-m-d H:i:s');
-            if (Db::name('store_member')->where('id',$this->uid)->update($update_data)){
-                setMemberInfoHash($this->uid);
-                $this->success('绑定成功');
-            }
-            $this->error('绑定失败');
-        }else{
-            $this->error('获取openid失败');
-        }
-    }
-
-
-    /**
-     * @title 编辑个人信息
-     * @desc 编辑个人信息
-     * @author Gavin
-     * @url /api/User_center/updateUserInfo
-     * @method POST
-     * @tag 编辑信息
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param name:name type:string require:0 default:-- desc:姓名
-     * @param name:headimg type:string require:0 default:-- desc:头像地址
-     */
-    public function updateUserInfo()
-    {
-        parent::check_login();
-        $headimg  = input('post.headimg');
-        $name     = trim(input('post.name',''));
-        if(!$headimg && !$name)   $this->error('参数错误');
-        $update_data= [];
-        if($name) $update_data['name'] = $name;
-        if ($headimg) $update_data['headimg'] = $headimg;
-        if($name){
-            $check_member =  Db::name('store_member')
-                ->where('name',$name)
-                ->where('id','<>',$this->uid)
-                ->count();
-            if($check_member) $this->error('该用户名已被占用');
-        }
-        $update_data['update_at'] = date('Y-m-d H:i:s');
-        if (Db::name('store_member')->where('id',$this->uid)->update($update_data)){
-            setMemberInfoHash($this->uid);
-            $this->success('编辑成功');
-        }
-        $this->error('编辑失败');
-    }
-
-
-    /**
-     * @title 绑定支付宝
-     * @desc 绑定支付宝
-     * @author Gavin
-     * @url /api/User_center/bind_zfb
-     * @method POST
-     * @tag 编辑信息
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param name:account type:string require:0 default:-- desc:支付宝账号
-     * @param name:zfb_real_name type:string require:0 default:-- desc:真实姓名
-     */
-    public function bind_zfb(){
-        parent::check_login();
-        $this->check_login();
-        $account = input('account');    //账号
-        $real_name = input('real_name'); //真实姓名
-        if (!$account) $this->error('支付宝账号为空');
-        if (!$real_name) $this->error('真实姓名为空');
-        $update_data['zfb_account'] = $account;
-        $update_data['zfb_real_name'] = $real_name;
-        $update_data['update_at'] = date('Y-m-d H:i:s');
-        if (Db::name('store_member')->where('id',$this->uid)->update($update_data)){
-            setMemberInfoHash($this->uid);
-            $this->success('绑定成功');
-        }
-        $this->error('绑定失败');
-    }
-
-    /**
-     * @title 实名认证
-     * @desc 实名认证
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/userCertification
-     * @header name:Authorization require:1 desc:Token
-     * @param name:true_name type:string require:1 default:-- desc:真实姓名
-     * @param name:id_card type:string require:1 default:-- desc:身份证号
-     */
-    public function userCertification(){
-        $this->error('没有实名认证');
-        parent::check_login();
-        //redis原子锁
-        if (redisSetNx('userCertification'.$this->uid,2)){
-            $true_name = input('post.true_name');
-            $id_card = input('post.id_card');
-            $bank_card = input('post.bank_card');
-            $bank_mobile = input('post.bank_mobile');
-            if (!$true_name || !$id_card || !$bank_card) $this->error('参数错误');
-            $check_id_card = isCreditNo($id_card);
-            //获取年龄
-            $age = getAge($id_card);
-            if (!$check_id_card) $this->error('身份证号格式错误');
-           // if (!checkbank($bank_card)) $this->error('银行卡号格式错误');
-            if ($age<18 || $age>65) $this->error('年龄不合规');
-            $is_auth = Db::table('store_member')->where('id',$this->uid)->value('is_auth');
-            if($is_auth) $this->error('已认证');
-            $check = Db::name('store_member')->where('id_card',$id_card)->count();
-            if ($check) $this->error('身份证号已经认证过');
-            $bank_check = Db::name('store_member')->where('bank_card',$bank_card)->count();
-            if ($bank_check) $this->error('银行卡号已经使用过');
-
-            //四要素
-            $res = idcardlingyufour($id_card,$true_name,$bank_card,$bank_mobile);
-            if (!$res['success']) $this->error($res['remark']);
-
-            if (Db::table('store_member')->where('id',$this->uid)->update(['is_auth'=>1,'true_name'=>$true_name,'id_card'=>$id_card,'auth_at'=>date('Y-m-d H:i:s')])){
-                setMemberInfoHash($this->uid);
-
-                $user1 = getMemberInfoHash($this->uid); //获取用户信息
-                if ($user1['pid']){
-                    $data = [
-                        'mid'=>$user1['pid'],
-                        'to_mid'=>$this->uid,
-                        'create_at'=>date('Y-m-d H:i:s')
-                    ];
-                    Db::name('store_activities_invite_log')->insert($data);
-                }
-
-                //拉新奖励
-                //pullNew($this->uid);
-                pull_new($this->uid);
-                DelRedisSetNx('userCertification'.$this->uid);
-                $this->success('认证成功');
-            }
-            DelRedisSetNx('userCertification'.$this->uid);
-            $this->error('认证失败');
-        }else{
-            $this->error('请求过快');
-        }
-
-    }
-
-    /**
-     * @title 修改密码
-     * @desc 修改密码
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/updatePass
-     * @header name:Authorization require:1 desc:Token
-     * @param name:old_password type:string require:1 default:-- desc:旧密码
-     * @param name:new_password type:string require:1 default:-- desc:新密码
-     * @param name:confirm_password type:string require:1 default:-- desc:确认密码
-     */
-    public function updatePass()
-    {
-        parent::check_login();
-        $old_password = input('post.old_password');
-        $new_password = input('post.new_password');
-        $confirm_password = input('post.confirm_password');
-       // $yzm = input('post.yzm');
-        if (!$old_password || !$new_password || !$confirm_password) $this->error('参数错误');
-        if ($new_password!=$confirm_password) $this->error('密码与确认密码不一致');
-        if (!preg_match('/^[0-9a-z]{6,12}$/i',$new_password)) $this->error('密码格式错误,请输入6-12位数字+字母');
-        $member = Db::name('store_member')->where('id',$this->uid)->find();
-
-        //验证短信验证码
-//        $time = time()-60;
-//        $sms = Db::name('store_sms')->where(['mobile' => $member['phone'], 'event' => 'forgetpwd'])
-//            ->where('createtime','>',$time)
-//            ->order('id', 'DESC')
-//            ->find();
-//        if (!$sms || $sms['code'] != $yzm) $this->error('短信验证码不正确!');
-
-        if ($member['password']!=md5($old_password)) $this->error('旧密码错误');
-        $data['password'] = md5($new_password);
-        $data['update_at'] = date('Y-m-d H:i:s');
-        if (Db::name('store_member')->where('id',$this->uid)->update($data)){
-            setMemberInfoHash($this->uid);
-            $this->success('修改成功');
-        }
-        $this->error('修改失败');
-    }
-
-    /**
-     * @title 修改二级密码
-     * @desc 修改二级密码
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/updateSecondPass
-     * @header name:Authorization require:1 desc:Token
-     * @param name:second_password type:string require:1 default:-- desc:二级密码
-     * @param name:confirm_second_password type:string require:1 default:-- desc:确认密码
-     */
-    public function updateSecondPass()
-    {
-        parent::check_login();
-        $second_password = input('post.second_password');
-        $confirm_second_password = input('post.confirm_second_password');
-        $yzm = input('post.yzm');
-        if (!$second_password || !$confirm_second_password) $this->error('参数错误');
-        if ($second_password!=$confirm_second_password) $this->error('密码与确认密码不一致');
-        if (!preg_match('/^[0-9]{6}$/i',$second_password)) $this->error('二级密码格式错误,请输入6位纯数字');
-
-        $member = getMemberInfoHash($this->uid); //获取用户信息
-        //验证短信验证码
-        $time = time()-60;
-        $sms = Db::name('store_sms')->where(['mobile' => $member['phone'], 'event' => 'forgetpwd'])
-            ->where('createtime','>',$time)
-            ->order('id', 'DESC')
-            ->find();
-        if (!$sms || $sms['code'] != $yzm) $this->error('短信验证码不正确!');
-
-        $data['second_password'] = md5($second_password);
-        $data['update_at'] = date('Y-m-d H:i:s');
-        if (Db::name('store_member')->where('id',$this->uid)->update($data)){
-            setMemberInfoHash($this->uid);
-            $this->success('修改成功');
-        }
-        $this->error('修改失败');
-    }
-
-    /**
-     * @title 我的藏品
-     * @desc 我的藏品
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/myCollection
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @return  name:id type:int require:0 default:0 desc:藏品ID
-     * @return  name:tag type:strin require:0 default:0 desc:唯一标签
-     * @return  name:name type:string require:0 default:0 desc:藏品名称
-     * @return  name:cover type:string require:0 default:0 desc:藏品图片
-     * @return  name:auth_img type:string require:0 default:0 desc:作者头像
-     * @return  name:auth_name type:string require:0 default:0 desc:作者名称
-     */
-    public function myCollection(){
-        parent::check_login();
-
-        $type = input('type');
-        $where = [
-            'mid'=>$this->uid,
-            'is_destruction'=>1,
-            'resale_status'=>1
-        ];
-        $cids = Db::name('store_order_info')->where($where)
-            ->where('status','neq','2')
-            ->when($type,function ($query) use ($type){
-                if ($type==1){
-                    $query->where('type','neq',3);
-                }else{
-                    $query->where('type',3);
-                }
-            })
-            ->group('c_id')
-            ->column('c_id');
-        $arr = [];
-        foreach ($cids as &$v){
-            $array['c_id'] = $v;
-            $array['count'] = Db::name('store_order_info')
-                ->where($where)
-                ->when($type,function ($query) use ($type){
-                    if ($type==1){
-                        $query->where('type','neq',3);
-                    }else{
-                        $query->where('type',3);
-                    }
-                })
-                ->where('c_id',$v)
-                ->where('status','neq','2')
-                ->count();
-            $info = Db::name('store_order_info')
-                ->where($where)->where('c_id',$v)
-                ->limit(1)
-                ->field('id,name,cover,tag,pro_info')
-                ->find();
-            $array['cover'] = $info['cover'];
-            $array['name'] = $info['name'];
-            $pro_info = json_decode($info['pro_info'],true);
-            $array['auth_img'] = $pro_info['auth_img'];
-            $array['auth_name'] = $pro_info['auth_name'];
-            $tag = explode('#',$info['tag']);
-            $tag2 = explode('/',$tag[1]);
-            $array['tag'] = $tag[0].'#???'.'/'.$tag2[1];
-            array_push($arr,$array);
-        }
-        $this->success('成功',$arr);
-
-
-        $list = Db::name('store_order_info')
-            ->where('mid',$this->uid)
-            ->when($type,function ($query) use ($type){
-                if ($type==1){
-                    $query->where('type','neq',3);
-                }else{
-                    $query->where('type',3);
-                }
-            })
-            ->where('status','neq','2')
-            ->where('is_destruction',1)
-            ->where('resale_status',1)
-            ->field('id,tag,pro_info,c_id')
-            ->order('id desc')
-            ->select();
-        foreach ($list as &$v){
-            $pro_info = json_decode($v['pro_info'],true);
-            $v['name'] = $pro_info['name'];
-            $v['cover'] = $pro_info['cover'];
-            $v['auth_img'] = $pro_info['auth_img']? $pro_info['auth_img'] : Db::name('store_collection')->where('id',$v['c_id'])->value('auth_img');
-            $v['auth_name'] = $pro_info['auth_name'] ? $pro_info['auth_name'] : Db::name('store_collection')->where('id',$v['c_id'])->value('auth_name');
-            if ($v['tag']){
-                $tag = explode('#',$v['tag']);
-                $tag1 = substr($tag[0],0,6);
-                $v['tag'] = $tag1.'#'.$tag[1];
-            }
-            unset($v['pro_info']);
-        }
-        $this->success('成功',$list);
-    }
-
-
-
-
-    /**
-     * @title 藏品列表
-     * @desc 藏品列表
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/myCollectionList
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param name:c_id type:string require:1 default:-- desc:藏品ID
-     *
-     * @return  name:id type:int require:0 default:0 desc:藏品ID
-     * @return  name:tag type:string require:0 default:0 desc:唯一标签
-     * @return  name:name type:string require:0 default:0 desc:藏品名称
-     * @return  name:cover type:string require:0 default:0 desc:藏品图片
-     * @return  name:auth_img type:string require:0 default:0 desc:作者头像
-     * @return  name:auth_name type:string require:0 default:0 desc:作者名称
-     */
-    public function myCollectionList(){
-        parent::check_login();
-
-        $c_id = input('c_id');
-        if (!$c_id) $this->error('参数错误');
-        $list = Db::name('store_order_info')
-            ->where('mid',$this->uid)
-            ->where('status','neq','2')
-            ->where('c_id',$c_id)
-            ->where('is_destruction',1)
-            ->where('resale_status',1)
-            ->field('id,tag,pro_info')
-            ->order('id desc')
-            ->select();
-        foreach ($list as &$v){
-            $pro_info = json_decode($v['pro_info'],true);
-            $v['name'] = $pro_info['name'];
-            $v['cover'] = $pro_info['cover'];
-            $v['auth_img'] = $pro_info['auth_img'];
-            $v['auth_name'] = $pro_info['auth_name'];
-            unset($v['pro_info']);
-        }
-        $this->success('成功',$list);
-    }
-
-
-
-
-
-
-    /**
-     * @title 我的藏品
-     * @desc 我的藏品
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/myCollection
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @return  name:id type:int require:0 default:0 desc:藏品ID
-     * @return  name:tag type:string require:0 default:0 desc:唯一标签
-     * @return  name:name type:string require:0 default:0 desc:藏品名称
-     * @return  name:cover type:string require:0 default:0 desc:藏品图片
-     * @return  name:auth_img type:string require:0 default:0 desc:作者头像
-     * @return  name:auth_name type:string require:0 default:0 desc:作者名称
-     */
-    public function myCollection2(){
-        parent::check_login();
-        $type = input('type');
-        $list = Db::name('store_order_info')
-            ->where('mid',$this->uid)
-            ->when($type,function ($query) use ($type){
-                if ($type==1){
-                    $query->where('type','neq',3);
-                }else{
-                    $query->where('type',3);
-                }
-            })
-            ->where('status','neq','2')
-            ->where('is_destruction',1)
-            ->where('resale_status',1)
-            ->field('id,tag,pro_info,c_id')
-            ->order('id desc')
-            ->select();
-        foreach ($list as &$v){
-            $pro_info = json_decode($v['pro_info'],true);
-            $v['name'] = $pro_info['name'];
-            $v['cover'] = $pro_info['cover'];
-            $v['auth_img'] = $pro_info['auth_img']? $pro_info['auth_img'] : Db::name('store_collection')->where('id',$v['c_id'])->value('auth_img');
-            $v['auth_name'] = $pro_info['auth_name'] ? $pro_info['auth_name'] : Db::name('store_collection')->where('id',$v['c_id'])->value('auth_name');
-            if ($v['tag']){
-                $tag = explode('#',$v['tag']);
-                $tag1 = substr($tag[0],0,6);
-                $v['tag'] = $tag1.'#'.$tag[1];
-            }
-            unset($v['pro_info']);
-        }
-        $this->success('成功',$list);
-    }
-
-    /**
-     * @title 我的盲盒
-     * @desc 我的盲盒
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/myBoxCollection
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @return  name:id type:int require:0 default:0 desc:藏品ID
-     * @return  name:tag type:string require:0 default:0 desc:唯一标签
-     * @return  name:name type:string require:0 default:0 desc:藏品名称
-     * @return  name:cover type:string require:0 default:0 desc:藏品图片
-     * @return  name:auth_img type:string require:0 default:0 desc:作者头像
-     * @return  name:auth_name type:string require:0 default:0 desc:作者名称
-     */
-    public function myBoxCollection(){
-        parent::check_login();
-        $list = Db::name('store_order_info')
-            ->where('mid',$this->uid)
-            ->where('status','neq','2')
-            ->where('type',3)
-            ->where('is_destruction',1)
-            ->where('resale_status',1)
-            ->field('id,tag,pro_info')
-            ->order('id desc')
-            ->select();
-        foreach ($list as &$v){
-            $pro_info = json_decode($v['pro_info'],true);
-            $v['name'] = $pro_info['name'];
-            $v['cover'] = $pro_info['cover'];
-            $v['auth_img'] = $pro_info['auth_img'];
-            $v['auth_name'] = $pro_info['auth_name'];
-            unset($v['pro_info']);
-        }
-        $this->success('成功',$list);
-    }
-
-    /**
-     * @title 藏品详情
-     * @desc 藏品详情
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/myCollectionDetail
-     * @header name:Authorization require:1 desc:Token
-     * @param name:id type:int require:1 default:-- desc:藏品ID
-     *
-     * @return  name:id type:int require:0 default:0 desc:藏品ID
-     * @return  name:tag type:string require:0 default:0 desc:唯一标签
-     * @return  name:collectors_name type:string require:0 default:0 desc:收藏者
-     * @return  name:collectors_hash type:string require:0 default:0 desc:收藏者hash
-     * @return  name:create_at type:string require:0 default:0 desc:收藏时间
-     * @return  name:company type:string require:0 default:0 desc:流转公司
-     * @return  name:company_hash type:string require:0 default:0 desc:流转公司hash
-     * @return  name:examples_illustrate type:string require:0 default:0 desc:转赠说明
-     * @return  name:pro_info@name type:string require:0 default:0 desc:藏品名称
-     * @return  name:pro_info@price type:string require:0 default:0 desc:藏品价格
-     * @return  name:pro_info@label type:string require:0 default:0 desc:藏品标签
-     * @return  name:pro_info@cover type:string require:0 default:0 desc:藏品图片
-     * @return  name:pro_info@auth_img type:string require:0 default:0 desc:作者头像
-     * @return  name:pro_info@auth_name type:string require:0 default:0 desc:作者姓名
-     * @return  name:pro_info@warm_prompt type:string require:0 default:0 desc:温馨提示
-     * @return  name:pro_info@share_img type:string require:0 default:0 desc:分享二维码
-     */
-    public function myCollectionDetail(){
-        parent::check_login();
-        $id = input('id');
-        if (!$id) $this->error('参数错误');
-        $info = Db::name('store_order_info')
-            ->where('mid',$this->uid)
-            ->where('id',$id)
-            ->find();
-        if (!$info) $this->error('藏品不存在');
-        $info['pro_info'] = json_decode($info['pro_info'],true);
-        if (!isset($info['pro_info']['share_img'])){
-            $info['pro_info']['share_img'] = Db::name('store_collection')->where('id',$info['pro_info']['id'])->value('share_img');
-        }
-
-        $issuer = Db::name('store_collection')->where('id',$info['c_id'])->value('issuer');
-        if (!empty($issuer)){
-            $info['company'] = $issuer;
-        }
-
-
-        $info['detail_img'] = $info['pro_info']['detail_img'];
-        $info['format'] = $info['pro_info']['format'];
-        $info['collectors_name'] = Db::name('store_member')->where('id',$this->uid)->value('name');
-        //$info['collectors_hash'] = $info['collectors_hash']=='' ? "发放中" : $info['collectors_hash'];
-        $info['collectors_hash_time'] = $info['collectors_hash_time']=='' ? "发放中" : $info['collectors_hash_time'];
-        $info['examples_illustrate'] = Db::table('system_config')->where('name','examples_illustrate')->value('value');
-        $info['c_id'] = (string)$info['c_id'];
-
-        if (!empty($info['tag'])){
-            $tag = explode('#',$info['tag']);
-            $tag1 = substr($tag[0],0,6);
-            $info['tag'] = $tag1.'#'.$tag[1];
-        }
-
-        $info['pro_info']['auth_name'] = $info['pro_info']['auth_name'] ? $info['pro_info']['auth_name'] : Db::name('store_collection')->where('id',$info['c_id'])->value('auth_name');
-        $info['pro_info']['auth_img'] = $info['pro_info']['auth_img'] ? $info['pro_info']['auth_img'] : Db::name('store_collection')->where('id',$info['c_id'])->value('auth_img');
-
-
-        if ($info['collectors_hash_time']!='0000-00-00 00:00:00'){
-            $info['create_at'] = $info['collectors_hash_time'];
-        }
-
-
-        $this->success('成功',$info);
-    }
-
-
-    /**
-     * @title 转赠
-     * @desc 转赠
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/examples
-     * @header name:Authorization require:1 desc:Token
-
-     * @param name:id type:int require:1 default:-- desc:藏品ID
-     * @param name:phone type:string require:1 default:-- desc:手机号
-     * @param name:wallet_address type:int require:1 default:-- desc:钱包地址
-     * @param name:second_password type:int require:1 default:-- desc:二级密码
-     *
-     */
-    public function examples(){
-        parent::check_login();
-
-        //redis原子锁
-        if (redisSetNx('examples'.$this->uid,2)){
-            $v = getConfigValue('examples_switch');
-            if (!$v) $this->error('维护中,暂时关闭');
-
-            $id = input('id');
-            $phone = input('phone');
-            $wallet_address = input('wallet_address');
-            $second_password = input('second_password');
-            if (!$id || !$phone || !$wallet_address) $this->error('参数错误');
-            $info = Db::name('store_order_info')->where('id',$id)->where('mid',$this->uid)->find();
-            if (!$info) $this->error('藏品不存在');
-            if ($info['status']==2) $this->error('藏品已转赠');
-            $member = Db::name('store_member')->where('phone',$phone)->where('wallet_address',$wallet_address)->find();
-            if (!$member) $this->error('转赠用户不存在');
-            if ($member['id']==$this->uid) $this->error('不能转赠给自己');
-
-            if (!$info['collectors_hash']) $this->error('发放中,无法转赠');
-
-            $mem = getMemberInfoHash($this->uid);
-            if ($mem['second_password']!=md5($second_password)) $this->error('密码错误');
-
-            $pro_info = Db::name('store_collection')->where('id',$info['c_id'])->find();
-            $log = Db::name('store_collect_examples_log')
-                ->where('order_info_id',$id)
-                ->find();
-            if (!$log){
-                if ($pro_info['one_given_day']!=0){
-                    $exam_time = strtotime($info['create_at'])+($pro_info['one_given_day']*24*60*60);
-                    if ($exam_time>time()) $this->error('持有时间限制,无法转赠');
-                }
-            }else{
-                if ($pro_info['other_given_day']!=0){
-                    $exam_time = strtotime($log['create_at'])+($pro_info['other_given_day']*24*60*60);
-                    if ($exam_time>time()) $this->error('持有时间限制,无法转赠');
-                }
-            }
-            $com = true;
-            Db::startTrans();
-            try {
-                Db::name('store_order_info')
-                    ->where('id',$id)
-                    ->update(['status'=>2,'over_time'=>date('Y-m-d H:i:s'),'to_mid'=>$member['id']]);
-                $to_date = [
-                    'order_id'=>$info['order_id'],
-                    'order_no'=>get_order_sn(),
-                    'tag'=>$info['tag'],
-                    'mid'=>$member['id'],
-                    'c_id'=>$info['c_id'],
-                    'name'=>$pro_info['name'],
-                    'cover'=>$pro_info['cover'],
-                    'pro_info'=>$info['pro_info'],
-                    'type'=>$pro_info['type'],
-                    'status'=>3,
-                    'to_mid'=>$this->uid,
-                    'over_time'=>date('Y-m-d H:i:s'),
-                    'tokenid'=>$info['tokenid'],
-                    'nfttype'=>$info['nfttype'],
-                    'nftid'=>$info['nftid'],
-                    'collectors_hash'=>'',
-                    'collectors_hash_time'=>date('Y-m-d H:i:s')
-                ];
-                $new_id = Db::name('store_order_info')->insertGetId($to_date);
-                $log_date = [
-                    'order_info_id'=>$new_id,
-                    'mid'=>$this->uid,
-                    'to_mid'=>$member['id'],
-                    'date'=>date('Y-m')
-                ];
-                Db::name('store_collect_examples_log')->insert($log_date);
-                Db::commit();
-            }catch (\Exception $e){
-                $com = false;
-                Db::rollback();
-            }
-            if ($com){
-                DelRedisSetNx('examples'.$this->uid);
-                $this->success('转赠成功');
-            }
-            DelRedisSetNx('examples'.$this->uid);
-            $this->error('转赠失败');
-        }else{
-            $this->error('请求过快');
-        }
-    }
-
-    /**
-     * @title 消息列表
-     * @desc 消息列表
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/messageList
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param  name:page type:int  : default:1 desc:页数
-     * @param  name:page_num type:int  : default:20 desc:每页数
-     *
-     * @return  name:id type:int require:0 default:0 desc:消息ID
-     * @return  name:title type:string require:0 default:0 desc:标题
-     * @return  name:content type:string require:0 default:0 desc:内容
-     * @return  name:create_at type:string require:0 default:0 desc:发布时间
-     * @return  name:is_read type:string require:0 default:0 desc:是否查看true:已查看false:未查看
-     */
-    public function messageList(){
-        $count = Db::name('store_message')->where('is_deleted',0)->count();
-        $list = Db::name('store_message')
-            ->field('is_deleted,update_at',true)
-            ->where('is_deleted',0)
-            ->order('id desc')
-            ->limit($this->off_set,$this->page_num)
-            ->select();
-//        echo Db::name('store_message')->getLastSql();die;
-        foreach ($list as &$v){
-            $is_read = Db::name('store_message_read_log')->where('mid',$this->uid)->where('message_id',$v['id'])->count();
-            $v['is_read'] = $is_read ? true : false;
-        }
-        $this->success('成功',compact('count','list'));
-    }
-
-    /**
-     * @title 点击消息
-     * @desc 点击消息,查看消息
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/readMessage
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param  name:id type:int  : default:1 desc:消息ID
-     *
-     */
-    public function readMessage(){
-        $id = input('id');
-        if (!$id) $this->error('参数错误');
-        $log = Db::name('store_message_read_log')->where('message_id',$id)->where('mid',$this->uid)->count();
-        if (!$log){
-            $data = [
-                'mid'=>$this->uid,
-                'message_id'=>$id
-            ];
-            Db::name('store_message_read_log')->insert($data);
-        }
-        $this->success('成功');
-    }
-
-    /**
-     * @title 人脸认证sign
-     * @desc 人脸认证sign
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/getFaceSign
-     * @header name:Authorization require:1 desc:Token
-     *
-     *
-     * @param  name:name type:string  default:1 desc:姓名
-     * @param  name:idNo type:string  default:1 desc:身份证号
-     *
-     * @return  name:sign type:string require: default:-- desc:签名
-     *
-     */
-    public function getFaceSign(){
-        parent::check_login();
-        $name = input('name');
-        $idNo = input('idNo');
-        if (!$name || !$idNo) $this->error('参数错误');
-        $userId =  $this->uid;
-        //$userId = get32Str();
-        $data = getfaceid($name,$idNo,$userId);
-        $this->success('成功',$data);
-    }
-
-    /**
-     * @title 邀请记录
-     * @desc 邀请记录
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/invitedRecord
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param  name:page type:int  : default:1 desc:页数
-     * @param  name:page_num type:int  : default:20 desc:每页数
-     *
-     * @return  name:id type:int require:0 default:0 desc:用户ID
-     * @return  name:headimg type:string require:0 default:0 desc:头像
-     * @return  name:name type:string require:0 default:0 desc:名称
-     * @return  name:create_at type:string require:0 default:0 desc:时间
-     */
-    public function invitedRecord(){
-        parent::check_login();
-        $count = Db::name('store_member')
-            ->where('is_auth',1)
-            ->where('pid',$this->uid)->count();
-        $list = Db::name('store_member')
-            ->field('id,headimg,name,create_at,phone,is_auth')
-            ->where('pid',$this->uid)
-           // ->where('is_auth',1)
-            ->order('id desc')
-            ->limit($this->off_set,$this->page_num)
-            ->select();
-        foreach ($list as &$v){
-            $v['phone'] = substr_replace($v['phone'],'****',3,4);
-            $v['name'] =  substr($v['name'],0,16);
-            $v['create_at'] = date('Y-m-d',strtotime($v['create_at']));
-        }
-        $this->success('成功',compact('count','list'));
-    }
-
-    /**
-     * @title 邀请排行榜
-     * @desc 邀请排行榜
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/invitedList
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param  name:page type:int  : default:1 desc:页数
-     * @param  name:page_num type:int  : default:20 desc:每页数
-     *
-     * @return  name:id type:int require:0 default:0 desc:用户ID
-     * @return  name:headimg type:string require:0 default:0 desc:头像
-     * @return  name:name type:string require:0 default:0 desc:名称
-     * @return  name:phone type:string require:0 default:0 desc:手机号
-     * @return  name:create_at type:string require:0 default:0 desc:时间
-     */
-    public function invitedList(){
-
-        $count = Db::name('store_member as a')
-            ->field('a.id,a.name,a.headimg,a.phone,a.pid,(select count(b.id) from store_member as b where b.pid=a.id and b.is_auth=1) as count')
-            ->group('a.id')
-            ->having('count>0')
-            ->count();
-        $list = Db::name('store_member as a')
-            ->field('a.id,a.name,a.headimg,a.phone,a.pid,(select count(b.id) from store_member as b where b.pid=a.id  and b.is_auth=1) as count')
-            ->group('a.id')
-            ->having('count>0')
-            ->order('count desc')
-            ->limit($this->off_set,$this->page_num)
-            ->select();
-        $this->success('成功',compact('count','list'));
-    }
-
-    /**
-     * @title 签到
-     * @desc 签到
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/sign
-     * @header name:Authorization require:1 desc:Token
-     *
-     */
-    public function sign(){
-        parent::check_login();
-        $date = date('Y-m-d');
-        $log = Db::name('store_member_sign')->where('mid',$this->uid)->where('date',$date)->count();
-        if ($log) $this->error('今日已签到');
-        $data = [
-            'mid'=>$this->uid,
-            'date'=>$date
-        ];
-        $com = true;
-        Db::startTrans();
-        try {
-            $id = Db::name('store_member_sign')->insertGetId($data);
-            $sign_integral = getConfigValue('sign_integral');
-            if ($sign_integral>0){
-                memberMoneyChange($sign_integral,1,$this->uid,'签到',1,$id);
-            }
-            Db::commit();
-        }catch (\Exception $e){
-            $com=false;
-            Db::rollback();
-        }
-        if ($com){
-            $this->success('签到成功');
-        }
-        $this->error('签到失败');
-    }
-
-
-
-    /**
-     * @title 积分记录
-     * @desc 积分记录
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/integralLog
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param  name:page type:int  : default:1 desc:页数
-     * @param  name:page_num type:int  : default:20 desc:每页数
-     *
-     * @return  name:id type:int require:0 default:0 desc:id
-     * @return  name:change type:string require:0 default:0 desc:变动数值
-     * @return  name:title type:string require:0 default:0 desc:标题
-     * @return  name:create_at type:string require:0 default:0 desc:时间
-     */
-    public function integralLog(){
-        parent::check_login();
-        $where = [
-            'm_id'=>$this->uid,
-            'type'=>1
-        ];
-        $status = input('status');
-        $count = Db::name('store_member_log')
-            ->where($where)
-            ->when($status,function ($query) use ($status){
-                $pm = $status==1 ? 1 : 0;
-                $query->where('pm',$pm);
-            })
-            ->count();
-        $list = Db::name('store_member_log')
-            ->field('id,pm,change,title,create_at')
-            ->where($where)
-            ->when($status,function ($query) use ($status){
-                $pm = $status==1 ? 1 : 0;
-                $query->where('pm',$pm);
-            })
-            ->order('id desc')
-            ->limit($this->off_set,$this->page_num)
-            ->select();
-        foreach ($list as &$v){
-            if ($v['pm']==1){
-                $v['change'] = '+'.$v['change'];
-            }else{
-                $v['change'] = '-'.$v['change'];
-            }
-        }
-        $this->success('成功',compact('count','list'));
-    }
-
-
-    /**
-     * @title 余额记录
-     * @desc 余额记录
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/moneyLog
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param  name:page type:int  : default:1 desc:页数
-     * @param  name:page_num type:int  : default:20 desc:每页数
-     *
-     * @return  name:id type:int require:0 default:0 desc:id
-     * @return  name:change type:string require:0 default:0 desc:变动数值
-     * @return  name:title type:string require:0 default:0 desc:标题
-     * @return  name:create_at type:string require:0 default:0 desc:时间
-     */
-    public function moneyLog(){
-        parent::check_login();
-        $where = [
-            'm_id'=>$this->uid,
-            'type'=>3
-        ];
-        $count = Db::name('store_member_log')->where($where)->count();
-        $list = Db::name('store_member_log')
-            ->field('id,pm,change,title,create_at')
-            ->where($where)
-            ->order('id desc')
-            ->limit($this->off_set,$this->page_num)
-            ->select();
-        foreach ($list as &$v){
-            if ($v['pm']==1){
-                $v['change'] = '+'.$v['change'];
-            }else{
-                $v['change'] = '-'.$v['change'];
-            }
-        }
-        $this->success('成功',compact('count','list'));
-    }
-
-
-
-    /**
-     * @title 提现
-     * @desc 提现
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/withdraw
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param  name:money type:int  : default: desc:提现金额
-     * @param  name:withdraw_type type:int  : default: desc:提现方式
-     *
-     */
-    public function withdraw(){
-        parent::check_login();
-        //redis原子锁
-        if (redisSetNx('withdraw'.$this->uid,3)){
-            $v = getConfigValue('withdraw_switch');
-            if (!$v) $this->error('维护中,暂时关闭');
-            $money = input('money');
-            $withdraw_type = input('withdraw_type','wx');
-            if (!$money) $this->error('参数错误');
-            $user = Db::name('store_member')->where('id',$this->uid)->find();
-            if ($user['money']<$money) $this->error('余额不足');
-            $withdraw_min_price = getConfigValue('withdraw_min_price');  //最小提现金额
-            $withdraw_max_price = getConfigValue('withdraw_max_price');  //最大提现金额
-            $poundage_proportion = getConfigValue('poundage_proportion');    //手续费百分比
-
-            if ($money < $withdraw_min_price)
-                $this->error('最低提现'.$withdraw_min_price.'元');
-            if ($money > $withdraw_max_price)
-                $this->error('最大提现'.$withdraw_min_price.'元');
-
-            if ($withdraw_type=='zfb'){
-                if (!$user['zfb_account'] || !$user['zfb_real_name']) $this->error('请先绑定支付宝');
-            }
-
-            $data['mid'] = $this->uid;
-            $order_no = get_order_sn();
-            $data['order_no'] = $order_no;
-            $data['price'] = $money;
-            $data['poundage_proportion'] = $poundage_proportion;
-            $proportion = sprintf("%.2f", $money*($poundage_proportion/100));    //四舍五入保留两位小数点
-            $data['proportion'] = $proportion;
-            $real_money = $money-$proportion;
-            $data['real_money'] = $real_money;
-            $data['withdraw_type'] = $withdraw_type;
-            $id =Db::name('store_member_withdraw')->insertGetId($data);
-            if ($id){
-                Db::startTrans();
-                try {
-                    //减少用户余额
-                    $res = memberMoneyChange($money,3,$this->uid,'余额提现',0,$id);
-                    if ($res){
-                        switch ($withdraw_type){
-                            case 'zfb':
-                                $zfb = new AliPay2();//实例化支付宝支付控制器
-                                $result = $zfb->FundTransToaccount($order_no, $user['zfb_account'], $user['zfb_real_name'], $real_money,'余额提现');//调用支付宝支付的方法
-                                if (!empty($result) && $result['code'] == 10000){
-                                    Db::name('store_member_withdraw')->where('id',$id)->update(['paid'=>1,'pay_time'=>time(),'return_info'=>json_encode($result['result'],true)]);
-                                }else{
-                                    Db::name('store_member_withdraw')->where('id',$id)->update(['return_info'=>json_encode($result['result'],true)]);
-                                    Db::rollback();
-                                    $this->error('提现失败,请检查绑定的支付宝信息');
-                                }
-                                break;
-                        }
-                        Db::commit();
-                        DelRedisSetNx('withdraw'.$this->uid);
-                        $this->success('提现成功');
-                    }else{
-                        Db::rollback();
-                        DelRedisSetNx('withdraw'.$this->uid);
-                        $this->error('提现失败,请稍后重试');
-                    }
-                }catch (Exception $e) {
-                    Db::rollback();
-                    DelRedisSetNx('withdraw'.$this->uid);
-                    $this->error('提现失败,请稍后重试1');
-                }
-            }else{
-                DelRedisSetNx('withdraw'.$this->uid);
-                $this->error('提现失败,请稍后重试2');
-            }
-        }else{
-            $this->error('请求过快,请稍后重试');
-        }
-
-
-
-    }
-
-    /**
-     * @title 打开盲盒
-     * @desc 打开盲盒
-     * @author Gavin
-     * @method POST
-     * @tag 编辑信息
-     * @url /api/User_center/openBoxCollection
-     * @header name:Authorization require:1 desc:Token
-     *
-     * @param  name:id type:int  : default: desc:藏品ID
-     *
-     */
-    public function openBoxCollection(){
-        parent::check_login();
-        //redis原子锁
-        if (redisSetNx('openBox'.$this->uid,3)){
-            $id = input('id');
-            if (!$id) $this->error('参数错误');
-            $info = Db::name('store_order_info')
-                ->where('id',$id)
-                ->where('status','neq',2)
-                ->where('mid',$this->uid)
-                ->where('is_destruction',1)
-                ->find();
-            if (!$info) $this->error('盲盒不存在');
-            if ($info['resale_status']!=1) $this->error('盲盒挂售中或已出售');
-            $com = true;
-            Db::startTrans();
-            try {
-                //销毁
-                Db::name('store_order_info')->where('id',$id)->update(['is_destruction'=>0]);
-                checkBoxCollection($info['c_id']);
-                $prize_arr = Db::name('store_box')
-                    ->where('status',1)
-                    ->where('coll_id',$info['c_id'])
-                    ->where('is_del',1)
-                    ->field('id,rate')
-                    ->select();
-
-                foreach ($prize_arr as $key => $val) {
-                    $arr[$val['id']] = $val['rate'];//概率数组
-                }
-                $rid = get_rand($arr); //根据概率获取奖项id
-
-//                $a=array_rand($prize_arr,1);
-//                $rid=$prize_arr[$a]['id'];
-                $pr_info = Db::name('store_box')->where('id',$rid)->field('id,title,prize,is_prize')->find();
-                $return = [
-                    'is_prize'=>$pr_info['is_prize']
-                ];
-                $coll_info =  getCollectionInfoHash($pr_info['prize']);
-                if ($pr_info['is_prize']==1){
-                    $json_info = json_encode($coll_info,true);
-                    $return['name'] = $pr_info['title'];
-                    $return['cover'] = $coll_info['cover'];
-                }else{
-                    $json_info = '';
-                    $return['name'] = '未中奖';
-                    $return['cover'] = '';
-                }
-
-                $data = [
-                    'm_id'=>$this->uid,
-                    'b_id'=>$rid,
-                    'is_prize'=>$pr_info['is_prize'],
-                    'name'=>$return['name'],
-                    'cover'=>$return['cover'],
-                    'info'=>$json_info,
-                    'date'=>date('Y-m-d'),
-                    'is_free'=>1
-                ];
-
-
-                Db::name('store_blind_box_log')->insert($data);
-                if ($pr_info['is_prize']==1){
-
-                    //获取排名
-                    $rank = getRanking($pr_info['prize'])+1;
-                    $tag = getTag($pr_info['prize'],$rank,$coll_info['inventory']);
-
-                    saveRanking($pr_info['prize']);
-
-                    $is_nft = Db::name('hash2')->where('goods_id',$pr_info['prize'])->where('success',1)->find();
-                    $collectors_hash = '';
-                    $date = [
-                        'order_id'=>0,
-                        'order_no'=>get_order_sn(),
-                        'tag'=>$tag,
-                        'mid'=>$this->uid,
-                        'c_id'=>$pr_info['prize'],
-                        'name'=>$coll_info['name'],
-                        'cover'=>$coll_info['cover'],
-                        'pro_info'=>$json_info,
-                        'tokenid'=>$is_nft['class_id'],
-                        'nfttype'=>$is_nft['operationId'],
-                        'collectors_hash'=>$collectors_hash,
-                       // 'collectors_hash_time'=>' ',
-                        'status'=>4
-                    ];
-                    Db::name('store_order_info')->insert($date);
-                }
-                Db::commit();
-            }catch (Exception $e) {
-                $com = false;
-                Db::rollback();
-            }
-            if ($com){
-                setMemberInfoHash($this->uid);
-                if ($pr_info['is_prize']==1){
-                    //减掉库存
-                    loseCollectionInventory($pr_info['prize'],1);
-                }
-                DelRedisSetNx('openBox'.$this->uid);
-                $this->success('成功',$return);
-            }else{
-                DelRedisSetNx('openBox'.$this->uid);
-                $this->error('开启失败,请稍后重试');
-            }
-        }else{
-            $this->error('请求过快');
-        }
-    }
-
-
-
-
-
-
-
-}

+ 0 - 74
application/api/controller/WeChart.php

@@ -1,74 +0,0 @@
-<?php
-namespace app\api\controller;
-use EasyWeChat\Factory;
-use  think\cache\driver\Redis;
-use  think\Session;
-class WeChart {
-
-    protected $app_id ='wx7a5f15ddeda9ef5a';
-    protected $app_secret = 'a4c33b42917949652c31447e42132de0';
-
-
-    /**
-     * 获取token
-     * @return mixed|string
-     */
-    public function  getAccessToken()
-    {
-        $session = new Session();
-        $over_time = $session->get('token_over_time');
-        if($over_time < time()) {
-            $url=  "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={$this->app_id}&secret={$this->app_secret}";
-            $ret = http_curl($url);
-            $session->set('access_token',$ret['access_token']);
-            $session->set('token_over_time',time() +$ret['expires_in'] );
-        }
-        return  $session->get('access_token');
-    }
-
-
-    public function send_message($order_sn=''){
-
-        $url='https://api.weixin.qq.com/cgi-bin/message/wxopen/template/uniform_send?access_token='.$access_token;
-        $order = Db::name('StoreOrder')->field('id,order_sn,create_at,num,take_time,user_id,goods_id')->where('order_sn',$order_sn)->find();
-        $member = Db::name('storeMember')->field('id,vip_level,openid,username,nickname')->where('id',$order['user_id'])->find();
-        $book_book = Db::name('book_book')->field('id,title')->where('id',$order['goods_id'])->find();
-        $data=[
-            'touser'=>$member['openid'],
-            'mp_template_msg'=>[
-                "appid"=>"wx3346d52f010b611d",
-                "template_id"=>"SH6KcRTVDiU0-7cSDujHsCg8MhbgzGpHb8US1QiPYW0",
-                "url"=>"http://www.baidu.com",
-                'miniprogram'=>[
-                    "appid"=>"wx2b03c73ff0547cc3",
-                ],
-                'data'=>[
-                    'first'=>[
-                        "value"=>'恭喜你已借阅到该图书',
-                        "color"=>"#173177"
-                    ],
-                    'keyword1'=>[
-                        "value"=>$book_book['title'],
-                        "color"=>"#173177"
-                    ],
-                    'keyword2'=>[
-                        "value"=>$member['username']?$member['username']:$member['nickname'],
-                        "color"=>"#173177"
-                    ],
-                    'keyword3'=>[
-                        "value"=>date('Y-m-d H:i:s',time()),
-                        "color"=>"#173177"
-                    ],
-                    'remark'=>[
-                        "value"=>'谢谢你对哩哈教育的支持!',
-                        "color"=>"#173177"
-                    ]
-                ]
-            ],
-        ];
-        $res = requestPost($url,json_encode($data));
-    }
-
-
-
-}

+ 0 - 1830
application/common.php

@@ -1,1830 +0,0 @@
-<?php
-
-use app\common\library\QRcode;
-use think\Db;
-use OSS\OssClient;
-
-function IntToChr($index, $start = 65) {
-    $str = '';
-    if (floor($index / 26) > 0) {
-        $str .= IntToChr(floor($index / 26)-1);
-    }
-    return $str . chr($index % 26 + $start);
-}
-/**
- * 秒转换为天
- */
-function get_stay_time($remain_time, $is_hour = 1, $is_minutes = 1)
-{
-    $day = floor($remain_time / (3600*24));
-    $day = $day > 0 ? $day.'天' : '';
-    $hour = floor(($remain_time % (3600*24)) / 3600);
-    $hour = $hour > 0 ? $hour.'小时' : '';
-    if($is_hour && $is_minutes) {
-        $minutes = floor((($remain_time % (3600*24)) % 3600) / 60);
-        $minutes = $minutes > 0 ? $minutes.'分钟' : '';
-        return $day.$hour.$minutes;
-    }
-
-    if($hour) {
-        return $day.$hour;
-    }
-    return $day;
-}
-//获取全图片地址 $image_data
-function image_path($image_data){
-    if(empty($image_data)){
-        return $image_data;
-    }
-    if (strpos($image_data,'|')!==false){
-        $image_res = explode('|',$image_data);
-    }elseif(strpos($image_data,',')!==false){
-        $image_res = explode(',',$image_data);
-    }else{
-        $image_res = array($image_data);
-    }
-    return $image_res;
-}
-
-
-
-
-
-
-
-
-
-// 获取模板区域
-function get_city_area()
-{
-    $field=['id','pid','name'];
-    $list=Db::table('store_area')->where('pid',0)->field($field)->select();
-    foreach ($list as $k=>&$v){
-        $v['children']= Db::table('store_area')->where('pid',$v['id'])->field($field)->select();
-    }
-    return $list;
-}
-
-
-function http_curl($url,$type='get',$res='json',$arr=''){
-
-    $headers = array();
-    //根据API的要求,定义相对应的Content-Type
-    array_push($headers, "Content-Type".":"."application/x-www-form-urlencoded; charset=UTF-8;application/json");
-    $curl = curl_init();
-    curl_setopt($curl, CURLOPT_CUSTOMREQUEST, $type);
-    curl_setopt($curl, CURLOPT_URL, $url);
-    curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
-    curl_setopt($curl, CURLOPT_FAILONERROR, false);
-    curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
-    curl_setopt($curl, CURLOPT_HEADER, false);
-    $output = curl_exec($curl);
-    curl_close($curl);
-    if($res=='json'){
-        if($output === false){
-            //请求失败,返回错误信息
-            return curl_error($curl);
-        }else{
-            //请求成功,返回信息
-            return json_decode($output,true);
-        }
-    }
-}
-
-// 获取物流信息
-function get_delivery($send_no = 'JD0053309649641',$express_code=''){
-        error_reporting(E_ALL || ~E_NOTICE);
-        $AppKey     = 204008273;
-        $AppSecret  ='t9PavvfCeK5v2XidwyK5pWDp8b0hzMq4';
-        $AppCode    ='47f640e3529d43e28365311a530db2b7';//开通服务后 买家中心-查看AppCode
-        $host = "https://wuliu.market.alicloudapi.com";//api访问链接
-        $path = "/kdi";//API访问后缀
-        $method = "GET";
-        $body  ='';
-        $headers = array();
-        array_push($headers, "Authorization:APPCODE " . $AppCode);
-        $querys = "no={$send_no}&type={$express_code}";  //参数写在这里
-        $url = $host . $path . "?" . $querys;
-        $curl = curl_init();
-        curl_setopt($curl, CURLOPT_CUSTOMREQUEST, $method);
-        curl_setopt($curl, CURLOPT_URL, $url);
-        curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
-        curl_setopt($curl, CURLOPT_FAILONERROR, false);
-        curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
-        curl_setopt($curl, CURLOPT_HEADER, true);
-        if (1 == strpos("$" . $host, "https://")) {
-            curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
-            curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
-        }
-        $out_put = curl_exec($curl);
-        $httpCode = curl_getinfo($curl, CURLINFO_HTTP_CODE);
-        list($header, $body) = explode("\r\n\r\n", $out_put, 2);
-        if ($httpCode == 200) {
-            return json_decode($body,true)['result'];
-        } else {
-            return [];
-        }
-    }
-
-
-// 元石日志
-function crystal_log($user_id,$crystal,$desc,$type,$rel_id=0)
-{
-    $log_data = [
-        'user_id' => $user_id,
-        'create_at' => date('Y-m-d H:i:s'),
-        'crystal' => $crystal,
-        'desc' => $desc,
-        'type' => $type,
-        'rel_id' => $rel_id,
-    ];
-    Db::table('crystal_info')->insert($log_data);
-}
-
-/**
- * 判断是否为合法的身份证号码
- * @param $mobile
- * @return int
- */
-function isCreditNo($vStr){
-    $vCity = array(
-        '11','12','13','14','15','21','22',
-        '23','31','32','33','34','35','36',
-        '37','41','42','43','44','45','46',
-        '50','51','52','53','54','61','62',
-        '63','64','65','71','81','82','91'
-    );
-    if (!preg_match('/^([\d]{17}[xX\d]|[\d]{15})$/', $vStr)) return false;
-    if (!in_array(substr($vStr, 0, 2), $vCity)) return false;
-    $vStr = preg_replace('/[xX]$/i', 'a', $vStr);
-    $vLength = strlen($vStr);
-    if ($vLength == 18) {
-        $vBirthday = substr($vStr, 6, 4) . '-' . substr($vStr, 10, 2) . '-' . substr($vStr, 12, 2);
-    } else {
-        $vBirthday = '19' . substr($vStr, 6, 2) . '-' . substr($vStr, 8, 2) . '-' . substr($vStr, 10, 2);
-    }
-    if (date('Y-m-d', strtotime($vBirthday)) != $vBirthday) return false;
-    if ($vLength == 18) {
-        $vSum = 0;
-        for ($i = 17 ; $i >= 0 ; $i--) {
-            $vSubStr = substr($vStr, 17 - $i, 1);
-            $vSum += (pow(2, $i) % 11) * (($vSubStr == 'a') ? 10 : intval($vSubStr , 11));
-        }
-        if($vSum % 11 != 1) return false;
-    }
-    return true;
-}
-
-
-//实名认证(云盾身份认证(身份证二要素核验)
-function identifyCertification($id_card,$name){
-
-    $host = "https://safrvcert.market.alicloudapi.com";
-    $path = "/safrv_2meta_id_name/";
-    $method = "GET";
-    $appcode = "0077fde8e0474401b8e090b780da1a97";
-    $headers = array();
-    array_push($headers, "Authorization:APPCODE " . $appcode);
-    $querys = "__userId=__userId&identifyNum=$id_card&userName=$name&verifyKey=verifyKey";
-    $bodys = "";
-    $url = $host . $path . "?" . $querys;
-
-    $curl = curl_init();
-    curl_setopt($curl, CURLOPT_CUSTOMREQUEST, $method);
-    curl_setopt($curl, CURLOPT_URL, $url);
-    curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
-    curl_setopt($curl, CURLOPT_FAILONERROR, false);
-    curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
-    curl_setopt($curl, CURLOPT_HEADER, false);
-    if (1 == strpos("$".$host, "https://"))
-    {
-        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
-        curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
-    }
-    curl_setopt($curl, CURLOPT_POSTFIELDS, $bodys);
-    $res = curl_exec($curl);
-    if($res){
-        $res = json_decode($res,true);
-        if($res['code'] == 200 && $res['message']=='success'){
-            return 1;
-        }else{
-            return 0;
-        }
-    }else{
-        return 0;
-    }
-}
-
-
-// 实名认证
-function user_certification($id_card,$name){
-    $host = "http://checkone.market.alicloudapi.com";
-    $path = "/chinadatapay/1882";
-    $method = "POST";
-    $appcode = "30be8bdcc65842919980a8276ffc4995";
-    $headers = array();
-    array_push($headers, "Authorization:APPCODE " . $appcode);
-    //根据API的要求,定义相对应的Content-Type
-    array_push($headers, "Content-Type".":"."application/x-www-form-urlencoded; charset=UTF-8");
-
-    $bodys = "idcard=".$id_card."&name=".$name;
-    $url = $host . $path;
-
-    $curl = curl_init();
-    curl_setopt($curl, CURLOPT_CUSTOMREQUEST, $method);
-    curl_setopt($curl, CURLOPT_URL, $url);
-    curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
-    curl_setopt($curl, CURLOPT_FAILONERROR, false);
-    curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
-    curl_setopt($curl, CURLOPT_HEADER, false);
-    if (1 == strpos("$".$host, "https://"))
-    {
-        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
-        curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
-    }
-    curl_setopt($curl, CURLOPT_POSTFIELDS, $bodys);
-    $res = curl_exec($curl);
-    dump($res);die;
-    if($res){
-        $res = json_decode($res,true);
-        if($res['data']['result'] == 1){
-           return 1;
-        }else{
-            return 0;
-        }
-    }else{
-       return 0;
-    }
-}
-
-
-
-function idcardlingyu1($id_card,$name)
-{
-    $data = array(
-        'appId' => 'QYeloNCb',
-        'appKey' => 'Q0PR2wle',
-        'name' => $name,
-        'idNum'=>$id_card
-    );
-
-    $data_string = json_encode($data,JSON_UNESCAPED_UNICODE);
-    // $data_string = $data;
-    $curl_con = curl_init();
-    curl_setopt($curl_con, CURLOPT_URL,$url);
-    curl_setopt($curl_con, CURLOPT_HEADER, false);
-    curl_setopt($curl_con, CURLOPT_POST, true);
-    curl_setopt($curl_con, CURLOPT_RETURNTRANSFER, TRUE);
-    curl_setopt($curl_con, CURLOPT_CONNECTTIMEOUT, 5);
-    curl_setopt($curl_con, CURLOPT_HTTPHEADER, array(
-            'Content-Type: application/json',
-            'Content-Length: ' . strlen($data_string))
-    );
-    curl_setopt($curl_con, CURLOPT_POSTFIELDS, $data_string);
-    $res = curl_exec($curl_con);
-    $status = curl_getinfo($curl_con);
-    curl_close($curl_con);
-
-    if (isset($status['http_code']) && $status['http_code'] == 200) {
-        return $res;
-    } else {
-        return FALSE;
-    }
-}
-
-function idcardlingyu($id_card,$name){
-
-
-    $url = 'http://139.224.206.237:3333/user/api/id-card-auth';
-    $header = array(
-        'Content-Type:application/x-www-form-urlencoded;boundary=ebf9f03029db4c2799ae16b5428b06bd1',
-    );
-    $data = array(
-
-        'appId' => 'QYeloNCb',
-        'appKey' => 'Q0PR2wle',
-        'name' => $name,
-        'idNum'=>$id_card
-    );
-
-    $ch = curl_init();
-    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
-    curl_setopt($ch, CURLOPT_URL, $url);
-    curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
-    curl_setopt($ch, CURLOPT_POST, true);
-    curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data));
-    $sResult = curl_exec($ch);
-    if($sError=curl_error($ch)){
-        die($sError);
-    }
-    curl_close($ch);
-    $res = json_decode($sResult,true);
-//    dump($res);
-    if (isset($res) && $res['code']=='200000'){
-        return true;
-    }
-    return false;
-}
-
-//四要素
-function idcardlingyufour($id_card,$name,$bank_card,$bank_mobile){
-    $url = 'http://139.224.206.237:3333/user/api/cardAuth';
-    $header = array(
-        'Content-Type:application/x-www-form-urlencoded;boundary=ebf9f03029db4c2799ae16b5428b06bd1',
-    );
-    $data = array(
-
-        'appId' => 'QYeloNCb',
-        'appKey' => 'Q0PR2wle',
-        'name' => $name,
-        'idNum'=>$id_card,
-        'cardNo'=>$bank_card,
-        'mobile'=>$bank_mobile
-    );
-
-    $ch = curl_init();
-    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
-    curl_setopt($ch, CURLOPT_URL, $url);
-    curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
-    curl_setopt($ch, CURLOPT_POST, true);
-    curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data));
-    $sResult = curl_exec($ch);
-    if($sError=curl_error($ch)){
-        die($sError);
-    }
-    curl_close($ch);
-    $res = json_decode($sResult,true);
-    //dump($res);die;
-    $array['success'] = 0;
-    if (isset($res) && $res['code']=='200000'){
-        if (isset($res['data']['result']) && $res['data']['result']=='01'){
-            $array['success']=1;
-            $array['remark'] ='验证成功';
-        }else{
-            $array['remark'] = $res['data']['remark'];
-        }
-    }else{
-        $array['remark'] ='认证失败';
-    }
-    return $array;
-}
-
-
-
-
-function shoucang(){
-    $host = "http://180.76.141.31:8888/cz/call";
-    $method = "POST";
-    $headers = array();
-    array_push($headers, "Content-Type".":"."application/json; charset=UTF-8");
-    $bodys = array(
-        'key' => 'test2',
-        'userkey' => '12344',
-        'product' => json_encode(array('name'=>'test','count'=>7))
-    );
-    $curl = curl_init();
-    curl_setopt($curl, CURLOPT_CUSTOMREQUEST, $method);
-    curl_setopt($curl, CURLOPT_URL, $host);
-    curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
-    curl_setopt($curl, CURLOPT_FAILONERROR, false);
-    curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
-    curl_setopt($curl, CURLOPT_HEADER, false);
-    if (1 == strpos("$".$host, "https://"))
-    {
-        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
-        curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
-    }
-    curl_setopt($curl, CURLOPT_POSTFIELDS, json_encode($bodys));
-    $res = curl_exec($curl);
-    var_dump($res);exit();
-}
-
-
-/**
- * 大师提前分钟数存入redis
- */
-function setAdvanceMinutes(){
-    $redis = new \think\cache\driver\Redis();
-    $value = Db::name('system_config')->where('name','advance_minutes')->value('value');
-    $redis->set('advance_minutes',$value);
-}
-
-
-/**
- * 获取大师提前分钟数
- */
-function getAdvanceMinutes(){
-    $redis = new \think\cache\driver\Redis();
-    $value = $redis->get('advance_minutes');
-    if (empty($value)){
-        $value = Db::name('system_config')->where('name','advance_minutes')->value('value');
-        $redis->set('advance_minutes',$value);
-    }
-    return $value;
-}
-
-/**
- * 获取自动取消分钟数
- */
-function getCancelTime(){
-    return Db::name('system_config')->where('name','cancel_time')->value('value');
-}
-
-
-/**
- * 用户信息存入redis hash
- */
-function setMemberInfoHash($member_id){
-    $info = Db::name('store_member')->where('id',$member_id)->find();
-    $redis = new \think\cache\driver\Redis();
-    $array = ['member'.$member_id=>json_encode($info)];
-    $redis->hMSet('memberInfo',$array);
-}
-
-
-/**
- * redis获取用户信息
- */
-function getMemberInfoHash($member_id){
-    $redis = new \think\cache\driver\Redis();
-    $info = $redis->hGet('memberInfo','member'.$member_id);
-    if (!$info){
-        $info = Db::name('store_member')->where('id',$member_id)->find();
-        $array = ['member'.$member_id=>json_encode($info)];
-        $redis->hMSet('memberInfo',$array);
-    }else{
-        $info = json_decode($info,true);
-    }
-    return $info;
-}
-
-
-
-/**
- * 用户抢购卡数量存入redis 字符串
- */
-function setMembercard($member_id){
-    $snap_card = Db::name('store_member')->where('id',$member_id)->value('snap_card');
-    $redis = new \think\cache\driver\Redis();
-    $redis->set('membercard_'.$member_id,$snap_card);
-}
-
-/**
- * 获取用户抢购卡数量
- */
-function getMembercard($member_id){
-    $redis = new \think\cache\driver\Redis();
-    $count = $redis->get('membercard_'.$member_id);
-    if (empty($count)){
-        $count = Db::name('store_member')->where('id',$member_id)->value('snap_card');
-        $redis->set('membercard_'.$member_id,$count);
-    }
-    return $count;
-}
-
-/**
- * 减掉用户抢购卡数量(减1)
- */
-function loseMembercard($id){
-    $redis = new \think\cache\driver\Redis();
-    $redis->Decr('membercard_'.$id);
-}
-
-/**
- * 增加用户抢购卡数量(加1)
- */
-function addMembercard($id){
-    $redis = new \think\cache\driver\Redis();
-    $redis->Incr('membercard_'.$id);
-}
-
-/**
- * 获取藏品库存
- */
-function getCollectionInventory($id){
-    $redis = new \think\cache\driver\Redis();
-    $count = $redis->get('collection_count_'.$id);
-    return $count ? $count : 0;
-}
-
-/**
- * 减掉藏品库存
- */
-function loseCollectionInventory($id,$num){
-    $redis = new \think\cache\driver\Redis();
-    $redis->Decrby('collection_count_'.$id,$num);
-}
-
-/**
- * 加藏品库存
- */
-function addCollectionInventory($id,$num){
-    $redis = new \think\cache\driver\Redis();
-    $redis->Incrby('collection_count_'.$id,$num);
-}
-
-
-/**
- * 用户购买藏品排名更新
- */
-function saveRanking($id){
-    $redis = new \think\cache\driver\Redis();
-    $redis->Incr('ranking'.$id);
-}
-
-/**
- * 获取用户购买藏品排名更新
- */
-function getRanking($id){
-    $redis = new \think\cache\driver\Redis();
-    $count =  $redis->get('ranking'.$id);
-    if (empty($count)){
-        $redis->set('ranking'.$id,0);
-    }
-    $count = empty($count) ? 0 : $count;
-    return $count;
-}
-
-
-/**
- * 藏品信息存入redis hash
- */
-function setCollectionInfoHash($id){
-    $info = Db::name('store_collection')->where('id',$id)->find();
-    $redis = new \think\cache\driver\Redis();
-    $array = ['collection'.$id=>json_encode($info)];
-    $redis->hMSet('collectionInfo',$array);
-}
-
-
-/**
- * 获取用户购买数量
- */
-function getByCount($mid,$id){
-    $redis = new \think\cache\driver\Redis();
-    $count = $redis->get('UserByCount_'.$mid.$id);
-    if (empty($count) && $count!=0){
-//        $count = Db::name('store_order')
-//            ->where('mid',$mid)
-//            ->where('c_id',$id)
-//            ->whereIn('status','0,1')
-//            ->sum('num');
-//        $count = $count ? $count : 0;
-        $count = 0;
-        $redis->Incrby('UserByCount_'.$mid.$id,$count);
-    }
-    return $count;
-}
-
-/**
- * 用户购买数量增加
- */
-function IncrByCount($mid,$id,$number){
-    $redis = new \think\cache\driver\Redis();
-    $redis->Incrby('UserByCount_'.$mid.$id,$number);
-}
-
-
-
-/**
- * 用户购买数量减少
- */
-function DecrByCount($mid,$id,$number){
-    $redis = new \think\cache\driver\Redis();
-    $redis->Decrby('UserByCount_'.$mid.$id,$number);
-}
-
-
-/**
- * 获取藏品hash redis长度
- */
-function getLenCollection($id){
-    $redis = new \think\cache\driver\Redis();
-    $count = $redis->Llen('collectionHash_'.$id);
-    if (!$count){
-        $count = Db::name('hash')
-            ->where('goods_id',$id)
-            ->where('status',0)
-            ->count();
-    }
-    return $count;
-}
-
-
-
-/**
- * 获取藏品信息
- */
-function getCollectionInfoHash($id)
-{
-    $redis = new \think\cache\driver\Redis();
-    $info = $redis->hGet('collectionInfo','collection'.$id);
-    if (!$info){
-        $info = Db::name('store_collection')->where('id',$id)->find();
-        $array = ['collection'.$id=>json_encode($info)];
-        $redis->hMSet('collectionInfo',$array);
-    }else{
-        $info = json_decode($info,true);
-    }
-    return $info;
-}
-
-
-/**
- * 收集下单用户id
- */
-function setCollectionBuyUser($mid){
-    $redis = new \think\cache\driver\Redis();
-    $array = [$mid=>1];
-    $redis->hMSet('buyUserInfo',$array);
-}
-
-
-/*
- * 微信支付账户
- */
-function retrunWxConfig(){
-    $config = [
-        'app_id' => 'wxa6980453638c9c78',
-        'mch_id' =>'1623128602',
-        'key' =>'qwertyuiopASDFGHJKLZXCVBNM123456',
-    ];
-
-    return $config;
-}
-
-/**
- * 获取离线账户
- */
-function getOfflineAccount(){
-    $url = 'http://192.144.219.204:8083/ddc/createAccount';
-    return file_get_contents($url);
-}
-
-/**
- * 获取链账户
- */
-function getWalletAddress($phone){
-    $url = 'http://39.107.12.194:8088/register?accountName='.$phone;
-    $res=curlRequest($url);
-    if ($res){
-        $res = json_decode($res,true);
-        if ($res['code']=='200'){
-            return $res['result']['userAddressStr'];
-        }
-    }
-    return false;
-}
-
-
-/**
- * 获取公司生成的hash
- */
-function getCompanyHash($id){
-    $redis = new \think\cache\driver\Redis();
-    $hash  = $redis->lPop('collectionHash_'.$id);
-    if (!$hash){
-        $hash = Db::name('hash')->where('goods_id',$id)
-            ->where('status',0)
-            ->order('id asc')
-            ->field('hash,create_at')
-            ->limit(1)
-            ->find();
-    }else{
-        $hash = json_decode($hash,true);
-    }
-    return $hash;
-}
-
-
-
-
-/**
- * 获取排名
- */
-function getTag($id,$now,$num){
-    $len = strlen($num);
-    $re = getConfigValue('tag_prefix').$id.'#';
-    switch ($len){
-        case 1:
-            $re = $re.'0'.$now;
-            break;
-        case 2:
-            if ($now<10){
-                $re = $re.'0'.$now;
-            }else{
-                $re = $re.$now;
-            }
-            break;
-        case 3:
-            if ($now<10){
-                $re = $re.'00'.$now;
-            }elseif ($now>=10 && $now<100){
-                $re = $re.'0'.$now;
-            }else{
-                $re = $re.$now;
-            }
-            break;
-        case 4:
-            if ($now<10){
-                $re = $re.'000'.$now;
-            }elseif ($now>=10 && $now<100){
-                $re = $re.'00'.$now;
-            }elseif ($now>=100 && $now<1000){
-                $re = $re.'0'.$now;
-            }else{
-                $re = $re.$now;
-            }
-            break;
-        case 5:
-            if ($now<10){
-                $re = $re.'0000'.$now;
-            }elseif ($now>=10 && $now<100){
-                $re = $re.'000'.$now;
-            }elseif ($now>=100 && $now<1000){
-                $re = $re.'00'.$now;
-            }elseif ($now>=1000 && $now<10000){
-                $re = $re.'0'.$now;
-            }else{
-                $re = $re.$now;
-            }
-            break;
-        case 6:
-            if ($now<10){
-                $re = $re.'00000'.$now;
-            }elseif ($now>=10 && $now<100){
-                $re = $re.'0000'.$now;
-            }elseif ($now>=100 && $now<1000){
-                $re = $re.'000'.$now;
-            }elseif ($now>=1000 && $now<10000){
-                $re = $re.'00'.$now;
-            }elseif ($now>=10000 && $now<100000){
-                $re = $re.'0'.$now;
-            }else{
-                $re = $re.$now;
-            }
-            break;
-        case 7:
-            if ($now<10){
-                $re = $re.'000000'.$now;
-            }elseif ($now>=10 && $now<100){
-                $re = $re.'00000'.$now;
-            }elseif ($now>=100 && $now<1000){
-                $re = $re.'0000'.$now;
-            }elseif ($now>=1000 && $now<10000){
-                $re = $re.'000'.$now;
-            }elseif ($now>=10000 && $now<100000){
-                $re = $re.'00'.$now;
-            }elseif ($now>=100000 && $now<1000000){
-                $re = $re.'0'.$now;
-            }else{
-                $re = $re.$now;
-            }
-            break;
-    }
-    $re = $re.'/'.$num;
-    return $re;
-}
-
-/**
- * 判断藏品是否设置过提醒
- */
-function getRemind($mid,$c_id){
-   return Db::name('store_collection_remind')->where('mid',$mid)->where('c_id',$c_id)->count();
-}
-
-/**
- * 变更会员积分等
- * @param int $money    余额
- * @param int $user_id  会员ID
- * @param string $memo  备注
- */
-function memberMoneyChange($num, $type , $m_id, $title, $pm = 0,$link_id=0)
-{
-    $member = Db::name('store_member')->where('id',$m_id)->find();
-    switch ($type){
-        case 1:    //积分
-            $before = $member['integral'];
-            if ($pm==1)
-                $after = $member['integral']+$num;
-            else
-                $after = $member['integral']-$num;
-
-            $update_data = ['integral'=>$after];
-            break;
-        case 2:   //抢购卡
-            $before = $member['snap_card'];
-            if ($pm==1)
-                $after = $member['snap_card']+$num;
-            else
-                $after = $member['snap_card']-$num;
-
-            $update_data = ['snap_card'=>$after];
-            break;
-        case 3:   //余额
-            $before = $member['money'];
-            if ($pm==1)
-                $after = $member['money']+$num;
-            else
-                $after = $member['money']-$num;
-
-            $update_data = ['money'=>$after];
-            break;
-    }
-    Db::startTrans();
-    try {
-        Db::name('store_member')->where('id',$m_id)->update($update_data);
-        $data = [
-            'm_id'=>$m_id,
-            'type'=>$type,
-            'pm'=>$pm,
-            'title'=>$title,
-            'change'=>$num,
-            'before'=>$before,
-            'after'=>$after,
-            'link_id'=>$link_id
-        ];
-        Db::name('store_member_log')->insert($data);
-        Db::commit();
-        return true;
-    }catch (\Exception $e){
-        Db::rollback();
-        return false;
-    }
-}
-
-
-/**
- * 获取单个系统配置信息
- */
-function getConfigValue($name){
-    return Db::name('system_config')->where('name',$name)->value('value');
-}
-
-
-
-/**
- * 判断藏品状态
- */
-function checkCollectionState($id=''){
-    if ($id){
-        $info = Db::name('store_collection')->where('id',$id)->find();
-        $now_inventory = getCollectionInventory($id);
-        if (!empty($v['endtime']) && strtotime($info['endtime'])<time()){
-            Db::name('store_collection')->where('id',$info['id'])->update(['state'=>4]);
-        }else{
-            if ($info['state']==1){
-                if ($now_inventory<=0){
-                   // Db::name('store_collection')->where('id',$info['id'])->update(['state'=>3]);
-                }
-            }else if($info['state']==2){
-                if (strtotime($info['sell_time'])<=time()){
-                    Db::name('store_collection')->where('id',$info['id'])->update(['state'=>1]);
-                }
-            }else if($info['state']==3){
-                if ($now_inventory>0){
-                    Db::name('store_collection')->where('id',$info['id'])->update(['state'=>1]);
-                }
-            }else if($info['state']==4){
-                if ($now_inventory>0){
-                    Db::name('store_collection')->where('id',$info['id'])->update(['state'=>1]);
-                }elseif (strtotime($info['sell_time'])<=time()){
-                    Db::name('store_collection')->where('id',$info['id'])->update(['state'=>1]);
-                }elseif ($now_inventory<=0){
-                    //Db::name('store_collection')->where('id',$info['id'])->update(['state'=>3]);
-                }
-            }
-        }
-        setCollectionInfoHash($id);
-
-    }else{
-        $list = Db::name('store_collection')
-            ->whereIn('state','1,2,3,4')
-            ->where('status',1)
-            ->where('is_deleted',0)
-            ->select();
-        foreach ($list as &$v){
-            $now_inventory = getCollectionInventory($v['id']);
-            if (!empty($v['endtime']) && strtotime($v['endtime'])<time()){
-                Db::name('store_collection')->where('id',$v['id'])->update(['state'=>4]);
-            }else{
-                if ($v['state']==1){
-                    if ($now_inventory<=0){
-                      //  Db::name('store_collection')->where('id',$v['id'])->update(['state'=>3]);
-                    }
-                }elseif ($v['state']==2){
-                    if (strtotime($v['sell_time'])<=time()){
-                        Db::name('store_collection')->where('id',$v['id'])->update(['state'=>1]);
-                    }
-                }elseif ($v['state']==3){
-                    if ($now_inventory>0){
-                        Db::name('store_collection')->where('id',$v['id'])->update(['state'=>1]);
-                    }
-                }else if($v['state']==4){
-                    if ($now_inventory>0){
-                        Db::name('store_collection')->where('id',$v['id'])->update(['state'=>1]);
-                    }elseif (strtotime($v['sell_time'])<=time()){
-                        Db::name('store_collection')->where('id',$v['id'])->update(['state'=>1]);
-                    }elseif ($now_inventory<=0){
-                       // Db::name('store_collection')->where('id',$v['id'])->update(['state'=>3]);
-                    }
-                }
-            }
-            setCollectionInfoHash($v['id']);
-        }
-    }
-}
-
-
-/**
- * 判断藏品状态
- */
-function checkSynCollectionState($id=''){
-    if ($id){
-        $info = Db::name('store_collection')->where('id',$id)->find();
-        $now_inventory = getCollectionInventory($id);
-        if ($info['sy_state']==1){
-            if ($now_inventory<=0){
-                Db::name('store_collection')->where('id',$info['id'])->update(['sy_state'=>4]);
-            }elseif(strtotime($info['end_time'])<time()){
-                Db::name('store_collection')->where('id',$info['id'])->update(['sy_state'=>3]);
-            }
-        }elseif ($info['sy_state']==2){
-            if (strtotime($info['sell_time'])<=time()){
-                Db::name('store_collection')->where('id',$info['id'])->update(['sy_state'=>1]);
-            }elseif ($now_inventory<=0){
-                Db::name('store_collection')->where('id',$info['id'])->update(['sy_state'=>4]);
-            }
-        }
-    }else{
-        $list = Db::name('store_collection')
-            ->where('type',2)
-            ->whereIn('sy_state','1,2')
-            ->where('is_deleted',0)
-            ->select();
-        foreach ($list as &$v){
-            $now_inventory = getCollectionInventory($v['id']);
-            if ($v['sy_state']==1){
-                if ($now_inventory<=0){
-                    Db::name('store_collection')->where('id',$v['id'])->update(['sy_state'=>4]);
-                }elseif(strtotime($v['end_time'])<time()){
-                    Db::name('store_collection')->where('id',$v['id'])->update(['sy_state'=>3]);
-                }
-            }elseif ($v['sy_state']==2){
-                if (strtotime($v['sell_time'])<=time()){
-                    Db::name('store_collection')->where('id',$v['id'])->update(['sy_state'=>1]);
-                }elseif ($now_inventory<=0){
-                    Db::name('store_collection')->where('id',$v['id'])->update(['sy_state'=>4]);
-                }
-            }
-        }
-    }
-}
-
-
-
-/**
- * redis加锁
- */
-function redisSetNx($key,$exptime){
-    $redis = new \think\cache\driver\Redis(['select'=>2]);
-    $is_lock = $redis->setnx($key,time()+$exptime);
-    if ($is_lock){
-        return true;
-    }else{
-        //加锁失败的情况下,判断锁是否已经存在,如果存在切已经过期,删除锁,重新加锁
-        $val = $redis->get($key);
-        if ($val && $val<time()){
-            $redis->del($key);
-        }
-        return $redis->setnx($key,time()+$exptime);
-    }
-}
-
-/**
- * 删除锁
- */
-function DelRedisSetNx($key){
-    $redis = new \think\cache\driver\Redis(['select'=>2]);
-    $redis->del($key);
-}
-
-
-/**
- * 盲盒信息存入redis hash
- */
-function setBoxInfoHash($id){
-    $info = Db::name('store_collection')->where('id',$id)->find();
-    $redis = new \think\cache\driver\Redis();
-    $array = ['collection'.$id=>json_encode($info)];
-    $redis->hMSet('collectionInfo',$array);
-}
-
-/**
- * 获取0的数量
- */
-function get0number($n){
-    if ($n==1){
-        return '00000000000';
-    }elseif ($n==2){
-        return '0000000000';
-    }elseif ($n==3){
-        return '000000000';
-    }elseif ($n==4){
-        return '00000000';
-    }elseif ($n==5){
-        return '0000000';
-    }elseif ($n==6){
-        return '000000';
-    }elseif ($n==7){
-        return '00000';
-    }elseif ($n==8){
-        return '0000';
-    }elseif ($n==9){
-        return '000';
-    }elseif ($n==10){
-        return '00';
-    }elseif ($n==11){
-        return '0';
-    }
-}
-
-
-
-
-
-/***********************************************人脸识别*****************************************************************/
-
-/**
- * 获取accesstoken
- * @return mixed
- */
-function getAccessToken(){
-    $appid_id =getFaceInfo()['appid'];
-    $secret = getFaceInfo()['secret'];
-    $grant_type = 'client_credential';
-    $version = '1.0.0';
-    $url = "https://miniprogram-kyc.tencentcloudapi.com/api/oauth2/access_token?app_id=".$appid_id."&secret=".$secret."&grant_type=".$grant_type."&version=".$version;
-    $result = curlRequest($url);
-    $result = json_decode($result,true);
-    if ($result['code']==0){
-        return $result;
-    }
-    echo $result['msg'];die;
-}
-
-/**
- * 获取api_ticket
- */
-function getApiTicket($type,$userId=''){
-    $appid_id =getFaceInfo()['appid'];
-    $access_token = getAccessToken()['access_token'];
-    $version = '1.0.0';
-    $url = "https://miniprogram-kyc.tencentcloudapi.com/api/oauth2/api_ticket?app_id=".$appid_id."&access_token=".$access_token."&type=".$type."&version=".$version;
-    if ($type=='NONCE'){
-        $url .= "&user_id=".$userId;
-    }
-    $result = curlRequest($url);
-    $result = json_decode($result,true);
-    if ($result['code']==0){
-        return $result;
-    }
-    echo $result['msg'];die;
-}
-
-/**
- * 生成签名
- */
-function generateSign($userId){
-    $wbappid = getFaceInfo()['appid'];
-    $version = '1.0.0';
-    $ticket = getApiTicket('SIGN')['tickets'][0]['value'];
-    $nonce = get32Str();
-
-   // $array = ['wbappid'=>$wbappid, 'userId'=>"$userId",'nonce'=>$nonce, 'version'=>$version, 'ticket'=>$ticket];
-    $array = [$wbappid, "$userId",$nonce, $version, $ticket];
-    file_put_contents("signLog.txt", json_encode($array) . "\n" . "\n", FILE_APPEND);
-    sort($array);
-    $str='';
-    foreach ($array as $kk=>$vv){
-        $str .=$vv;
-    }
-   // echo $str;die;
-    $result = strtoupper(sha1($str));
-    $res['sign'] = $result;
-    $res['nonce'] = $nonce;
-    $res['appid'] = $wbappid;
-    return $res;
-}
-
-/**
- * 合作方后台上送身份信息
- */
-function getfaceid($name,$idNo,$userId){
-    $webankAppId = getFaceInfo()['appid'];
-    $orderNo = get32Str();
-    $sign = generateSign($userId);
-    $data = [
-        'webankAppId'=>$webankAppId,
-        'orderNo'=>$orderNo,
-        'name'=>$name,
-        'idNo'=>$idNo,
-        'userId'=>"$userId",
-        'version'=>'1.0.0',
-        'sign'=>$sign['sign'],
-        'nonce'=>$sign['nonce']
-    ];
-    $headers = [];
-    array_push($headers, "Content-Type".":"."application/json; charset=UTF-8");
-    $url = 'https://miniprogram-kyc.tencentcloudapi.com/api/server/getfaceid?orderNo='.$orderNo;
-    $result = curlRequest($url,$headers,json_encode($data),'POST');
-    $result = json_decode($result,true);
-    if ($result['code']==0){
-        $data = [
-            'appid'=>$sign['appid'],
-            'userID'=>"$userId",
-            'sign'=>$sign['sign'],
-            'nonce'=>$sign['nonce'],
-            'sdksign'=>SdkSign($userId,$sign['nonce']),
-            'result'=>$result['result'],
-        ];
-        return $data;
-    }
-    echo $result['msg'];die;
-}
-
-
-
-
-
-
-
-/**
- * 生成 SDK 接口调用步骤使用签名
- */
-function SdkSign($userId,$nonce){
-    $wbappid = getFaceInfo()['appid'];
-    $version = '1.0.0';
-    $ticket = getApiTicket('NONCE',$userId)['tickets'][0]['value'];
-    //$nonce = get32Str();
-
-    $array = [$wbappid, "$userId",$nonce, $version, $ticket];
-    file_put_contents("sdksignLog.txt", json_encode($array) . "\n" . "\n", FILE_APPEND);
-    sort($array);
-    $str='';
-    foreach ($array as $kk=>$vv){
-        $str .=$vv;
-    }
-    $result = strtoupper(sha1($str));
-    return $result;
-}
-
-
-
-function getFaceInfo(){
-    //正式
-    $date = [
-        'appid'=>'IDAKcvCn',
-        'secret'=>'L1id3z5zROK8SVXg72ZyZXc8ziniYLKpOnIzN1gecrBaEMaKIlKrreyRGCLU2z4l'
-    ];
-    //测试
-//    $date = [
-//        'appid'=>'TIDA3uGO',
-//        'secret'=>'z41IysbEhRy5oR4Qs2kFfVkrufXIJMtsJOQ3eulkWwXwdKG772LSSiZsKKwfsv9n'
-//    ];
-    return $date;
-}
-
-
-
-//将数组转成uri字符串
-function formatBizQueryParaMap($paraMap, $urlencode)
-{
-    $buff = "";
-    ksort($paraMap);
-    foreach ($paraMap as $k => $v)
-    {
-        if($urlencode)
-        {
-            $v = urlencode($v);
-        }
-       // $buff .= strtolower($k) . "=" . $v . "&";
-        $buff .=  $v;
-    }
-    if (strlen($buff) > 0)
-    {
-        $reqPar = substr($buff, 0, strlen($buff)-1);
-    }
-    return $reqPar;
-}
-
-
-/**
- * 生成32位随机数
- */
-function get32Str($length='32'){
-    $str = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
-    $len = strlen($str)-1;
-    $randstr = '';
-    for ($i=0;$i<$length;$i++) {
-        $num=mt_rand(0,$len);
-        $randstr .= $str[$num];
-    }
-    return $randstr;
-}
-
-/**
- * 盲盒藏品库存和藏品状态判断
- * @param $proArr
- * @return int|string
- */
-function checkBoxCollection($coll_id){
-    $list = Db::name('store_box')
-        ->where('status',1)
-        ->where('coll_id',$coll_id)
-        ->where('is_del',1)
-        ->field('id,is_prize,prize')
-        ->select();
-    foreach ($list as &$v){
-        if ($v['is_prize']==1){
-            $info = Db::name('store_collection')->where('id',$v['prize'])->find();
-            $now_inventory = getCollectionInventory($info['id']);
-            if ($now_inventory<=0 || $info['status']==0 || $info['is_deleted']==1){
-                Db::name('store_box')->where('id',$v['id'])->update(['status'=>0]);
-            }
-        }
-    }
-}
-
-function get_order_sn(){
-    $order_id_main = date('YmdHis') . rand(10000000,99999999);
-    $order_id_len = strlen($order_id_main);
-    $order_id_sum = 0;
-    for($i=0; $i<$order_id_len; $i++){
-        $order_id_sum += (int)(substr($order_id_main,$i,1));
-    }
-    $osn = $order_id_main . str_pad((100 - $order_id_sum % 100) % 100,2,'0',STR_PAD_LEFT);
-    return $osn;
-}
-
-
-/**
- * 生成二维码
- */
-function setqrcode($value,$name){
-    $dir = dirname(realpath(dirname($_SERVER['SCRIPT_FILENAME']))) . '/public/user';
-    if(!file_exists($dir)){
-        //检查是否有该文件夹,如果没有就创建,并给予最高权限
-        mkdir($dir, 0700,true);
-    }
-    $filename = $dir.'/'.$name.'.png';
-    QRcode::png($value,$filename,QR_ECLEVEL_L,7);
-
-    $storage_type = getConfigValue('storage_type');
-    if ($storage_type == 'oss'){
-        $ossClient = new OssClient(getConfigValue('storage_oss_keyid'), getConfigValue('storage_oss_secret'), getConfigValue('storage_oss_endpoint'));
-        $file_path = dirname($_SERVER['SCRIPT_FILENAME']) . "/user/".$name.".png";
-        $newName = date('Ymd').'/'.get_order_sn().'.png';
-        $result = $ossClient->uploadFile(getConfigValue('storage_oss_bucket'), $newName, $file_path);
-        $url = $result['info']['url'];
-        unlink($file_path);
-    }else{
-      $url = 'http://'.$_SERVER['SERVER_NAME']."/user/".$name.'.png';
-    }
-    return $url;
-}
-
-//生成邀请二维码
-function setintivecode($user_id){
-    $name = $user_id."_".time();
-    $address = 'https://'.$_SERVER['SERVER_NAME'].'/pages/mine/zhuce?invite_code='.$user_id;
-
-    $url = setqrcode($address,$name);
-    return $url;
-}
-
-//邀请地址
-function getintiveaddress($user_id){
-    $address = 'https://'.$_SERVER['SERVER_NAME'].'/pages/mine/zhuce?invite_code='.$user_id;
-    return $address;
-}
-
-
-
-/**
- * @param $url
- * @param array $headers
- * @param array $body
- * @param string $method
- * @return bool|string
- */
-function curlRequest($url, $headers = [], $body = [], $method = "GET")
-{
-
-    $ch = curl_init();
-    curl_setopt($ch, CURLOPT_URL, $url);
-    curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);//设置请求头
-    curl_setopt($ch, CURLOPT_POSTFIELDS, $body);//设置请求体
-    curl_setopt($ch, CURLOPT_CUSTOMREQUEST, $method); //定义请求类型
-    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
-    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
-    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
-    curl_setopt($ch, CURLOPT_HTTP_VERSION, 'CURL_HTTP_VERSION_1_1');
-    $output = curl_exec($ch);
-    curl_close($ch);
-    return $output;
-}
-
-
-/**
- * 盲盒藏品库存和藏品状态判断
- * @param $proArr
- * @return int|string
- */
-function checkBox(){
-    $list = Db::name('store_blind_box')
-        ->where('status',1)
-        ->where('is_del',1)
-        ->field('id,is_prize,prize')
-        ->select();
-    foreach ($list as &$v){
-        if ($v['is_prize']==1){
-            $info = Db::name('store_collection')->where('id',$v['prize'])->find();
-            if ($info['now_inventory']<=0 || $info['status']==0 || $info['is_deleted']==1){
-                Db::name('store_blind_box')->where('id',$v['id'])->update(['status'=>0]);
-            }
-        }
-    }
-}
-
-
-//计算中奖概率
-function get_rand($proArr) {
-    $result = '';
-    //概率数组的总概率精度
-    $proSum = array_sum($proArr);
-    // var_dump($proSum);
-    //概率数组循环
-    foreach ($proArr as $key => $proCur) {
-        $randNum = mt_rand(1, $proSum); //返回随机整数
-
-        if ($randNum <= $proCur) {
-            $result = $key;
-            break;
-        } else {
-            $proSum -= $proCur;
-        }
-    }
-    unset ($proArr);
-    return $result;
-}
-
-
-/**
- * 获取链上ip
- */
-function getIpAddress(){
-    $address = 'http://120.27.21.5:8083/';
-    return $address;
-}
-
-
-/**
- * 调试函数
- */
-function debug($str){
-    $str = var_export($str,true).PHP_EOL;
-    $str.= date('Y-m-d H:i:s').'   ';
-    $str.= $_SERVER['REMOTE_ADDR'].'   ';
-    $str.= $_SERVER['REQUEST_METHOD'].': ';
-    // $str.=$_SERVER['HTTP_HOST'];
-    $str.= $_SERVER['REQUEST_URI'].''.PHP_EOL.PHP_EOL;
-    $str='<?php exit();?>'.PHP_EOL.$str;
-    error_log($str,3,"debug.log");
-}
-
-
-function getAge($id){
-
-# 1.从身份证中获取出生日期
-    $id = $id;//身份证
-    $birth_Date = strtotime(substr($id, 6, 8));//截取日期并转为时间戳
-
-# 2.格式化[出生日期]
-    $Year = date('Y', $birth_Date);//yyyy
-    $Month = date('m', $birth_Date);//mm
-    $Day = date('d', $birth_Date);//dd
-
-# 3.格式化[当前日期]
-    $current_Y = date('Y');//yyyy
-    $current_M = date('m');//mm
-    $current_D = date('d');//dd
-
-# 4.计算年龄()
-    $age = $current_Y - $Year;//今年减去生日年
-    if($Month > $current_M || $Month == $current_M && $Day > $current_D){//深层判断(日)
-        $age--;//如果出生月大于当前月或出生月等于当前月但出生日大于当前日则减一岁
-    }
-# 返回
-    return $age;
-
-}
-
-/**
- * 金额校验函数
- * @param $value
- * @param bool $isZero
- * @param bool $negative
- * @return bool
- */
-function isAmount($value, $isZero=false, $negative=false){
-    // 必须是整数或浮点数,且允许为负
-    if (!preg_match("/^[-]?\d+(.\d{1,2})?$/", $value)){
-        return false;
-    }
-    // 不为 0
-    if (!$isZero && empty((int)($value*100))){
-        return false;
-    }
-    // 不为负数
-    if (!$negative && (int)($value * 100) < 0){
-        return false;
-    }
-    return true;
-}
-
-
-//注册邀请奖励
-function pull_new($mid){
-    checkactivity();
-    //判断有没有正在进行的活动
-    $act = Db::name('store_activity')
-        ->where('is_del',1)
-        ->where('state',1)
-        ->where('status',2)
-        ->find();
-    if ($act){
-        $user1 = getMemberInfoHash($mid); //获取用户信息
-        if ($user1['pid']){
-            //先判断有没有单人拉新奖励活动
-            $info = Db::name('store_activities')
-                ->where('ac_id',$act['id'])
-                ->where('is_del',1)
-                ->where('type',2)
-                ->where('state',1)
-                ->find();
-            if ($info){
-                $pro_info = getCollectionInfoHash($info['c_id2']);
-                $now_inventory = getCollectionInventory($info['c_id2']);
-                if ($now_inventory>0){
-                    $is_nft = Db::name('hash2')->where('goods_id',$info['c_id2'])->find();
-                    if (!$is_nft || !$is_nft['success']){
-
-                    }else{
-                        //获取排名
-                        $rank = getRanking($info['c_id2'])+1;
-                        $tag = getTag($info['c_id2'],$rank,$pro_info['inventory']);
-                        saveRanking($info['c_id2']);
-                        $collectors_hash = '';
-                        $date = [
-                            'order_no'=>get_order_sn(),
-                            'tag'=>$tag,
-                            'mid'=>$mid,
-                            'c_id'=>$info['c_id2'],
-                            'name'=>$pro_info['name'],
-                            'cover'=>$pro_info['cover'],
-                            'pro_info'=>json_encode($pro_info,true),
-                            'type'=>$pro_info['type'],
-                            'tokenid'=>$is_nft['class_id'],
-                            'nfttype'=>$is_nft['operationId'],
-                            'collectors_hash'=>$collectors_hash,
-                            'remark'=>'新人被邀请奖励'
-                        ];
-                        if (Db::name('store_order_info')->insert($date)){
-                            loseCollectionInventory($info['c_id2'],1);
-                        }
-                    }
-                }
-            }
-
-            //判断邀请人邀请的人数
-            $count = Db::name('store_activities_invite_log')
-                ->where('mid',$user1['pid'])
-                ->where('create_at','egt',$act['start_at'])
-                ->where('create_at','elt',$act['end_at'])
-                ->count();
-            if ($count){
-                if ($count==1){
-                    if ($info){
-                        $pro_info = getCollectionInfoHash($info['c_id']);
-                        $now_inventory = getCollectionInventory($info['c_id']);
-                        if ($now_inventory>0){
-                            $is_nft = Db::name('hash2')->where('goods_id',$info['c_id'])->find();
-                            if (!$is_nft || !$is_nft['success']){
-
-                            }else{
-                                //获取排名
-                                $rank = getRanking($info['c_id'])+1;
-                                $tag = getTag($info['c_id'],$rank,$pro_info['inventory']);
-                                saveRanking($info['c_id']);
-                                $collectors_hash = '';
-                                $dates = [
-                                    'order_no'=>get_order_sn(),
-                                    'tag'=>$tag,
-                                    'mid'=>$user1['pid'],
-                                    'c_id'=>$info['c_id'],
-                                    'name'=>$pro_info['name'],
-                                    'cover'=>$pro_info['cover'],
-                                    'pro_info'=>json_encode($pro_info,true),
-                                    'type'=>$pro_info['type'],
-                                    'tokenid'=>$is_nft['class_id'],
-                                    'nfttype'=>$is_nft['operationId'],
-                                    'collectors_hash'=>$collectors_hash,
-                                    'remark'=>'邀请单人奖励'
-                                ];
-                                if (Db::name('store_order_info')->insert($dates)){
-                                    loseCollectionInventory($info['c_id'],1);
-                                }
-                            }
-                        }
-                    }
-                }else{
-                    //查询有没有当前人数的活动
-                    $info = Db::name('store_activities')
-                        ->where('ac_id',$act['id'])
-                        ->where('is_del',1)
-                        ->where('type',3)
-                        ->where('state',1)
-                        ->where('num',$count)
-                        ->find();
-                    if ($info){
-                        $pro_info = getCollectionInfoHash($info['c_id']);
-                        $now_inventory = getCollectionInventory($info['c_id']);
-                        if ($now_inventory>0){
-                            $is_nft = Db::name('hash2')->where('goods_id',$info['c_id'])->find();
-                            if (!$is_nft || !$is_nft['success']){
-
-                            }else{
-                                //获取排名
-                                $rank = getRanking($info['c_id'])+1;
-                                $tag = getTag($info['c_id'],$rank,$pro_info['inventory']);
-                                saveRanking($info['c_id']);
-                                $collectors_hash = '';
-                                $dates = [
-                                    'order_no'=>get_order_sn(),
-                                    'tag'=>$tag,
-                                    'mid'=>$user1['pid'],
-                                    'c_id'=>$info['c_id'],
-                                    'name'=>$pro_info['name'],
-                                    'cover'=>$pro_info['cover'],
-                                    'pro_info'=>json_encode($pro_info,true),
-                                    'type'=>$pro_info['type'],
-                                    'tokenid'=>$is_nft['class_id'],
-                                    'nfttype'=>$is_nft['operationId'],
-                                    'collectors_hash'=>$collectors_hash,
-                                    'remark'=>'邀请'.$count.'人奖励'
-                                ];
-                                if (Db::name('store_order_info')->insert($dates)){
-                                    loseCollectionInventory($info['c_id'],1);
-                                }
-                            }
-                        }
-                    }
-                }
-            }
-        }else{
-            //判断新人注册是否有活动
-            $info = Db::name('store_activities')
-                ->where('ac_id',$act['id'])
-                ->where('is_del',1)
-                ->where('state',1)
-                ->where('type',1)
-                ->find();
-            if ($info){
-                $pro_info = getCollectionInfoHash($info['c_id']);
-                $now_inventory = getCollectionInventory($info['c_id']);
-                if ($now_inventory>0){
-                    $is_nft = Db::name('hash2')->where('goods_id',$info['c_id'])->find();
-                    if (!$is_nft || !$is_nft['success']){
-
-                    }else{
-                        //获取排名
-                        $rank = getRanking($info['c_id'])+1;
-                        $tag = getTag($info['c_id'],$rank,$pro_info['inventory']);
-                        saveRanking($info['c_id']);
-                        $collectors_hash = '';
-                        $date = [
-                            'order_no'=>get_order_sn(),
-                            'tag'=>$tag,
-                            'mid'=>$mid,
-                            'c_id'=>$info['c_id'],
-                            'name'=>$pro_info['name'],
-                            'cover'=>$pro_info['cover'],
-                            'pro_info'=>json_encode($pro_info,true),
-                            'type'=>$pro_info['type'],
-                            'tokenid'=>$is_nft['class_id'],
-                            'nfttype'=>$is_nft['operationId'],
-                            'collectors_hash'=>$collectors_hash,
-                            'remark'=>'新人注册奖励'
-                        ];
-                        if (Db::name('store_order_info')->insert($date)){
-                            loseCollectionInventory($info['c_id'],1);
-                        }
-                    }
-
-                }
-            }
-        }
-    }
-    return true;
-
-}
-
-function pullNew($mid){
-    //判断给拉新奖励
-    $user1 = getMemberInfoHash($mid); //获取用户信息
-    if ($user1['pid']){
-        //获取奖励列表
-        $ids = Db::name('store_collection')
-            ->where('is_deleted',0)
-            ->where('pull_new',1)
-            ->column('id');
-        if ($ids){
-            $array = [];
-            foreach ($ids as &$v){
-                $now_inventory = getCollectionInventory($v);
-                if ($now_inventory>1){
-                    array_push($array,$v);
-                }
-            }
-            if ($array){
-                $vaule = array_rand($array);
-                $id =  $array[$vaule];
-                $info = getCollectionInfoHash($id);
-                $is_nft = Db::name('hash2')->where('goods_id',$id)->where('success',1)->find();
-                //获取排名
-                $rank = getRanking($id)+1;
-                $tag = getTag($id,$rank,$info['inventory']);
-                saveRanking($id);
-                $collectors_hash = '';
-                $date = [
-                    'order_no'=>get_order_sn(),
-                    'tag'=>$tag,
-                    'mid'=>$user1['pid'],
-                    'c_id'=>$id,
-                    'name'=>$info['name'],
-                    'cover'=>$info['cover'],
-                    'pro_info'=>json_encode($info,true),
-                    'type'=>$info['type'],
-                    'tokenid'=>$is_nft['class_id'],
-                    'nfttype'=>$is_nft['operationId'],
-                    'collectors_hash'=>$collectors_hash,
-                    'remark'=>'拉新奖励'
-                ];
-                Db::name('store_order_info')->insert($date);
-
-//                //获取排名
-//                $rank = getRanking($id)+1;
-//                $tag = getTag($id,$rank,$info['inventory']);
-//                saveRanking($id);
-//                $collectors_hash = '';
-//                $data = [
-//                    'order_no'=>get_order_sn(),
-//                    'tag'=>$tag,
-//                    'mid'=>$mid,
-//                    'c_id'=>$id,
-//                    'name'=>$info['name'],
-//                    'cover'=>$info['cover'],
-//                    'pro_info'=>json_encode($info,true),
-//                    'type'=>$info['type'],
-//                    'tokenid'=>$is_nft['class_id'],
-//                    'nfttype'=>$is_nft['operationId'],
-//                    'collectors_hash'=>$collectors_hash,
-//                    'collectors_hash_time'=>'',
-//                    'remark'=>'被拉新奖励'
-//                ];
-//                Db::name('store_order_info')->insert($data);
-            }
-        }
-
-        //获取奖励列表
-        $ids2 = Db::name('store_collection')
-            ->where('is_deleted',0)
-            ->where('pull_new2',1)
-            ->column('id');
-        if ($ids2){
-            $array2 = [];
-            foreach ($ids2 as &$v){
-                $now_inventory2 = getCollectionInventory($v);
-                if ($now_inventory2>1){
-                    array_push($array,$v);
-                }
-            }
-            if ($array2){
-                $vaule = array_rand($array2);
-                $id2 =  $array2[$vaule];
-                $info2 = getCollectionInfoHash($id2);
-                $is_nft2 = Db::name('hash2')->where('goods_id',$id2)->where('success',1)->find();
-                //获取排名
-                $rank = getRanking($id2)+1;
-                $tag = getTag($id2,$rank,$info2['inventory']);
-                saveRanking($id2);
-                $collectors_hash = '';
-                $data2 = [
-                    'order_no'=>get_order_sn(),
-                    'tag'=>$tag,
-                    'mid'=>$mid,
-                    'c_id'=>$id2,
-                    'name'=>$info2['name'],
-                    'cover'=>$info2['cover'],
-                    'pro_info'=>json_encode($info2,true),
-                    'type'=>$info2['type'],
-                    'tokenid'=>$is_nft2['class_id'],
-                    'nfttype'=>$is_nft2['operationId'],
-                    'collectors_hash'=>$collectors_hash,
-                    'remark'=>'被拉新奖励'
-                ];
-                Db::name('store_order_info')->insert($data2);
-            }
-        }
-    }
-
-}
-/**
- * 判断邀请人活动
- * @param $proArr
- * @return int|string
- */
-function checkactivity($id=''){
-    if ($id){
-        $info = Db::name('store_activity')->where('id',$id)->find();
-        if (time()<strtotime($info['start_at'])){
-            Db::name('store_activity')->where('id',$id)->update(['status'=>1]);
-        }elseif (time()>strtotime($info['start_at']) && time()<strtotime($info['end_at'])){
-            Db::name('store_activity')->where('id',$id)->update(['status'=>2]);
-        }elseif (time()>strtotime($info['end_at'])){
-            Db::name('store_activity')->where('id',$id)->update(['status'=>3]);
-        }
-    }else{
-        $list = Db::name('store_activity')->where('is_del',1)->select();
-        foreach ($list as &$v){
-            if (time()<strtotime($v['start_at'])){
-                Db::name('store_activity')->where('id',$v['id'])->update(['status'=>1]);
-            }elseif (time()>strtotime($v['start_at']) && time()<strtotime($v['end_at'])){
-                Db::name('store_activity')->where('id',$v['id'])->update(['status'=>2]);
-            }elseif (time()>strtotime($v['end_at'])){
-                Db::name('store_activity')->where('id',$v['id'])->update(['status'=>3]);
-            }
-        }
-    }
-}
-
-
-/**
- * 登录日志
- */
-function LoginLog($mid){
-    $data = [
-        'mid'=>$mid,
-        'ip'=>request()->ip()
-    ];
-    Db::name('store_login_log')->insert($data);
-}
-
-
-/**
- * 判断银行卡号格式
- */
-function checkbank($no=""){
-    if(empty($no)) return false;
-    $arr_no = str_split($no);
-    $last_n = $arr_no[count($arr_no)-1];
-    krsort($arr_no);
-    $i = 1;
-    $total = 0;
-    foreach ($arr_no as $n){
-        if($i%2==0){
-            $ix = $n*2;
-            if($ix>=10){
-                $nx = 1 + ($ix % 10);
-                $total += $nx;
-            }else{
-                $total += $ix;
-            }
-        }else{
-            $total += $n;
-        }
-        $i++;
-    }
-    $total -= $last_n;
-    $x = 10 - ($total % 10);
-    if($x == $last_n){
-        return true;
-    }else{
-        return false;
-    }
-}
-
-
-
-

+ 0 - 53
application/common/Api/ConfigApi.php

@@ -1,53 +0,0 @@
-<?php
-// +----------------------------------------------------------------------
-// | TwoThink [ WE CAN DO IT JUST THINK ]
-// +----------------------------------------------------------------------
-// | Copyright (c) 2013 http://www.twothink.cn All rights reserved.
-// +----------------------------------------------------------------------
-// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
-// +----------------------------------------------------------------------
-// | Author: 田建龙 <864491238@qq.com>
-// +----------------------------------------------------------------------
-
-namespace app\common\Api;
-class ConfigApi {
-    /**
-     * 获取数据库中的配置列表
-     * @return array 配置数组
-     */
-    public static function lists(){
-        $map  = array('status' => 1);
-        $data = \think\Db::name('Config')->where($map)->field('type,name,value')->select();
-        
-        $config = array();
-        if($data){
-            foreach ($data as $value) {
-                $config[$value['name']] = self::parse($value['type'], $value['value']);
-            }
-        }
-        return $config;
-    }
-
-    /**
-     * 根据配置类型解析配置
-     * @param  integer $type  配置类型
-     * @param  string  $value 配置值
-     */
-    private static function parse($type, $value){
-        switch ($type) {
-            case 3: //解析数组
-                $array = preg_split('/[,;\r\n]+/', trim($value, ",;\r\n"));
-                if(strpos($value,':')){
-                    $value  = array();
-                    foreach ($array as $val) {
-                        list($k, $v) = explode(':', $val);
-                        $value[$k]   = $v;
-                    }
-                }else{
-                    $value =    $array;
-                }
-                break;
-        }
-        return $value;
-    }	
-}

+ 0 - 76
application/common/behavior/Common.php

@@ -1,76 +0,0 @@
-<?php
-
-namespace app\common\behavior;
-
-use think\Config;
-use think\Lang;
-use think\Loader;
-
-class Common
-{
-
-    public function moduleInit(&$request)
-    {
-        // 设置mbstring字符编码
-        mb_internal_encoding("UTF-8");
-
-        // 如果修改了index.php入口地址,则需要手动修改cdnurl的值
-        $url = preg_replace("/\/(\w+)\.php$/i", '', $request->root());
-        // 如果未设置__CDN__则自动匹配得出
-        if (!Config::get('view_replace_str.__CDN__'))
-        {
-            Config::set('view_replace_str.__CDN__', $url);
-        }
-        // 如果未设置__PUBLIC__则自动匹配得出
-        if (!Config::get('view_replace_str.__PUBLIC__'))
-        {
-            Config::set('view_replace_str.__PUBLIC__', $url . '/');
-        }
-        // 如果未设置__ROOT__则自动匹配得出
-        if (!Config::get('view_replace_str.__ROOT__'))
-        {
-            Config::set('view_replace_str.__ROOT__', preg_replace("/\/public\/$/", '', $url . '/'));
-        }
-        // 如果未设置cdnurl则自动匹配得出
-        if (!Config::get('site.cdnurl'))
-        {
-            Config::set('site.cdnurl', $url);
-        }
-        // 如果未设置cdnurl则自动匹配得出
-        if (!Config::get('upload.cdnurl'))
-        {
-            Config::set('upload.cdnurl', $url);
-        }
-        if (Config::get('app_debug'))
-        {
-            // 如果是调试模式将version置为当前的时间戳可避免缓存
-            Config::set('site.version', time());
-            // 如果是开发模式那么将异常模板修改成官方的
-            Config::set('exception_tmpl', THINK_PATH . 'tpl' . DS . 'think_exception.tpl');
-        }
-        // 如果是trace模式且Ajax的情况下关闭trace
-        if (Config::get('app_trace') && $request->isAjax())
-        {
-            Config::set('app_trace', false);
-        }
-        // 切换多语言
-        if (Config::get('lang_switch_on') && $request->get('lang'))
-        {
-            \think\Cookie::set('think_var', $request->get('lang'));
-        }
-        // Form别名
-        if (!class_exists('Form')) {
-            class_alias('fast\\Form', 'Form');
-        }
-    }
-
-    public function addonBegin(&$request)
-    {
-        // 加载插件语言包
-        Lang::load([
-            APP_PATH . 'common' . DS . 'lang' . DS . $request->langset() . DS . 'addon' . EXT,
-        ]);
-        $this->moduleInit($request);
-    }
-
-}

+ 0 - 114
application/common/controller/Api.php

@@ -1,114 +0,0 @@
-<?php
-
-namespace app\common\controller;
-
-use app\common\model\User;
-use think\exception\HttpResponseException;
-use think\facade\Request;
-use think\Response;
-
-/**
- * API控制器基类
- */
-class Api
-{
-
-    /**
-     * @var Request Request 实例
-     */
-    protected $request;
-
-    /**
-     * @var bool 验证失败是否抛出异常
-     */
-    protected $failException = true;
-
-    /**
-     * 默认响应输出类型,支持json/xml
-     * @var string 
-     */
-    protected $responseType = 'json';
-
-
-    /**
-     * 操作成功返回的数据
-     * @param string $msg   提示信息
-     * @param mixed $data   要返回的数据
-     * @param int   $code   错误码,默认为1
-     * @param string $type  输出类型
-     * @param array $header 发送的 Header 信息
-     */
-    protected function success($msg = '', $data = null , $is_login = 1, $code = 1, $type = null, array $header = [])
-    {
-        $this->result($msg, $data, $is_login, $code, $type, $header);
-    }
-
-    /**
-     * 操作失败返回的数据
-     * @param string $msg   提示信息
-     * @param mixed $data   要返回的数据
-     * @param int   $code   错误码,默认为0
-     * @param string $type  输出类型
-     * @param array $header 发送的 Header 信息
-     */
-    protected function error($msg = '', $data = null, $is_login = 1, $code = 0, $type = null, array $header = [])
-    {
-        $this->result($msg, $data, $is_login, $code, $type, $header);
-    }
-
-    /**
-     * 返回封装后的 API 数据到客户端
-     * @access protected
-     * @param mixed  $msg    提示信息
-     * @param mixed  $data   要返回的数据
-     * @param int    $code   错误码,默认为0
-     * @param string $type   输出类型,支持json/xml/jsonp
-     * @param array  $header 发送的 Header 信息
-     * @return void
-     * @throws HttpResponseException
-     */
-    protected function result($msg, $data = null, $is_login, $code = 0, $type = null, array $header = [])
-    {
-        $result = [
-            'code' => $code,
-            'is_login' => $is_login,
-            'msg'  => $msg,
-            'time' => Request::instance()->server('REQUEST_TIME'),
-            'data' => $data,
-        ];
-        // 如果未设置类型则自动判断
-        $type = $type ? $type : 'json';
-
-        if (isset($header['statuscode']))
-        {
-            $code = $header['statuscode'];
-            unset($header['statuscode']);
-        }
-        else
-        {
-            //未设置状态码,根据code值判断
-            $code = $code >= 1000 || $code < 200 ? 200 : $code;
-        }
-        $response = Response::create($result, $type, $code)->header($header);
-        throw new HttpResponseException($response);
-    }
-
-    /**
-     * 判断登录
-     * @return bool
-     */
-    protected function check_login(){
-        $user =  app()->session->get('us');
-        if (!$user){
-            $this->error('请先登录','',0);
-        }
-        $userinfo = User::where('id',$user['id'])->find();
-        if ($userinfo['status']!=1){
-            app()->session->clear();
-            app()->session->destroy();
-            $this->error('账号被禁用','',0);
-        }
-        return true;
-    }
-
-}

+ 0 - 471
application/common/controller/Backend.php

@@ -1,471 +0,0 @@
-<?php
-
-namespace app\common\controller;
-
-use think\Config;
-use think\Controller;
-use think\Hook;
-use think\Lang;
-use think\Session;
-
-/**
- * 后台控制器基类
- */
-class Backend extends Controller
-{
-
-    /**
-     * 无需登录的方法,同时也就不需要鉴权了
-     * @var array
-     */
-    protected $noNeedLogin = [];
-
-    /**
-     * 无需鉴权的方法,但需要登录
-     * @var array
-     */
-    protected $noNeedRight = [];
-
-    /**
-     * 布局模板
-     * @var string
-     */
-    protected $layout = 'default';
-
-    /**
-     * 权限控制类
-     * @var Auth
-     */
-    protected $auth = null;
-
-    /**
-     * 模型对象
-     * @var \think\Model
-     */
-    protected $model = null;
-
-    /**
-     * 快速搜索时执行查找的字段
-     */
-    protected $searchFields = 'id';
-
-    /**
-     * 是否是关联查询
-     */
-    protected $relationSearch = false;
-
-    /**
-     * 是否开启数据限制
-     * 支持auth/personal
-     * 表示按权限判断/仅限个人
-     * 默认为禁用,若启用请务必保证表中存在admin_id字段
-     */
-    protected $dataLimit = false;
-
-    /**
-     * 数据限制字段
-     */
-    protected $dataLimitField = 'admin_id';
-
-    /**
-     * 数据限制开启时自动填充限制字段值
-     */
-    protected $dataLimitFieldAutoFill = true;
-
-    /**
-     * 是否开启Validate验证
-     */
-    protected $modelValidate = false;
-
-    /**
-     * 是否开启模型场景验证
-     */
-    protected $modelSceneValidate = false;
-
-    /**
-     * Multi方法可批量修改的字段
-     */
-    protected $multiFields = 'status';
-
-    /**
-     * Selectpage可显示的字段
-     */
-    protected $selectpageFields = '*';
-
-    /**
-     * 导入文件首行类型
-     * 支持comment/name
-     * 表示注释或字段名
-     */
-    protected $importHeadType = 'comment';
-
-    /**
-     * 引入后台控制器的traits
-     */
-
-    public function _initialize()
-    {
-        $modulename = $this->request->module();
-        $controllername = strtolower($this->request->controller());
-        $actionname = strtolower($this->request->action());
-
-        $path = str_replace('.', '/', $controllername) . '/' . $actionname;
-
-        // 定义是否Addtabs请求
-        !defined('IS_ADDTABS') && define('IS_ADDTABS', input("addtabs") ? TRUE : FALSE);
-
-        // 定义是否Dialog请求
-        !defined('IS_DIALOG') && define('IS_DIALOG', input("dialog") ? TRUE : FALSE);
-
-        // 定义是否AJAX请求
-        !defined('IS_AJAX') && define('IS_AJAX', $this->request->isAjax());
-
-        $this->auth = Auth::instance();
-
-        // 设置当前请求的URI
-        $this->auth->setRequestUri($path);
-        // 检测是否需要验证登录
-        if (!$this->auth->match($this->noNeedLogin)) {
-            //检测是否登录
-            if (!$this->auth->isLogin()) {
-                Hook::listen('admin_nologin', $this);
-                $url = Session::get('referer');
-                $url = $url ? $url : $this->request->url();
-                $this->error(__('Please login first'), url('index/login', ['url' => $url]));
-            }
-            // 判断是否需要验证权限
-            if (!$this->auth->match($this->noNeedRight)) {
-                // 判断控制器和方法判断是否有对应权限
-                if (!$this->auth->check($path)) {
-                    Hook::listen('admin_nopermission', $this);
-                    $this->error(__('You have no permission'), '');
-                }
-            }
-        }
-
-        // 非选项卡时重定向
-        if (!$this->request->isPost() && !IS_AJAX && !IS_ADDTABS && !IS_DIALOG && input("ref") == 'addtabs') {
-            $url = preg_replace_callback("/([\?|&]+)ref=addtabs(&?)/i", function ($matches) {
-                return $matches[2] == '&' ? $matches[1] : '';
-            }, $this->request->url());
-            if (Config::get('url_domain_deploy')) {
-                if (stripos($url, $this->request->server('SCRIPT_NAME')) === 0) {
-                    $url = substr($url, strlen($this->request->server('SCRIPT_NAME')));
-                }
-                $url = url($url, '', false);
-            }
-            $this->redirect('index/index', [], 302, ['referer' => $url]);
-            exit;
-        }
-
-        // 设置面包屑导航数据
-        $breadcrumb = $this->auth->getBreadCrumb($path);
-        array_pop($breadcrumb);
-        $this->view->breadcrumb = $breadcrumb;
-
-        // 如果有使用模板布局
-        if ($this->layout) {
-            $this->view->engine->layout('layout/' . $this->layout);
-        }
-
-        // 语言检测
-        $lang = strip_tags($this->request->langset());
-
-        $site = Config::get("site");
-
-        $upload = \app\common\model\Config::upload();
-
-        // 上传信息配置后
-        Hook::listen("upload_config_init", $upload);
-
-        // 配置信息
-        $config = [
-            'site'           => array_intersect_key($site, array_flip(['name', 'indexurl', 'cdnurl', 'version', 'timezone', 'languages'])),
-            'upload'         => $upload,
-            'modulename'     => $modulename,
-            'controllername' => $controllername,
-            'actionname'     => $actionname,
-            'jsname'         => 'backend/' . str_replace('.', '/', $controllername),
-            'moduleurl'      => rtrim(url("/{$modulename}", '', false), '/'),
-            'language'       => $lang,
-            'fastadmin'      => Config::get('fastadmin'),
-            'referer'        => Session::get("referer")
-        ];
-        $config = array_merge($config, Config::get("view_replace_str"));
-
-        Config::set('upload', array_merge(Config::get('upload'), $upload));
-
-        // 配置信息后
-        Hook::listen("config_init", $config);
-        //加载当前控制器语言包
-        $this->loadlang($controllername);
-        //渲染站点配置
-        $this->assign('site', $site);
-        //渲染配置信息
-        $this->assign('config', $config);
-        //渲染权限对象
-        $this->assign('auth', $this->auth);
-        //渲染管理员对象
-        $this->assign('admin', Session::get('admin'));
-    }
-
-    /**
-     * 加载语言文件
-     * @param string $name
-     */
-    protected function loadlang($name)
-    {
-        Lang::load(APP_PATH . $this->request->module() . '/lang/' . $this->request->langset() . '/' . str_replace('.', '/', $name) . '.php');
-    }
-
-    /**
-     * 渲染配置信息
-     * @param mixed $name 键名或数组
-     * @param mixed $value 值
-     */
-    protected function assignconfig($name, $value = '')
-    {
-        $this->view->config = array_merge($this->view->config ? $this->view->config : [], is_array($name) ? $name : [$name => $value]);
-    }
-
-    /**
-     * 生成查询所需要的条件,排序方式
-     * @param mixed $searchfields 快速查询的字段
-     * @param boolean $relationSearch 是否关联查询
-     * @return array
-     */
-    protected function buildparams($searchfields = null, $relationSearch = null)
-    {
-        $searchfields = is_null($searchfields) ? $this->searchFields : $searchfields;
-        $relationSearch = is_null($relationSearch) ? $this->relationSearch : $relationSearch;
-        $search = $this->request->get("search", '');
-        $filter = $this->request->get("filter", '');
-        $op = $this->request->get("op", '', 'trim');
-        $sort = $this->request->get("sort", "id");
-        $order = $this->request->get("order", "DESC");
-        $offset = $this->request->get("offset", 0);
-        $limit = $this->request->get("limit", 0);
-        $filter = (array)json_decode($filter, TRUE);
-        $op = (array)json_decode($op, TRUE);
-        $filter = $filter ? $filter : [];
-        $where = [];
-        $tableName = '';
-        if ($relationSearch) {
-            if (!empty($this->model)) {
-                $name = \think\Loader::parseName(basename(str_replace('\\', '/', get_class($this->model))));
-                $tableName = $name . '.';
-            }
-            $sortArr = explode(',', $sort);
-            foreach ($sortArr as $index => & $item) {
-                $item = stripos($item, ".") === false ? $tableName . trim($item) : $item;
-            }
-            unset($item);
-            $sort = implode(',', $sortArr);
-        }
-        $adminIds = $this->getDataLimitAdminIds();
-        if (is_array($adminIds)) {
-            $where[] = [$tableName . $this->dataLimitField, 'in', $adminIds];
-        }
-        if ($search) {
-            $searcharr = is_array($searchfields) ? $searchfields : explode(',', $searchfields);
-            foreach ($searcharr as $k => &$v) {
-                $v = stripos($v, ".") === false ? $tableName . $v : $v;
-            }
-            unset($v);
-            $where[] = [implode("|", $searcharr), "LIKE", "%{$search}%"];
-        }
-        foreach ($filter as $k => $v) {
-            $sym = isset($op[$k]) ? $op[$k] : '=';
-            if (stripos($k, ".") === false) {
-                $k = $tableName . $k;
-            }
-            $v = !is_array($v) ? trim($v) : $v;
-            $sym = strtoupper(isset($op[$k]) ? $op[$k] : $sym);
-            switch ($sym) {
-                case '=':
-                case '!=':
-                    $where[] = [$k, $sym, (string)$v];
-                    break;
-                case 'LIKE':
-                case 'NOT LIKE':
-                case 'LIKE %...%':
-                case 'NOT LIKE %...%':
-                    $where[] = [$k, trim(str_replace('%...%', '', $sym)), "%{$v}%"];
-                    break;
-                case '>':
-                case '>=':
-                case '<':
-                case '<=':
-                    $where[] = [$k, $sym, intval($v)];
-                    break;
-                case 'FINDIN':
-                case 'FINDINSET':
-                case 'FIND_IN_SET':
-                    $where[] = "FIND_IN_SET('{$v}', " . ($relationSearch ? $k : '`' . str_replace('.', '`.`', $k) . '`') . ")";
-                    break;
-                case 'IN':
-                case 'IN(...)':
-                case 'NOT IN':
-                case 'NOT IN(...)':
-                    $where[] = [$k, str_replace('(...)', '', $sym), is_array($v) ? $v : explode(',', $v)];
-                    break;
-                case 'BETWEEN':
-                case 'NOT BETWEEN':
-                    $arr = array_slice(explode(',', $v), 0, 2);
-                    if (stripos($v, ',') === false || !array_filter($arr))
-                        continue 2;
-                    //当出现一边为空时改变操作符
-                    if ($arr[0] === '') {
-                        $sym = $sym == 'BETWEEN' ? '<=' : '>';
-                        $arr = $arr[1];
-                    } else if ($arr[1] === '') {
-                        $sym = $sym == 'BETWEEN' ? '>=' : '<';
-                        $arr = $arr[0];
-                    }
-                    $where[] = [$k, $sym, $arr];
-                    break;
-                case 'RANGE':
-                case 'NOT RANGE':
-                    $v = str_replace(' - ', ',', $v);
-                    $arr = array_slice(explode(',', $v), 0, 2);
-                    if (stripos($v, ',') === false || !array_filter($arr))
-                        continue 2;
-                    //当出现一边为空时改变操作符
-                    if ($arr[0] === '') {
-                        $sym = $sym == 'RANGE' ? '<=' : '>';
-                        $arr = $arr[1];
-                    } else if ($arr[1] === '') {
-                        $sym = $sym == 'RANGE' ? '>=' : '<';
-                        $arr = $arr[0];
-                    }
-                    $where[] = [$k, str_replace('RANGE', 'BETWEEN', $sym) . ' time', $arr];
-                    break;
-                case 'LIKE':
-                case 'LIKE %...%':
-                    $where[] = [$k, 'LIKE', "%{$v}%"];
-                    break;
-                case 'NULL':
-                case 'IS NULL':
-                case 'NOT NULL':
-                case 'IS NOT NULL':
-                    $where[] = [$k, strtolower(str_replace('IS ', '', $sym))];
-                    break;
-                default:
-                    break;
-            }
-        }
-        $where = function ($query) use ($where) {
-            foreach ($where as $k => $v) {
-                if (is_array($v)) {
-                    call_user_func_array([$query, 'where'], $v);
-                } else {
-                    $query->where($v);
-                }
-            }
-        };
-        return [$where, $sort, $order, $offset, $limit];
-    }
-
-    /**
-     * 获取数据限制的管理员ID
-     * 禁用数据限制时返回的是null
-     * @return mixed
-     */
-    protected function getDataLimitAdminIds()
-    {
-        if (!$this->dataLimit) {
-            return null;
-        }
-        if ($this->auth->isSuperAdmin()) {
-            return null;
-        }
-        $adminIds = [];
-        if (in_array($this->dataLimit, ['auth', 'personal'])) {
-            $adminIds = $this->dataLimit == 'auth' ? $this->auth->getChildrenAdminIds(true) : [$this->auth->id];
-        }
-        return $adminIds;
-    }
-
-    /**
-     * Selectpage的实现方法
-     *
-     * 当前方法只是一个比较通用的搜索匹配,请按需重载此方法来编写自己的搜索逻辑,$where按自己的需求写即可
-     * 这里示例了所有的参数,所以比较复杂,实现上自己实现只需简单的几行即可
-     *
-     */
-    protected function selectpage()
-    {
-        //设置过滤方法
-        $this->request->filter(['strip_tags', 'htmlspecialchars']);
-
-        //搜索关键词,客户端输入以空格分开,这里接收为数组
-        $word = (array)$this->request->request("q_word/a");
-        //当前页
-        $page = $this->request->request("pageNumber");
-        //分页大小
-        $pagesize = $this->request->request("pageSize");
-        //搜索条件
-        $andor = $this->request->request("andOr", "and", "strtoupper");
-        //排序方式
-        $orderby = (array)$this->request->request("orderBy/a");
-        //显示的字段
-        $field = $this->request->request("showField");
-        //主键
-        $primarykey = $this->request->request("keyField");
-        //主键值
-        $primaryvalue = $this->request->request("keyValue");
-        //搜索字段
-        $searchfield = (array)$this->request->request("searchField/a");
-        //自定义搜索条件
-        $custom = (array)$this->request->request("custom/a");
-        $order = [];
-        foreach ($orderby as $k => $v) {
-            $order[$v[0]] = $v[1];
-        }
-        $field = $field ? $field : 'name';
-
-        //如果有primaryvalue,说明当前是初始化传值
-        if ($primaryvalue !== null) {
-            $where = [$primarykey => ['in', $primaryvalue]];
-        } else {
-            $where = function ($query) use ($word, $andor, $field, $searchfield, $custom) {
-                $logic = $andor == 'AND' ? '&' : '|';
-                $searchfield = is_array($searchfield) ? implode($logic, $searchfield) : $searchfield;
-                foreach ($word as $k => $v) {
-                    $query->where(str_replace(',', $logic, $searchfield), "like", "%{$v}%");
-                }
-                if ($custom && is_array($custom)) {
-                    foreach ($custom as $k => $v) {
-                        $query->where($k, '=', $v);
-                    }
-                }
-            };
-        }
-        $adminIds = $this->getDataLimitAdminIds();
-        if (is_array($adminIds)) {
-            $this->model->where($this->dataLimitField, 'in', $adminIds);
-        }
-        $list = [];
-        $total = $this->model->where($where)->count();
-        if ($total > 0) {
-            if (is_array($adminIds)) {
-                $this->model->where($this->dataLimitField, 'in', $adminIds);
-            }
-            $datalist = $this->model->where($where)
-                ->order($order)
-                ->page($page, $pagesize)
-                ->field($this->selectpageFields)
-                ->select();
-            foreach ($datalist as $index => $item) {
-                unset($item['password'], $item['salt']);
-                $list[] = [
-                    $primarykey => isset($item[$primarykey]) ? $item[$primarykey] : '',
-                    $field      => isset($item[$field]) ? $item[$field] : ''
-                ];
-            }
-        }
-        //这里一定要返回有list这个字段,total是可选的,如果total<=list的数量,则会隐藏分页按钮
-        return json(['list' => $list, 'total' => $total]);
-    }
-
-}

+ 0 - 137
application/common/controller/Frontend.php

@@ -1,137 +0,0 @@
-<?php
-
-namespace app\common\controller;
-
-use app\common\library\Auth;
-use think\Config;
-use think\Controller;
-use think\Hook;
-use think\Lang;
-
-/**
- * 前台控制器基类
- */
-class Frontend extends Controller
-{
-
-    /**
-     * 布局模板
-     * @var string
-     */
-    protected $layout = '';
-
-    /**
-     * 无需登录的方法,同时也就不需要鉴权了
-     * @var array
-     */
-    protected $noNeedLogin = [];
-
-    /**
-     * 无需鉴权的方法,但需要登录
-     * @var array
-     */
-    protected $noNeedRight = [];
-
-    /**
-     * 权限Auth
-     * @var Auth
-     */
-    protected $auth = null;
-
-    public function _initialize()
-    {
-        //移除HTML标签
-        $this->request->filter('strip_tags');
-        $modulename = $this->request->module();
-        $controllername = strtolower($this->request->controller());
-        $actionname = strtolower($this->request->action());
-
-        // 如果有使用模板布局
-        if ($this->layout) {
-            $this->view->engine->layout('layout/' . $this->layout);
-        }
-        $this->auth = Auth::instance();
-
-        // token
-        $token = $this->request->server('HTTP_TOKEN', $this->request->request('token', \think\Cookie::get('token')));
-
-        $path = str_replace('.', '/', $controllername) . '/' . $actionname;
-        // 设置当前请求的URI
-        $this->auth->setRequestUri($path);
-        // 检测是否需要验证登录
-        if (!$this->auth->match($this->noNeedLogin)) {
-            //初始化
-            $this->auth->init($token);
-            //检测是否登录
-            if (!$this->auth->isLogin()) {
-                $this->error(__('Please login first'), 'user/login');
-            }
-            // 判断是否需要验证权限
-            if (!$this->auth->match($this->noNeedRight)) {
-                // 判断控制器和方法判断是否有对应权限
-                if (!$this->auth->check($path)) {
-                    $this->error(__('You have no permission'));
-                }
-            }
-        } else {
-            // 如果有传递token才验证是否登录状态
-            if ($token) {
-                $this->auth->init($token);
-            }
-        }
-
-        $this->view->assign('user', $this->auth->getUser());
-
-        // 语言检测
-        $lang = strip_tags($this->request->langset());
-
-        $site = Config::get("site");
-
-        $upload = \app\common\model\Config::upload();
-
-        // 上传信息配置后
-        Hook::listen("upload_config_init", $upload);
-
-        // 配置信息
-        $config = [
-            'site'           => array_intersect_key($site, array_flip(['name', 'cdnurl', 'version', 'timezone', 'languages'])),
-            'upload'         => $upload,
-            'modulename'     => $modulename,
-            'controllername' => $controllername,
-            'actionname'     => $actionname,
-            'jsname'         => 'frontend/' . str_replace('.', '/', $controllername),
-            'moduleurl'      => rtrim(url("/{$modulename}", '', false), '/'),
-            'language'       => $lang
-        ];
-        $config = array_merge($config, Config::get("view_replace_str"));
-
-        Config::set('upload', array_merge(Config::get('upload'), $upload));
-
-        // 配置信息后
-        Hook::listen("config_init", $config);
-        // 加载当前控制器语言包
-        $this->loadlang($controllername);
-        $this->assign('site', $site);
-        $this->assign('config', $config);
-    }
-
-    /**
-     * 加载语言文件
-     * @param string $name
-     */
-    protected function loadlang($name)
-    {
-        Lang::load(APP_PATH . $this->request->module() . '/lang/' . $this->request->langset() . '/' . str_replace('.', '/', $name) . '.php');
-    }
-
-    /**
-     * 渲染配置信息
-     * @param mixed $name 键名或数组
-     * @param mixed $value 值
-     */
-    protected function assignconfig($name, $value = '')
-    {
-        $this->view->config = array_merge($this->view->config ? $this->view->config : [], is_array($name) ? $name : [$name => $value]);
-    }
-
-}

+ 0 - 104
application/common/lang/zh-cn/addon.php

@@ -1,104 +0,0 @@
-<?php
-
-return [
-    'addon %s not found'                          => '插件未找到',
-    'addon %s is disabled'                        => '插件已禁用',
-    'addon controller %s not found'               => '插件控制器未找到',
-    'addon action %s not found'                   => '插件控制器方法未找到',
-    'addon can not be empty'                      => '插件不能为空',
-    'Keep login'                                  => '保持会话',
-    'Forgot password'                             => '忘记密码?',
-    'Sign in'                                     => '登入',
-    'Username'                                    => '用户名',
-    'User id'                                     => '会员ID',
-    'Username'                                    => '用户名',
-    'Nickname'                                    => '昵称',
-    'Password'                                    => '密码',
-    'Sign up'                                     => '注 册',
-    'Sign in'                                     => '登 录',
-    'Sign out'                                    => '注 销',
-    'Guest'                                       => '游客',
-    'Welcome'                                     => '%s,你好!',
-    'Add'                                         => '添加',
-    'Edit'                                        => '编辑',
-    'Delete'                                      => '删除',
-    'Move'                                        => '移动',
-    'Name'                                        => '名称',
-    'Status'                                      => '状态',
-    'Weigh'                                       => '权重',
-    'Operate'                                     => '操作',
-    'Warning'                                     => '温馨提示',
-    'Default'                                     => '默认',
-    'Article'                                     => '文章',
-    'Page'                                        => '单页',
-    'OK'                                          => '确定',
-    'Cancel'                                      => '取消',
-    'Loading'                                     => '加载中',
-    'More'                                        => '更多',
-    'Normal'                                      => '正常',
-    'Hidden'                                      => '隐藏',
-    'Submit'                                      => '提交',
-    'Reset'                                       => '重置',
-    'Execute'                                     => '执行',
-    'Close'                                       => '关闭',
-    'Search'                                      => '搜索',
-    'Refresh'                                     => '刷新',
-    'First'                                       => '首页',
-    'Previous'                                    => '上一页',
-    'Next'                                        => '下一页',
-    'Last'                                        => '末页',
-    'None'                                        => '无',
-    'Home'                                        => '主页',
-    'Online'                                      => '在线',
-    'Logout'                                      => '注销',
-    'Profile'                                     => '个人资料',
-    'Index'                                       => '首页',
-    'Hot'                                         => '热门',
-    'Recommend'                                   => '推荐',
-    'Dashboard'                                   => '控制台',
-    'Code'                                        => '编号',
-    'Message'                                     => '内容',
-    'Line'                                        => '行号',
-    'File'                                        => '文件',
-    'Menu'                                        => '菜单',
-    'Name'                                        => '名称',
-    'Weigh'                                       => '权重',
-    'Type'                                        => '类型',
-    'Title'                                       => '标题',
-    'Content'                                     => '内容',
-    'Status'                                      => '状态',
-    'Operate'                                     => '操作',
-    'Append'                                      => '追加',
-    'Memo'                                        => '备注',
-    'Parent'                                      => '父级',
-    'Params'                                      => '参数',
-    'Permission'                                  => '权限',
-    'Begin time'                                  => '开始时间',
-    'End time'                                    => '结束时间',
-    'Create time'                                 => '创建时间',
-    'Flag'                                        => '标志',
-    'Home'                                        => '首页',
-    'Store'                                       => '插件市场',
-    'Services'                                    => '服务',
-    'Download'                                    => '下载',
-    'Demo'                                        => '演示',
-    'Donation'                                    => '捐赠',
-    'Forum'                                       => '社区',
-    'Docs'                                        => '文档',
-    'Go back'                                     => '返回首页',
-    'Jump now'                                    => '立即跳转',
-    'Please login first'                          => '请登录后再操作',
-    'Send verification code'                      => '发送验证码',
-    'Redirect now'                                => '立即跳转',
-    'Operation completed'                         => '操作成功!',
-    'Operation failed'                            => '操作失败!',
-    'Unknown data format'                         => '未知的数据格式!',
-    'Network error'                               => '网络错误!',
-    'Advanced search'                             => '高级搜索',
-    'Invalid parameters'                          => '未知参数',
-    'No results were found'                       => '记录未找到',
-    'Parameter %s can not be empty'               => '参数%s不能为空',
-    'You have no permission'                      => '你没有权限访问',
-    'An unexpected error occurred'                => '发生了一个意外错误,程序猿正在紧急处理中',
-    'This page will be re-directed in %s seconds' => '页面将在 %s 秒后自动跳转',
-];

+ 0 - 87
application/common/library/AliPay.php

@@ -1,87 +0,0 @@
-<?php
-namespace app\common\library;
-use Alipay\EasySDK\Kernel\Factory;
-use Alipay\EasySDK\Kernel\Util\ResponseChecker;
-use app\common\model\Config;
-use think\Controller;
-
-class AliPay extends Controller
-{
-    /*
-   配置参数
-   */
-    public function __construct()
-    {
-        $this->appId = "202100312862198822222";
-        $this->rsaPrivateKey =  'MIIEowIBAAKCAQEAhkW8tpvdkVRZklapB+scLgcdL6N8/noWdV4h6ViUDxHd1rSjYJRHLmFgLYLgyKHHyS3tXySPf7qRbWwyImV4A17+WNTxAtdMH+TBAuqS49sAND4JYjurtY6CbQjwBEHUOE506DhISM4+fzkgtLGF8lD0jAJyXFRK4XutL3ddJ2XSzbIUTvT1bIP+cwNQcsmTTmpO145+9gKvx8tkHILKZPockarsoUoeo9gapB3hnNHNrYTbzpsa/zkOETD7L3rgpWbGJSc675t5dk8RaqH13Eon0BTn/Ov5gJ0P8j4VUWXYqdI9cEVur65S002vvhiIFVpy+30nB9SviF+/rcjQnQIDAQABAoIBAAGAdCzir2a5t8rAN2HESmtlXvkybep2uRuU8vImMHm+rGmDWbRx1B37rtSzewojbRWd8uK2iPhXwNqldCYYVnBLNrMNpqhuegZ9S39Z2ky8HVN4QiicHD6KmoDXsb+KcPI0RnB2eLB/xgksPWZn+eSM7T9Ho7nOo4vEE1rNjfgr0hexrbGJwrE1mlXfgsLRFgXfx5/3ndv4HZtX1uULdt9Xei9h8jE/kbkGz5bemjGar3ZC7rGQ+TNHDJ3BBXNCVxt9kJDjYpnf6EPceMEdClfSWwN4pvFvCx9LGcSGtFDx9NOF43alt4nt9VWrBj0H0iXRA1hyIFmO7KeuUoujN00CgYEA79L5cT38sMx3HMQ8aDXjUDvVq3yjHjKMDryt8PB3DVLqZCn7qehUQQG7NuVc4gdX6Ew97tcmx6vs8LRoD36lr8WFvJiY3RVTlu5fkZdMfu4jYoyG3udtzAOQ+dLxtAtCLO28FApAwi2VPF+nTJDWOzJsStDfDgJhDPKL5eojPwMCgYEAj1Q1iHKZ4+S/2zrhOoviIILCNy0VWTmEv0SV26NdJIQk1zAbrSz+m2q+ufJgO+6Tt6WXnjYWHA5ocObddH+paB12Ja4Z5UVSqa8kuDMZlVz4B1UiUmV5yuHnC20EI+2vGe4g/kDvTfwpaQFR5tMhwgMBTx9G21Bx0HmL033hT98CgYEA1BfqAGtImXcJ9EfcAHF/6cow6isc+yzKzpGw5v9S2la08gZrCdVtBdypHCB2J3NFHCypLRvbsQRsVGfIC8P+ddeisarmrccZmMaRgGmk/jBO3O3YrTNQ1/djdH1IwuieCqvpBHQY12GGtNEHXOBOhiXOvc/BJFuYRuIONTP/Hc8CgYAzUDumMRlFTLUfYNIX6tK3PvkXVe2ptvz+mShprPAAzcp+u/t8oXo53BqSaeLoMf7ypbdFbim2O7ZKjWzFc5sL6lhNHyqoOYxhsZGc3LaREeq+fU0/YJMc/omAPrRXxJWG3Ak13buPGPMeY9mVoQsZ8Yd7c0Aj7oYA1DMqMYwD0wKBgEenuZbJDJFOXgRj9T7UvE2ANvnZtCLNhxlQ+AtCCSKTUSESQvO2v+Xhe2bKYhZAejXBykia2UjUDmeDVzT2aID0p+qLaAUtfOdR2ahUN4ME0JJFcwzqSODeuOR7CqWWDu2OQ/rJMhh12nePzMpedepkRrGnzqBwPljAPnigat04';
-        $this->aliPayRsaPublicKey = 'MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAhkW8tpvdkVRZklapB+scLgcdL6N8/noWdV4h6ViUDxHd1rSjYJRHLmFgLYLgyKHHyS3tXySPf7qRbWwyImV4A17+WNTxAtdMH+TBAuqS49sAND4JYjurtY6CbQjwBEHUOE506DhISM4+fzkgtLGF8lD0jAJyXFRK4XutL3ddJ2XSzbIUTvT1bIP+cwNQcsmTTmpO145+9gKvx8tkHILKZPockarsoUoeo9gapB3hnNHNrYTbzpsa/zkOETD7L3rgpWbGJSc675t5dk8RaqH13Eon0BTn/Ov5gJ0P8j4VUWXYqdI9cEVur65S002vvhiIFVpy+30nB9SviF+/rcjQnQIDAQAB';
-    }
-
-
-    /**
-     * @throws \EasyWeChat\Kernel\Exceptions\InvalidArgumentException
-     * @throws \EasyWeChat\Kernel\Exceptions\InvalidConfigException
-     * @throws \GuzzleHttp\Exception\GuzzleException
-     * 支付宝支付
-     */
-    public static function ali_pay($subject,$totalAmount,$outTradeNo,$notifyUrl){
-        Factory::setOptions(self::getOptions($notifyUrl));
-        try {
-            //2. 发起API调用(以支付能力下的统一收单交易创建接口为例)
-            //$result = Factory::payment()->common()->create("iPhone6 16G", "20200326235526001", "88.88", "2088002656718920");
-            $result = Factory::payment()->App()->pay($subject,$outTradeNo , $totalAmount);
-            $responseChecker = new ResponseChecker();
-            //3. 处理响应或异常
-            if ($responseChecker->success($result)) {
-                return $result->body;
-            } else {
-                echo "调用失败,原因:". $result->msg.",".$result->subMsg.PHP_EOL;
-            }
-        } catch (Exception $e) {
-            return false;
-        }
-    }
-
-    public static function ali_pay_pc($subject='商品',$totalAmount,$outTradeNo,$notifyUrl,$returnUrl){
-        Factory::setOptions(self::getOptions($notifyUrl));
-        try {
-            $result = Factory::payment()->Page()->pay($subject,$outTradeNo,$totalAmount,$returnUrl);
-            $responseChecker = new ResponseChecker();
-            //3. 处理响应或异常
-            if ($responseChecker->success($result)) {
-                return $result->body;
-            } else {
-                echo "调用失败,原因:". $result->msg.",".$result->subMsg.PHP_EOL;
-            }
-        } catch (Exception $e) {
-            return false;
-        }
-    }
-
-
-    public static function getOptions($notifyUrl){
-        $options = new \Alipay\EasySDK\Kernel\Config();
-        $options->protocol = 'https';
-        $options->gatewayHost = 'openapi.alipay.com';
-        $options->signType = 'RSA2';
-
-        $options->appId = '2021003128621988';
-
-        // 为避免私钥随源码泄露,推荐从文件中读取私钥字符串而不是写入源码中
-        $options->merchantPrivateKey = 'MIIEowIBAAKCAQEAhkW8tpvdkVRZklapB+scLgcdL6N8/noWdV4h6ViUDxHd1rSjYJRHLmFgLYLgyKHHyS3tXySPf7qRbWwyImV4A17+WNTxAtdMH+TBAuqS49sAND4JYjurtY6CbQjwBEHUOE506DhISM4+fzkgtLGF8lD0jAJyXFRK4XutL3ddJ2XSzbIUTvT1bIP+cwNQcsmTTmpO145+9gKvx8tkHILKZPockarsoUoeo9gapB3hnNHNrYTbzpsa/zkOETD7L3rgpWbGJSc675t5dk8RaqH13Eon0BTn/Ov5gJ0P8j4VUWXYqdI9cEVur65S002vvhiIFVpy+30nB9SviF+/rcjQnQIDAQABAoIBAAGAdCzir2a5t8rAN2HESmtlXvkybep2uRuU8vImMHm+rGmDWbRx1B37rtSzewojbRWd8uK2iPhXwNqldCYYVnBLNrMNpqhuegZ9S39Z2ky8HVN4QiicHD6KmoDXsb+KcPI0RnB2eLB/xgksPWZn+eSM7T9Ho7nOo4vEE1rNjfgr0hexrbGJwrE1mlXfgsLRFgXfx5/3ndv4HZtX1uULdt9Xei9h8jE/kbkGz5bemjGar3ZC7rGQ+TNHDJ3BBXNCVxt9kJDjYpnf6EPceMEdClfSWwN4pvFvCx9LGcSGtFDx9NOF43alt4nt9VWrBj0H0iXRA1hyIFmO7KeuUoujN00CgYEA79L5cT38sMx3HMQ8aDXjUDvVq3yjHjKMDryt8PB3DVLqZCn7qehUQQG7NuVc4gdX6Ew97tcmx6vs8LRoD36lr8WFvJiY3RVTlu5fkZdMfu4jYoyG3udtzAOQ+dLxtAtCLO28FApAwi2VPF+nTJDWOzJsStDfDgJhDPKL5eojPwMCgYEAj1Q1iHKZ4+S/2zrhOoviIILCNy0VWTmEv0SV26NdJIQk1zAbrSz+m2q+ufJgO+6Tt6WXnjYWHA5ocObddH+paB12Ja4Z5UVSqa8kuDMZlVz4B1UiUmV5yuHnC20EI+2vGe4g/kDvTfwpaQFR5tMhwgMBTx9G21Bx0HmL033hT98CgYEA1BfqAGtImXcJ9EfcAHF/6cow6isc+yzKzpGw5v9S2la08gZrCdVtBdypHCB2J3NFHCypLRvbsQRsVGfIC8P+ddeisarmrccZmMaRgGmk/jBO3O3YrTNQ1/djdH1IwuieCqvpBHQY12GGtNEHXOBOhiXOvc/BJFuYRuIONTP/Hc8CgYAzUDumMRlFTLUfYNIX6tK3PvkXVe2ptvz+mShprPAAzcp+u/t8oXo53BqSaeLoMf7ypbdFbim2O7ZKjWzFc5sL6lhNHyqoOYxhsZGc3LaREeq+fU0/YJMc/omAPrRXxJWG3Ak13buPGPMeY9mVoQsZ8Yd7c0Aj7oYA1DMqMYwD0wKBgEenuZbJDJFOXgRj9T7UvE2ANvnZtCLNhxlQ+AtCCSKTUSESQvO2v+Xhe2bKYhZAejXBykia2UjUDmeDVzT2aID0p+qLaAUtfOdR2ahUN4ME0JJFcwzqSODeuOR7CqWWDu2OQ/rJMhh12nePzMpedepkRrGnzqBwPljAPnigat04';
-
-        /*$options->alipayCertPath = '<-- 请填写您的支付宝公钥证书文件路径,例如:/foo/alipayCertPublicKey_RSA2.crt -->';
-        $options->alipayRootCertPath = '<-- 请填写您的支付宝根证书文件路径,例如:/foo/alipayRootCert.crt" -->';
-        $options->merchantCertPath = '<-- 请填写您的应用公钥证书文件路径,例如:/foo/appCertPublicKey_2019051064521003.crt -->';*/
-
-        //注:如果采用非证书模式,则无需赋值上面的三个证书路径,改为赋值如下的支付宝公钥字符串即可
-        $options->alipayPublicKey ='MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAhkW8tpvdkVRZklapB+scLgcdL6N8/noWdV4h6ViUDxHd1rSjYJRHLmFgLYLgyKHHyS3tXySPf7qRbWwyImV4A17+WNTxAtdMH+TBAuqS49sAND4JYjurtY6CbQjwBEHUOE506DhISM4+fzkgtLGF8lD0jAJyXFRK4XutL3ddJ2XSzbIUTvT1bIP+cwNQcsmTTmpO145+9gKvx8tkHILKZPockarsoUoeo9gapB3hnNHNrYTbzpsa/zkOETD7L3rgpWbGJSc675t5dk8RaqH13Eon0BTn/Ov5gJ0P8j4VUWXYqdI9cEVur65S002vvhiIFVpy+30nB9SviF+/rcjQnQIDAQAB';
-        //可设置异步通知接收服务地址(可选)
-        $options->notifyUrl = $notifyUrl;
-        //可设置AES密钥,调用AES加解密相关接口时需要(可选)
-        $options->encryptKey = "";
-        return $options;
-    }
-
-
-}

+ 0 - 144
application/common/library/AliPay2.php

@@ -1,144 +0,0 @@
-<?php
-namespace app\common\library;
-use app\common\model\Config;
-use think\Controller;
-
-class AliPay2 extends Controller
-{
-    /*
-   配置参数
-   */
-    public function __construct()
-    {
-        $this->appId = "202100312862198822222122";
-        $this->rsaPrivateKey =  'MIIEowIBAAKCAQEAhkW8tpvdkVRZklapB+scLgcdL6N8/noWdV4h6ViUDxHd1rSjYJRHLmFgLYLgyKHHyS3tXySPf7qRbWwyImV4A17+WNTxAtdMH+TBAuqS49sAND4JYjurtY6CbQjwBEHUOE506DhISM4+fzkgtLGF8lD0jAJyXFRK4XutL3ddJ2XSzbIUTvT1bIP+cwNQcsmTTmpO145+9gKvx8tkHILKZPockarsoUoeo9gapB3hnNHNrYTbzpsa/zkOETD7L3rgpWbGJSc675t5dk8RaqH13Eon0BTn/Ov5gJ0P8j4VUWXYqdI9cEVur65S002vvhiIFVpy+30nB9SviF+/rcjQnQIDAQABAoIBAAGAdCzir2a5t8rAN2HESmtlXvkybep2uRuU8vImMHm+rGmDWbRx1B37rtSzewojbRWd8uK2iPhXwNqldCYYVnBLNrMNpqhuegZ9S39Z2ky8HVN4QiicHD6KmoDXsb+KcPI0RnB2eLB/xgksPWZn+eSM7T9Ho7nOo4vEE1rNjfgr0hexrbGJwrE1mlXfgsLRFgXfx5/3ndv4HZtX1uULdt9Xei9h8jE/kbkGz5bemjGar3ZC7rGQ+TNHDJ3BBXNCVxt9kJDjYpnf6EPceMEdClfSWwN4pvFvCx9LGcSGtFDx9NOF43alt4nt9VWrBj0H0iXRA1hyIFmO7KeuUoujN00CgYEA79L5cT38sMx3HMQ8aDXjUDvVq3yjHjKMDryt8PB3DVLqZCn7qehUQQG7NuVc4gdX6Ew97tcmx6vs8LRoD36lr8WFvJiY3RVTlu5fkZdMfu4jYoyG3udtzAOQ+dLxtAtCLO28FApAwi2VPF+nTJDWOzJsStDfDgJhDPKL5eojPwMCgYEAj1Q1iHKZ4+S/2zrhOoviIILCNy0VWTmEv0SV26NdJIQk1zAbrSz+m2q+ufJgO+6Tt6WXnjYWHA5ocObddH+paB12Ja4Z5UVSqa8kuDMZlVz4B1UiUmV5yuHnC20EI+2vGe4g/kDvTfwpaQFR5tMhwgMBTx9G21Bx0HmL033hT98CgYEA1BfqAGtImXcJ9EfcAHF/6cow6isc+yzKzpGw5v9S2la08gZrCdVtBdypHCB2J3NFHCypLRvbsQRsVGfIC8P+ddeisarmrccZmMaRgGmk/jBO3O3YrTNQ1/djdH1IwuieCqvpBHQY12GGtNEHXOBOhiXOvc/BJFuYRuIONTP/Hc8CgYAzUDumMRlFTLUfYNIX6tK3PvkXVe2ptvz+mShprPAAzcp+u/t8oXo53BqSaeLoMf7ypbdFbim2O7ZKjWzFc5sL6lhNHyqoOYxhsZGc3LaREeq+fU0/YJMc/omAPrRXxJWG3Ak13buPGPMeY9mVoQsZ8Yd7c0Aj7oYA1DMqMYwD0wKBgEenuZbJDJFOXgRj9T7UvE2ANvnZtCLNhxlQ+AtCCSKTUSESQvO2v+Xhe2bKYhZAejXBykia2UjUDmeDVzT2aID0p+qLaAUtfOdR2ahUN4ME0JJFcwzqSODeuOR7CqWWDu2OQ/rJMhh12nePzMpedepkRrGnzqBwPljAPnigat04';
-        $this->aliPayRsaPublicKey = 'MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAhkW8tpvdkVRZklapB+scLgcdL6N8/noWdV4h6ViUDxHd1rSjYJRHLmFgLYLgyKHHyS3tXySPf7qRbWwyImV4A17+WNTxAtdMH+TBAuqS49sAND4JYjurtY6CbQjwBEHUOE506DhISM4+fzkgtLGF8lD0jAJyXFRK4XutL3ddJ2XSzbIUTvT1bIP+cwNQcsmTTmpO145+9gKvx8tkHILKZPockarsoUoeo9gapB3hnNHNrYTbzpsa/zkOETD7L3rgpWbGJSc675t5dk8RaqH13Eon0BTn/Ov5gJ0P8j4VUWXYqdI9cEVur65S002vvhiIFVpy+30nB9SviF+/rcjQnQIDAQAB';
-    }
-
-    /*
-     * 支付宝支付
-     */
-    public function aliPay($body, $total_amount, $product_code, $notify_url)
-    {
-        /**
-         * 调用支付宝接口。
-         */
-        $isdir = dirname(__DIR__)."/library/";//绝对路径
-        require_once($isdir.'/alipay/aop/AopClient.php');
-        require_once($isdir.'/alipay/aop/request/AlipayTradeAppPayRequest.php');
-        $total_amount = floatval($total_amount);
-        $aop = new AopClient();
-        $aop->gatewayUrl = "https://openapi.alipay.com/gateway.do";
-        $aop->appId = $this->appId;
-        $aop->rsaPrivateKey = $this->rsaPrivateKey;
-        $aop->format = "json";
-        $aop->charset = "UTF-8";
-        $aop->signType = "RSA2";
-        $aop->alipayrsaPublicKey = $this->aliPayRsaPublicKey;
-        $request = new AlipayTradeAppPayRequest();
-        $arr['body'] = $body;
-        $arr['subject'] = $body;
-        $arr['out_trade_no'] = $product_code;
-        $arr['timeout_express'] = '30m';
-        $arr['total_amount'] = $total_amount;
-        $arr['product_code'] = 'QUICK_MSECURITY_PAY';
-
-        $json = json_encode($arr);
-        $request->setNotifyUrl($notify_url);
-        $request->setBizContent($json);
-        $response = $aop->sdkExecute($request);
-        return $response;
-
-
-    }
-
-    //支付宝退款
-    public function zfbrefund($out_trade_no,$out_refund_no,$total_fee,$refund_reason){
-        $total_fee  = sprintf("%.2f",substr(sprintf("%.4f", $total_fee), 0, -2));
-        $isdir = dirname(__DIR__)."/library/";//绝对路径
-        require_once($isdir.'/alipay/aop/AopClient.php');
-        require_once($isdir.'/alipay/aop/request/AlipayTradeRefundRequest.php');
-        $aop = new AopClient();
-        $aop->gatewayUrl = "https://openapi.alipay.com/gateway.do";
-        $aop->appId = $this->appId;
-        $aop->rsaPrivateKey = $this->rsaPrivateKey;
-        $aop->format = "json";
-        $aop->charset = "UTF-8";
-        $aop->signType = "RSA2";
-        $aop->apiVersion = '1.0';
-//        $aop->alipayrsaPublicKey = $this->aliPayRsaPublicKey;
-        $request = new \AlipayTradeRefundRequest();
-        //$arr['trade_no'] = $out_refund_no;
-        $arr['out_trade_no'] = $out_trade_no;
-        $arr['refund_amount'] = $total_fee;
-        $arr['refund_reason'] = $refund_reason;
-        $arr['refund_currency'] = "CNY";
-        $arr['operator_id'] = "OP001";
-        $arr['store_id'] = "NJ_S_001";
-        $arr['terminal_id'] = "NJ_T_001";
-        $json = json_encode($arr);
-        $request->setBizContent($json);
-        $result = $aop->execute($request);
-        $responseNode = str_replace(".", "_", $request->getApiMethodName()) . "_response";
-        $resultCode = $result->$responseNode->code;
-        return $resultCode;
-    }
-
-
-    //支付宝转账个人账户
-    public function FundTransToaccount($out_trade_no,$account,$account_real_name,$amount,$remark){
-        $amount  = sprintf("%.2f",substr(sprintf("%.4f", $amount), 0, -2));
-        $isdir = dirname(__DIR__)."/library/";//绝对路径
-        require_once($isdir.'/alipay/aop/AopClient.php');
-        $aop = new AopClient();
-        $aop->gatewayUrl = "https://openapi.alipay.com/gateway.do";
-        $aop->appId = $this->appId;
-        $aop->rsaPrivateKey = $this->rsaPrivateKey;
-        $aop->format = 'json';
-        $aop->charset = 'UTF-8';
-        $aop->signType = 'RSA2';
-        //$aop->alipayrsaPublicKey = $this->aliPayRsaPublicKey;
-        require_once($isdir.'/alipay/aop/request/AlipayFundTransToaccountTransferRequest.php');
-        $request = new \AlipayFundTransToaccountTransferRequest();
-        $arr['out_biz_no'] = $out_trade_no;      //订单号
-        $arr['payee_type'] = 'ALIPAY_LOGONID';
-        $arr['payee_account'] = $account;        //对方支付宝账号
-        $arr['payee_real_name'] = $account_real_name;   //支付宝实名姓名
-        $arr['amount']  = $amount;
-        $arr['remark']  = $remark;
-        $json = json_encode($arr,true);
-        $request->setBizContent($json);
-        $result = $aop->execute($request);
-        $result2 = json_decode(json_encode($result),true);
-        $responseNode = str_replace(".", "_", $request->getApiMethodName()) . "_response";
-        $resultCode = $result->$responseNode->code;
-        $arr = ['code'=>$resultCode,'result'=>$result2];
-        return $arr;
-    }
-
-
-    function createLinkstring($para)
-    {
-        $arg = "";
-        while (list ($key, $val) = each($para)) {
-            $arg .= $key . "=" . $val . "&";
-        }
-        //去掉最后一个&字符
-        $arg = substr($arg, 0, count($arg) - 2);
-
-        //如果存在转义字符,那么去掉转义
-        if (get_magic_quotes_gpc()) {
-            $arg = stripslashes($arg);
-        }
-
-        return $arg;
-    }
-
-
-    function argSort($para)
-    {
-        ksort($para);
-        reset($para);
-        return $para;
-    }
-}

+ 0 - 239
application/common/library/AliPay3.php

@@ -1,239 +0,0 @@
-<?php
-namespace app\common\library;
-use think\Controller;
-
-class AliPay3 extends Controller
-{
-    /*
-   配置参数
-   */
-    public function __construct()
-    {
-        $this->appId = "220431411";
-        $this->rsaPrivateKey =  "-----BEGIN PRIVATE KEY-----
-MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQC95Mqn1Q9bTF0H
-ncQOXRCsP10I6U7f83OX2+8WMxMr30J8AX6QxU3sWRY/eDMPmnnSifsG6n1ZsgJQ
-DaN8CRFjsGGA6E0Fglphf0A22MkuTsyQRSAnhmQCQbjFetdrLUBGcwXzX9H1uLhe
-F8opCjK3YdnnIYfadlq5Y8Ogw5RsmjX7sRN2l6hvONPlrN5qKd0GjGbttfYrNgxt
-D7Upbr+MVZ//RoeN3DfGSmdPQjEMVrbnHaNp92hxdVTo2t0ZlqpsICJlDF8lFzFv
-0DVmn0tsR1rlCjmASy0LRLrIQJhp4ojhl2Jew8zx/XUEWQpyjsBGXETh4zeHXURa
-Cw8NsofrAgMBAAECggEAQirawqhm9XUiZWj/y9F54csia9x/82EtQhkMsjuRzpO4
-4uTSaTeW82gHbI5BnIpDMK2LntlOXFa+n45hDPNL7+Sh1P0c+XJ2c8qXYYUgdNZY
-SV0M2zjk2DR2YblwHpRh9SpXRHp6+pgnBgJcGvjGu0eJWhRA9kqPSlIM9JOxwDVR
-2RUn52VFmLqwe/QY3RlMTBS6lHxZqo8qwok+BsHAD79o5EDVKj64tvCD6Ew3WzZi
-NySctdRKt+GN/l4IWgwzll8dkMEZbqMhB6Kb4KAU0Bkzdqz539Q5CapNsYTTHW+j
-VbCq8LwhMyAkpUgWyjCxUNH6c6+AoApstKeMjiQoAQKBgQDskD6WPaAhxZcAFqDL
-Ei03LUmuypl4djuKJVWYdxPxTr3icAqd/gRfLojWRMT/5Ql/E62L0E/5uHa/Tx9P
-9A0lej8CS1NHrtE8JtXPjUF5jv+yNr7QyZkDF2tIBkSr5hMFBtSRBbsDYsRDPalB
-yHJ2XPdIOBoplzIcDxW2F921AQKBgQDNfutqYgdMkgrVH9hRv+e8bu4S1n08HbgJ
-/wn37TvsT/vRyWs/we6umkDia0zm0BDBeN8IGj+HVrLqcQQqAFADo1ToI8hQMH5f
-WVlsIq7JkRJY6MNPGaM40ZkQJ0C0H7GNZBDKP0LKX/2DU6j3loVEpfX3tkY0Gnb5
-2Ox0kE1g6wKBgF/I6A6dVUFXaBS5FNIkwfoddEA5+Ho2JVWCWG4riP+kCm6tPx9J
-wytnBDD+F2YlrvqtVQ/PgRJ0BmDgAKW3A7uxC+I57baQqlfYwaoQX/qAVDgswoZ3
-mmUODnpTT2rq9biLU3aFA3wTebRgOzBPoUkby2SKks1UUw3ZbckVUMgBAoGBALPw
-EN+kWtPXhZi9O8PJkHdVgy4Hlr2PIFnQcsAfgTsZhl1aS4kWnZNSCsK4RixNwH5J
-ArKrmTk+14el0omcoHOvD2f9/ScKb326VSz06awiVbh4iJy4zE2yap7UYDnZDrXK
-C1GtNyTSDMBz/x5dNPC5ibmQZ8Sz774zDkm7GaZlAoGBAMnbSMMXs+wuTCo4LI38
-hHANp5Ry8xUPzWyQ8N0XkF9PvUz/dnr/b+SRB2y4Xe5w2YGPp4OKBWRMJMjG2Pby
-8+lPXS6OalWyzsdPVuDEMbM5D54FmVlMIjvi1vTzsaYiHqoTydivaet/F87Dghpa
-U6MhZnBh1032L8aFVcn3q7fj
------END PRIVATE KEY-----
-"; //商户私钥
-        $this->aliPayRsaPublicKey = "-----BEGIN PUBLIC KEY-----
-MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAp7+ID0TR1iN/5YUWkSzh
-8fG3+e+kj9gWbkU5j8jkGqG0fXE7uhKvhuPeUOvuAnVtUw8VKI6GssfFUafs0rMT
-4No/s8wF7AzndyD/YoqpCqe5xToPNVHZ+5JHa9K92alTvvcx1ukRfJp1SI0JHXg1
-goUhfUrLOXV2QSgoshBHUTocWuIY4CdKP1tVOelBMcwItY9KBujfs7WMUFibe6gg
-5V+KqYoK0uhpvZmFb9IHCGdujVdPGxL0tPH/hGBNrbgm1gOBubB9yEnH3hTj9gGg
-arcELZGyRi9HQU0haG3c79f4XDvirSTsnHnd7aIM9BKPdlkq8QZANGyuO7Rs1zkF
-CwIDAQAB
------END PUBLIC KEY-----";//平台公钥
-    }
-
-    /*
-     * 支付宝支付
-     */
-    public function aliPay($body, $total_amount, $order_no, $notify_url,$attach,$callbackurl)
-    {
-        $params = [
-            "service"=>"App.Order.Pay",
-            "timestamp"=>date('Y-m-d H:i:s'),
-            "nonce"=>time(),
-            "member_id"=>$this->appId,
-            "mem_order"=>$order_no,
-            "bank_code"=>"953",
-           // "notifyurl"=>"https://".$_SERVER['SERVER_NAME']."/api/Pay/alipayOrderNotify",
-            "notifyurl"=>$notify_url,
-           // "callbackurl"=>"https://".$_SERVER['SERVER_NAME']."/pages/mine/order-list?num=1",
-            "callbackurl"=>$callbackurl,
-            "amount"=>$total_amount,
-            "productname"=>$body,
-            "attach"=>$attach
-        ];
-        $apiKey = "4n79o0izlo0ax9z45lopjj0hgwl249bk";//商户中心的APIKEY
-
-        ksort($params);
-
-        $signString = "";
-        foreach($params as $key => $val){
-            $signString .= $val;
-        }
-        $signString .= $apiKey;
-
-        $params['sign'] = strtoupper(md5($signString));
-
-//    var_dump($params['sign']);
-        //到这里签名完成
-        //对notifyurl进行rsa加密
-        $params['notifyurl'] = $this->sslEn($params['notifyurl'],$this->rsaPrivateKey);//$key是商户私钥
-
-        //最后POST提交  $params
-        $url = "https://apis.wqkeji.cn";
-        $re = $this->httpPost($url,$params);//提交返回
-        //判断是否为数组
-        $re = is_array($re)?$re:json_decode($re,true);
-
-        //对data进行平台公钥解密
-        $data = $this->sslDe($re['data'], $this->aliPayRsaPublicKey);
-        return json_decode($data,true);
-    }
-
-
-
-    /**
-     * RSA 私钥、公钥加密
-     * @param $data
-     * @param $key
-     * @param $type
-     * @return string
-     */
-    function sslEn($data, $key, $type = 'pi')
-    {
-        $encrypted = "";
-        if ($type == 'pi') {
-            $r = openssl_pkey_get_private($key);
-            //私钥加密
-            foreach (str_split($data, 117) as $chunk) {
-                openssl_private_encrypt($chunk, $encryptData, $key);
-                $encrypted .= $encryptData;
-            }
-        } elseif ($type == 'pu') {
-            $r = openssl_pkey_get_public($key);
-            //公钥加密
-            foreach (str_split($data, 117) as $chunk) {
-                openssl_public_encrypt($chunk, $encryptData, $key);
-                $encrypted .= $encryptData;
-            }
-        }
-        $encrypt_data = base64_encode($encrypted);
-        return $encrypt_data;
-    }
-
-    /**
-     * RSA 私钥、公钥解密
-     * @param $data
-     * @param $key
-     * @param $type
-     * @return string
-     */
-    function sslDe($data, $key, $type = 'pu')
-    {
-        $hex_encrypt_data = trim($data);
-        $encrypt_data = base64_decode($hex_encrypt_data);//对BASE64进行转换
-        $decrypted = "";
-        if ($type == 'pu') {
-            $r = openssl_pkey_get_public($key);
-            //公钥解密
-            $arrThrunk = str_split($encrypt_data, 256);
-            foreach ($arrThrunk as $trunk) {
-                $temp = '';
-                if (openssl_public_decrypt($trunk, $temp, $key)) {
-                    $decrypted .= $temp;
-                } else {
-                    return '';
-                }
-            }
-        } elseif ($type == 'pi') {
-            $r = openssl_pkey_get_private($key);
-            //私钥解密  ---- 分段解密
-            $arrThrunk = str_split($encrypt_data, 256);
-            foreach ($arrThrunk as $trunk) {
-                $temp = '';
-                if (openssl_private_decrypt($trunk, $temp, $key)) {
-                    $decrypted .= $temp;
-                } else {
-                    return '';
-                }
-            }
-        }
-        return $decrypted;
-    }
-
-    /**
-     * RSA 私钥、公钥解密
-     * @param $data
-     * @param $key
-     * @param $type
-     * @return string
-     */
-    function sslDeReturn($data, $type = 'pu')
-    {
-        $key = $this->aliPayRsaPublicKey;
-        $hex_encrypt_data = trim($data);
-        $encrypt_data = base64_decode($hex_encrypt_data);//对BASE64进行转换
-        $decrypted = "";
-        if ($type == 'pu') {
-            $r = openssl_pkey_get_public($key);
-            //公钥解密
-            $arrThrunk = str_split($encrypt_data, 256);
-            foreach ($arrThrunk as $trunk) {
-                $temp = '';
-                if (openssl_public_decrypt($trunk, $temp, $key)) {
-                    $decrypted .= $temp;
-                } else {
-                    return '';
-                }
-            }
-        } elseif ($type == 'pi') {
-            $r = openssl_pkey_get_private($key);
-            //私钥解密  ---- 分段解密
-            $arrThrunk = str_split($encrypt_data, 256);
-            foreach ($arrThrunk as $trunk) {
-                $temp = '';
-                if (openssl_private_decrypt($trunk, $temp, $key)) {
-                    $decrypted .= $temp;
-                } else {
-                    return '';
-                }
-            }
-        }
-        return $decrypted;
-    }
-
-    //HTTP post 工具
-    function httpPost($url, $post_data)
-    {
-        // 模拟提交数据函数
-        $curl = curl_init(); // 启动一个CURL会话
-        curl_setopt($curl, CURLOPT_URL, $url); // 要访问的地址
-        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); // 对认证证书来源的检查
-        curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false); // 从证书中检查SSL加密算法是否存在
-        if (isset($_SERVER['HTTP_USER_AGENT'])) {
-            curl_setopt($curl, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']); // 模拟用户使用的浏览器
-        }
-        curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1); // 使用自动跳转
-        curl_setopt($curl, CURLOPT_AUTOREFERER, 1); // 自动设置Referer
-        if (!empty($post_data)) {
-            curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($post_data)); // Post提交的数据包
-        }
-        curl_setopt($curl, CURLOPT_POST, 1); // 发送一个常规的Post请求
-        curl_setopt($curl, CURLOPT_TIMEOUT, 30); // 设置超时限制防止死循环
-        curl_setopt($curl, CURLOPT_HEADER, 0); // 显示返回的Header区域内容
-        curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); // 获取的信息以文件流的形式返回
-        // 发出请求
-        $response = curl_exec($curl);
-        curl_close($curl); // 关闭CURL会话
-        return $response;
-    }
-
-}

+ 0 - 613
application/common/library/Auth.php

@@ -1,613 +0,0 @@
-<?php
-
-namespace app\common\library;
-
-use app\common\model\User;
-use app\common\model\UserRule;
-use fast\Random;
-use think\Config;
-use think\Db;
-use think\Hook;
-use think\Request;
-use think\Validate;
-
-class Auth
-{
-
-    protected static $instance = null;
-    protected $_error = '';
-    protected $_logined = FALSE;
-    protected $_user = NULL;
-    protected $_token = '';
-    //Token默认有效时长
-    protected $keeptime = 2592000;
-    protected $requestUri = '';
-    protected $rules = [];
-    //默认配置
-    protected $config = [];
-    protected $options = [];
-    protected $allowFields = ['id', 'username', 'nickname', 'mobile', 'avatar', 'score','money','city','gender'];
-
-    public function __construct($options = [])
-    {
-        if ($config = Config::get('user'))
-        {
-            $this->config = array_merge($this->config, $config);
-        }
-        $this->options = array_merge($this->config, $options);
-    }
-
-    /**
-     * 
-     * @param array $options 参数
-     * @return Auth
-     */
-    public static function instance($options = [])
-    {
-        if (is_null(self::$instance))
-        {
-            self::$instance = new static($options);
-        }
-
-        return self::$instance;
-    }
-
-    /**
-     * 获取User模型
-     * @return User
-     */
-    public function getUser()
-    {
-        return $this->_user;
-    }
-
-    /**
-     * 兼容调用user模型的属性
-     * 
-     * @param string $name
-     * @return mixed
-     */
-    public function __get($name)
-    {
-        return $this->_user ? $this->_user->$name : NULL;
-    }
-
-    /**
-     * 根据Token初始化
-     *
-     * @param string       $token    Token
-     * @return boolean
-     */
-    public function init($token)
-    {
-        if ($this->_logined)
-        {
-            return TRUE;
-        }
-        if ($this->_error)
-            return FALSE;
-        $data = Token::get($token);
-        if (!$data)
-        {
-            return FALSE;
-        }
-        $user_id = intval($data['user_id']);
-        if ($user_id > 0)
-        {
-            $user = User::get($user_id);
-            if (!$user)
-            {
-                $this->setError('Account not exist');
-                return FALSE;
-            }
-            if ($user['status'] != 'normal')
-            {
-                $this->setError('Account is locked');
-                return FALSE;
-            }
-            $this->_user = $user;
-            $this->_logined = TRUE;
-            $this->_token = $token;
-
-            //初始化成功的事件
-            Hook::listen("user_init_successed", $this->_user);
-
-            return TRUE;
-        }
-        else
-        {
-            $this->setError('You are not logged in');
-            return FALSE;
-        }
-    }
-
-    /**
-     * 注册用户
-     *
-     * @param string $username  用户名
-     * @param string $password  密码
-     * @param string $email     邮箱
-     * @param string $mobile    手机号
-     * @param array $extend    扩展参数
-     * @return boolean
-     */
-    public function register($username, $password, $email = '', $mobile = '', $extend = [])
-    {
-        // 检测用户名或邮箱、手机号是否存在
-        if (User::getByUsername($username))
-        {
-            $this->setError('Username already exist');
-            return FALSE;
-        }
-        if ($email && User::getByEmail($email))
-        {
-            $this->setError('Email already exist');
-            return FALSE;
-        }
-        //if ($mobile && User::getByMobile($mobile))
-        //{
-        //    $this->setError('Mobile already exist');
-        //    return FALSE;
-        //}
-
-        $ip = request()->ip();
-        $time = time();
-
-        $data = [
-            'username' => $username,
-            'password' => $password,
-            'email'    => $email,
-            'mobile'   => $mobile,
-            'level'    => 1,
-            'score'    => 0,
-            'avatar'   => '',
-        ];
-        $params = array_merge($data, [
-            'nickname'  => $username,
-            'salt'      => Random::alnum(),
-            'jointime'  => $time,
-            'joinip'    => $ip,
-            'logintime' => $time,
-            'loginip'   => $ip,
-            'prevtime'  => $time,
-            'status'    => 'normal'
-        ]);
-        $params['password'] = $this->getEncryptPassword($password, $params['salt']);
-        $params = array_merge($params, $extend);
-
-        //账号注册时需要开启事务,避免出现垃圾数据
-        Db::startTrans();
-        try
-        {
-            $user = User::create($params);
-            Db::commit();
-
-            // 此时的Model中只包含部分数据
-            $this->_user = User::get($user->id);
-
-            //设置Token
-            $this->_token = Random::uuid();
-            Token::set($this->_token, $user->id, $this->keeptime);
-
-            //注册成功的事件
-            Hook::listen("user_register_successed", $this->_user);
-
-            return TRUE;
-        }
-        catch (Exception $e)
-        {
-            $this->setError($e->getMessage());
-            Db::rollback();
-            return FALSE;
-        }
-    }
-
-    /**
-     * 用户登录
-     *
-     * @param string    $account    账号,用户名、邮箱、手机号
-     * @param string    $password   密码
-     * @return boolean
-     */
-    public function login($account, $password)
-    {
-        $field = Validate::is($account, 'email') ? 'email' : (Validate::regex($account, '/^1\d{10}$/') ? 'mobile' : 'username');
-        $user = User::get([$field => $account]);
-        if (!$user)
-        {
-            $this->setError('Account is incorrect');
-            return FALSE;
-        }
-
-        if (!empty($user->email_chkcode))
-        {
-            $this->setError('请验证邮箱后登陆');
-            return FALSE;
-        }
-
-        if ($user->status != 'normal')
-        {
-            $this->setError('Account is locked');
-            return FALSE;
-        }
-        if ($user->password != $this->getEncryptPassword($password, $user->salt))
-        {
-            $this->setError('Password is incorrect');
-            return FALSE;
-        }
-
-        //直接登录会员
-        $this->direct($user->id);
-
-        return TRUE;
-    }
-
-    /**
-     * 注销
-     * 
-     * @return boolean
-     */
-    public function logout()
-    {
-        if (!$this->_logined)
-        {
-            $this->setError('You are not logged in');
-            return false;
-        }
-        //设置登录标识
-        $this->_logined = FALSE;
-        //删除Token
-        Token::delete($this->_token);
-        //注销成功的事件
-        Hook::listen("user_logout_successed", $this->_user);
-        return TRUE;
-    }
-
-    /**
-     * 修改密码
-     * @param string    $newpassword        新密码
-     * @param string    $oldpassword        旧密码
-     * @param bool      $ignoreoldpassword  忽略旧密码
-     * @return boolean
-     */
-    public function changepwd($newpassword, $oldpassword = '', $ignoreoldpassword = false)
-    {
-        if (!$this->_logined)
-        {
-            $this->setError('You are not logged in');
-            return false;
-        }
-        //判断旧密码是否正确
-        if ($this->_user->password == $this->getEncryptPassword($oldpassword, $this->_user->salt) || $ignoreoldpassword)
-        {
-            $salt = Random::alnum();
-            $newpassword = $this->getEncryptPassword($newpassword, $salt);
-            $this->_user->save(['password' => $newpassword, 'salt' => $salt]);
-
-            Token::delete($this->_token);
-            //修改密码成功的事件
-            Hook::listen("user_changepwd_successed", $this->_user);
-            return true;
-        }
-        else
-        {
-            $this->setError('Password is incorrect');
-            return false;
-        }
-    }
-
-    /**
-     * 直接登录账号
-     * @param int $user_id
-     * @return boolean
-     */
-    public function direct($user_id)
-    {
-        $user = User::get($user_id);
-        if ($user)
-        {
-            ////////////////同步到Ucenter////////////////
-            if (defined('UC_STATUS') && UC_STATUS)
-            {
-                $uc = new \addons\ucenter\library\client\Client();
-                $re = $uc->uc_user_login($this->user->id, $this->user->password . '#split#' . $this->user->salt, 3);
-                // 如果小于0则说明发生错误
-                if ($re <= 0)
-                {
-                    $this->setError('Username or password is incorrect');
-                    return FALSE;
-                }
-            }
-
-            $ip = request()->ip();
-            $time = time();
-
-            //判断连续登录和最大连续登录
-            if ($user->logintime < \fast\Date::unixtime('day'))
-            {
-                $user->successions = $user->logintime < \fast\Date::unixtime('day', -1) ? 1 : $user->successions + 1;
-                $user->maxsuccessions = max($user->successions, $user->maxsuccessions);
-            }
-
-            $user->prevtime = $user->logintime;
-            //记录本次登录的IP和时间
-            $user->loginip = $ip;
-            $user->logintime = $time;
-
-            $user->save();
-
-            $this->_user = $user;
-
-            $this->_token = Random::uuid();
-            Token::set($this->_token, $user->id, $this->keeptime);
-
-            $this->_logined = TRUE;
-
-            //登录成功的事件
-            Hook::listen("user_login_successed", $this->_user);
-            return TRUE;
-        }
-        else
-        {
-            return FALSE;
-        }
-    }
-
-    /**
-     * 检测是否是否有对应权限
-     * @param string $path      控制器/方法
-     * @param string $module    模块 默认为当前模块
-     * @return boolean
-     */
-    public function check($path = NULL, $module = NULL)
-    {
-        if (!$this->_logined)
-            return false;
-
-        $ruleList = $this->getRuleList();
-        $rules = [];
-        foreach ($ruleList as $k => $v)
-        {
-            $rules[] = $v['name'];
-        }
-        $url = ($module ? $module : request()->module()) . '/' . (is_null($path) ? $this->getRequestUri() : $path);
-        $url = strtolower(str_replace('.', '/', $url));
-        return in_array($url, $rules) ? TRUE : FALSE;
-    }
-
-    /**
-     * 判断是否登录
-     * @return boolean
-     */
-    public function isLogin()
-    {
-        if ($this->_logined)
-        {
-            return true;
-        }
-        return false;
-    }
-
-    /**
-     * 获取当前Token
-     * @return string
-     */
-    public function getToken()
-    {
-        return $this->_token;
-    }
-
-    /**
-     * 获取会员基本信息
-     */
-    public function getUserinfo()
-    {
-        $data = $this->_user->toArray();
-        $allowFields = $this->getAllowFields();
-        $userinfo = array_intersect_key($data, array_flip($allowFields));
-        $userinfo = array_merge($userinfo, Token::get($this->_token));
-        return $userinfo;
-    }
-
-    /**
-     * 获取会员组别规则列表
-     * @return array
-     */
-    public function getRuleList()
-    {
-        if ($this->rules)
-            return $this->rules;
-        $group = $this->_user->group;
-        if (!$group)
-        {
-            return [];
-        }
-        $rules = explode(',', $group->rules);
-        $this->rules = UserRule::where('status', 'normal')->where('id', 'in', $rules)->field('id,pid,name,title,ismenu')->select();
-        return $this->rules;
-    }
-
-    /**
-     * 获取当前请求的URI
-     * @return string
-     */
-    public function getRequestUri()
-    {
-        return $this->requestUri;
-    }
-
-    /**
-     * 设置当前请求的URI
-     * @param string $uri
-     */
-    public function setRequestUri($uri)
-    {
-        $this->requestUri = $uri;
-    }
-
-    /**
-     * 获取允许输出的字段
-     * @return array
-     */
-    public function getAllowFields()
-    {
-        return $this->allowFields;
-    }
-
-    /**
-     * 设置允许输出的字段
-     * @param array $fields
-     */
-    public function setAllowFields($fields)
-    {
-        $this->allowFields = $fields;
-    }
-
-    /**
-     * 删除一个指定会员
-     * @param int $user_id 会员ID
-     * @return boolean
-     */
-    public function delete($user_id)
-    {
-        $user = User::get($user_id);
-        if (!$user)
-        {
-            return FALSE;
-        }
-
-        ////////////////同步到Ucenter////////////////
-        if (defined('UC_STATUS') && UC_STATUS)
-        {
-            $uc = new \addons\ucenter\library\client\Client();
-            $re = $uc->uc_user_delete($user['id']);
-            // 如果小于0则说明发生错误
-            if ($re <= 0)
-            {
-                $this->setError('Account is locked');
-                return FALSE;
-            }
-        }
-
-        // 调用事务删除账号
-        $result = Db::transaction(function($db) use($user_id) {
-                    // 删除会员
-                    User::destroy($user_id);
-                    // 删除会员指定的所有Token
-                    Token::clear($user_id);
-                    return TRUE;
-                });
-        if ($result)
-        {
-            Hook::listen("user_delete_successed", $user);
-        }
-        return $result ? TRUE : FALSE;
-    }
-
-    /**
-     * 获取密码加密后的字符串
-     * @param string $password  密码
-     * @param string $salt      密码盐
-     * @return string
-     */
-    public function getEncryptPassword($password, $salt = '')
-    {
-        return md5(md5($password) . $salt);
-    }
-
-    /**
-     * 检测当前控制器和方法是否匹配传递的数组
-     *
-     * @param array $arr 需要验证权限的数组
-     * @return boolean
-     */
-    public function match($arr = [])
-    {
-        $request = Request::instance();
-        $arr = is_array($arr) ? $arr : explode(',', $arr);
-        if (!$arr)
-        {
-            return FALSE;
-        }
-        $arr = array_map('strtolower', $arr);
-        // 是否存在
-        if (in_array(strtolower($request->action()), $arr) || in_array('*', $arr))
-        {
-            return TRUE;
-        }
-
-        // 没找到匹配
-        return FALSE;
-    }
-
-    /**
-     * 设置会话有效时间
-     * @param int $keeptime 默认为永久
-     */
-    public function keeptime($keeptime = 0)
-    {
-        $this->keeptime = $keeptime;
-    }
-
-    /**
-     * 渲染用户数据
-     * @param array     $datalist   二维数组
-     * @param mixed     $fields     加载的字段列表
-     * @param string    $fieldkey   渲染的字段
-     * @param string    $renderkey  结果字段
-     * @return array
-     */
-    public function render(&$datalist, $fields = [], $fieldkey = 'user_id', $renderkey = 'userinfo')
-    {
-        $fields = !$fields ? ['id', 'nickname', 'level', 'avatar'] : (is_array($fields) ? $fields : explode(',', $fields));
-        $ids = [];
-        foreach ($datalist as $k => $v)
-        {
-            if (!isset($v[$fieldkey]))
-                continue;
-            $ids[] = $v[$fieldkey];
-        }
-        $list = [];
-        if ($ids)
-        {
-            if (!in_array('id', $fields))
-            {
-                $fields[] = 'id';
-            }
-            $ids = array_unique($ids);
-            $selectlist = User::where('id', 'in', $ids)->column($fields);
-            foreach ($selectlist as $k => $v)
-            {
-                $list[$v['id']] = $v;
-            }
-        }
-        foreach ($datalist as $k => &$v)
-        {
-            $v[$renderkey] = isset($list[$v[$fieldkey]]) ? $list[$v[$fieldkey]] : NULL;
-        }
-        unset($v);
-        return $datalist;
-    }
-
-    /**
-     * 设置错误信息
-     *
-     * @param $error 错误信息
-     * @return Auth
-     */
-    public function setError($error)
-    {
-        $this->_error = $error;
-        return $this;
-    }
-
-    /**
-     * 获取错误信息
-     * @return string
-     */
-    public function getError()
-    {
-        return $this->_error ? __($this->_error) : '';
-    }
-
-}

+ 0 - 304
application/common/library/Common.php

@@ -1,304 +0,0 @@
-<?php
-
-namespace app\common\library;
-
-use app\common\model\Config;
-use app\common\model\OrderStatus;
-use app\common\model\User;
-use think\Hook;
-use think\Request;
-use app\common\library\QRcode;
-
-/**
- * 公共类
- */
-class Common
-{
-
-    /**
-     * curl 请求
-     * @param $url string 请求地址
-     * @param $headers json 请求头
-     * @param $body json 请求体
-     * @return mixed
-     */
-    public static function curlRequest($url, $headers = [], $body = [], $method = "GET")
-    {
-        $ch = curl_init();
-        curl_setopt($ch, CURLOPT_URL, $url);
-        curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);//设置请求头
-        curl_setopt($ch, CURLOPT_POSTFIELDS, $body);//设置请求体
-        curl_setopt($ch, CURLOPT_CUSTOMREQUEST, $method); //定义请求类型
-        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
-        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
-        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
-        curl_setopt($ch, CURLOPT_HTTP_VERSION, 'CURL_HTTP_VERSION_1_1');
-        $output = curl_exec($ch);
-        curl_close($ch);
-        $arr = json_decode($output, true);
-        return $arr;
-    }
-    /**
-     * 成功
-     * @param $msg
-     * @return array
-     */
-    public static function return_success($msg,$data = null){
-        $result = [
-            'code' => 1,
-            'msg'  => $msg,
-            'data' =>$data
-        ];
-        return $result;
-        die;
-    }
-
-    /**
-     * 失败
-     * @param $msg
-     * @return array
-     */
-    public static function return_error($msg,$data = null){
-        $result = [
-            'code' => 0,
-            'msg'  => $msg,
-            'data' => $data
-        ];
-        return $result;
-        die;
-    }
-
-
-    public static function get_ffid($invite_code){
-        $f = \app\common\model\User::where('id',$invite_code)->field('fid')->find();
-        if ($f)
-            return $f->fid;
-        else
-            return 0;
-    }
-
-
-    /**
-     * 生成二维码
-     */
-    public static function generate_qrcode($value){
-        $dir = dirname(realpath(dirname($_SERVER['SCRIPT_FILENAME']))) . '/public/verify';
-        if(!file_exists($dir)){
-            //检查是否有该文件夹,如果没有就创建,并给予最高权限
-            mkdir($dir, 0700,true);
-        }
-        $filename = $dir.'/'.$value.'.png';
-        QRcode::png($value,$filename);
-        return 'http://'.$_SERVER['SERVER_NAME']."/verify/".$value.'.png';
-    }
-
-
-    /**
-     * 生成二维码
-     */
-    public static function setqrcode($value,$name){
-        $dir = dirname(realpath(dirname($_SERVER['SCRIPT_FILENAME']))) . '/public/user';
-        if(!file_exists($dir)){
-            //检查是否有该文件夹,如果没有就创建,并给予最高权限
-            mkdir($dir, 0700,true);
-        }
-        $filename = $dir.'/'.$name.'.png';
-        QRcode::png($value,$filename,QR_ECLEVEL_L,7);
-        return 'http://'.$_SERVER['SERVER_NAME']."/user/".$name.'.png';
-    }
-
-    public static function setintivecode($user_id,$type){
-        $g = $type==1 ? 'invite' : 'mer';
-        $name = $g.$user_id."_".time();
-        $address = 'http://'.$_SERVER['SERVER_NAME'].'/build/#/'.$type.'/'.$user_id;
-        $url = self::setqrcode($address,$name);
-        return $url;
-    }
-
-
-    /**
-     * 订单操作记录
-     * @param int $change_message    操作备注
-     * @param int $oid  订单id
-     */
-    public static function order_status($oid, $change_message)
-    {
-        OrderStatus::create(['oid' => $oid,'change_message' => $change_message, 'change_time' => time()]);
-    }
-
-
-    /**
-     * 判断金额在哪个区间
-     */
-    public static function checkMoneyGrade($money){
-        if ($money<50000){
-            return false;
-        }elseif ($money>=50000 && $money<150000){
-            return 50000;
-        }elseif ($money>=150000 && $money<450000){
-            return 150000;
-        }elseif ($money>=450000 && $money<1350000){
-            return 450000;
-        }elseif ($money>=1350000 && $money<4000000){
-            return 1350000;
-        }elseif ($money>=4000000 && $money<12000000){
-            return 4000000;
-        }elseif ($money>=12000000 && $money<36000000){
-            return 12000000;
-        }elseif ($money>=36000000 && $money<100000000){
-            return 36000000;
-        }elseif ($money>=100000000 && $money<300000000){
-            return 100000000;
-        }elseif ($money>=300000000 && $money<600000000){
-            return 300000000;
-        }elseif ($money>=600000000){
-            return 600000000;
-        }
-    }
-
-
-    /**
-     * 生成订单唯一id
-     * $user_id  用户id
-     * @return string
-     */
-    public static function getNewOrderId($user_id)
-    {
-        $str = date('Ymd').$user_id.substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8);
-        return $str;
-    }
-
-
-
-    /**
-     * 身份证验证
-     * @param $card
-     * @return bool
-     */
-    public static function setCard($card){
-        $city = [11=>"北京",12=>"天津",13=>"河北",14=>"山西",15=>"内蒙古",21=>"辽宁",22=>"吉林",23=>"黑龙江 ",31=>"上海",32=>"江苏",33=>"浙江",34=>"安徽",35=>"福建",36=>"江西",37=>"山东",41=>"河南",42=>"湖北 ",43=>"湖南",44=>"广东",45=>"广西",46=>"海南",50=>"重庆",51=>"四川",52=>"贵州",53=>"云南",54=>"西藏 ",61=>"陕西",62=>"甘肃",63=>"青海",64=>"宁夏",65=>"新疆",71=>"台湾",81=>"香港",82=>"澳门",91=>"国外 "];
-        $tip = "";
-        $match = "/^\d{6}(18|19|20)?\d{2}(0[1-9]|1[012])(0[1-9]|[12]\d|3[01])\d{3}(\d|X)$/";
-        $pass= true;
-        if(!$card || !preg_match($match,$card)){
-            //身份证格式错误
-            $pass = false;
-        }else if(!$city[substr($card,0,2)]){
-            //地址错误
-            $pass = false;
-        }else{
-            //18位身份证需要验证最后一位校验位
-            if(strlen($card) == 18){
-                $card = str_split($card);
-                //∑(ai×Wi)(mod 11)
-                //加权因子
-                $factor = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ];
-                //校验位
-                $parity = [ 1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2 ];
-                $sum = 0;
-                $ai = 0;
-                $wi = 0;
-                for ($i = 0; $i < 17; $i++)
-                {
-                    $ai = $card[$i];
-                    $wi = $factor[$i];
-                    $sum += $ai * $wi;
-                }
-                $last = $parity[$sum % 11];
-                if($parity[$sum % 11] != $card[17]){
-                    $pass =false;
-                }
-            }else{
-                $pass =false;
-            }
-        }
-        if(!$pass) return false;/* 身份证格式错误*/
-        return true;/* 身份证格式正确*/
-    }
-
-
-
-    /**
-     * 高德地图api根据ip获取地区
-     */
-    public static function gaoDegetAreaToIp(){
-        $ip = request()->ip();
-        $content = file_get_contents("http://restapi.amap.com/v3/ip?key=7b60be14348558ca73ea081b3e871c6e&ip={$ip}");
-        $json = json_decode($content,true);
-        return $json;
-    }
-
-
-
-
-
-    /**
-     * 获取当前的经纬度
-     */
-    public static function get_ipjwd(){
-        $ip = request()->ip();
-        //获取百度地图apikey
-        $api_key = Config::get_values('baidu_api_server');
-        if ($ip=='127.0.0.1') {//如果获取到的ip为127.0.0.1 会报错  在这随便给一个ip
-            $ip='58.30.228.35';
-        }
-        $content = file_get_contents("http://api.map.baidu.com/location/ip?ak=$api_key&ip={$ip}&coor=bd09ll");
-        $json = json_decode($content);
-        $data=array();
-        $data['log']=$json->{'content'}->{'point'}->{'x'};//按层级关系提取经度数据
-        $data['lat']=$json->{'content'}->{'point'}->{'y'};//按层级关系提取纬度数据
-        $data['address']=$json->{'content'}->{'address'};//按层级关系提取address数据
-        return $data;
-    }
-
-
-    /**
-     * 计算距离
-     * 1.纬度1,经度1,纬度2,经度2
-     * 2.返回结果是单位是KM。
-     * 3.保留一位小数
-    */
-    public static function getDistance($lat2,$lng2,$lat='',$log='')
-    {
-        $user = app()->session->get('us');
-        $userinfo = User::get($user['id']);
-        if ($lat && $log) {
-            $lng1 = $log;
-            $lat1 = $lat;
-        }elseif ($userinfo && $userinfo['now_lat'] && $userinfo['now_log']){
-            $lng1 = $userinfo['now_log'];
-            $lat1 = $userinfo['now_lat'];
-        }else{
-            return "0";
-        }
-
-//        $userinfo = User::get($user['id']);
-//        if ($userinfo && $userinfo['now_lat'] && $userinfo['now_log']){
-//            $lng1 = $userinfo['now_log'];
-//            $lat1 = $userinfo['now_lat'];
-//        }else{
-//            if (!$lat2 || !$lng2)
-//                return '1';
-//            $ip = request()->ip();
-//            //获取百度地图apikey
-//            $api_key = Config::get_values('baidu_api_server');
-//            if ($ip=='127.0.0.1') {//如果获取到的ip为127.0.0.1 会报错  在这随便给一个ip
-//                $ip='58.30.228.35';
-//            }
-//            $content = file_get_contents("http://api.map.baidu.com/location/ip?ak=$api_key&ip={$ip}&coor=bd09ll");
-//            $json = json_decode($content);
-//            $lng1=$json->{'content'}->{'point'}->{'x'};//按层级关系提取经度数据
-//            $lat1=$json->{'content'}->{'point'}->{'y'};//按层级关系提取纬度数据
-//        }
-        //将角度转为狐度
-        $radLat1 = deg2rad($lat1);//deg2rad()函数将角度转换为弧度
-        $radLat2 = deg2rad($lat2);
-        $radLng1 = deg2rad($lng1);
-        $radLng2 = deg2rad($lng2);
-        $a = $radLat1 - $radLat2;
-        $b = $radLng1 - $radLng2;
-        $s = 2*asin(sqrt(pow(sin($a/2),2)+cos($radLat1)*cos($radLat2)*pow(sin($b/2),2)))*6371;
-        return round($s,1);
-    }
-
-}

+ 0 - 197
application/common/library/Email.php

@@ -1,197 +0,0 @@
-<?php
-
-namespace app\common\library;
-
-use PHPMailer\PHPMailer\PHPMailer;
-use think\Config;
-
-class Email
-{
-
-    /**
-     * 单例对象
-     */
-    protected static $instance;
-
-    /**
-     * phpmailer对象
-     */
-    protected $mail = [];
-
-    /**
-     * 错误内容
-     */
-    protected $_error = '';
-
-    /**
-     * 默认配置
-     */
-    public $options = [
-        'charset' => 'utf-8', //编码格式
-        'debug'   => 0, //调式模式
-    ];
-
-    /**
-     * 初始化
-     * @access public
-     * @param array $options 参数
-     * @return Email
-     */
-    public static function instance($options = [])
-    {
-        if (is_null(self::$instance))
-        {
-            self::$instance = new static($options);
-        }
-
-        return self::$instance;
-    }
-
-    /**
-     * 构造函数
-     * @param array $options
-     */
-    public function __construct($options = [])
-    {
-        if ($config = Config::get('smtp'))
-        {
-            $this->options = array_merge($this->options, $config);
-        }
-
-        $this->options = array_merge($this->options, $options);
-        vendor('phpmailer.phpmailer.PHPMailerAutoload');
-        $securArr = [1 => 'tls', 2 => 'ssl'];
-
-        $this->mail = new PHPMailer(true);
-        $this->mail->CharSet = $this->options['charset'];
-        $this->mail->SMTPDebug = $this->options['debug'];
-        $this->mail->isSMTP();
-        $this->mail->SMTPAuth = true;
-        $this->mail->Host = $this->options['server'];
-        $this->mail->Username = $this->options['smtpuser'];
-        $this->mail->Password = $this->options['smtpass'];
-        $this->mail->SMTPSecure = isset($securArr[$this->options['smttype']]) ? $securArr[$this->options['smttype']] : '';
-        $this->mail->Port = $this->options['serverport'];
-        //设置发件人
-        $this->from($this->options['usermail']);
-    }
-
-    /**
-     * 设置邮件主题
-     * @param string $subject
-     * @return $this
-     */
-    public function subject($subject)
-    {
-        $this->options['subject'] = $subject;
-        return $this;
-    }
-
-    /**
-     * 设置发件人
-     * @param string $email
-     * @param string $name
-     * @return $this
-     */
-    public function from($email, $name = '')
-    {
-        $this->options['from'] = $email;
-        $this->options['from_name'] = $name;
-        return $this;
-    }
-
-    /**
-     * 设置收件人
-     * @param string $email
-     * @param string $name
-     * @return $this
-     */
-    public function to($email, $name = '')
-    {
-        $this->options['to'] = $email;
-        $this->options['to_name'] = $name;
-        return $this;
-    }
-
-    /**
-     * 设置邮件正文
-     * @param string $body
-     * @param boolean $ishtml
-     * @return $this
-     */
-    public function message($body, $ishtml = true)
-    {
-        $this->options['body'] = $body;
-        $this->options['ishtml'] = $ishtml;
-        return $this;
-    }
-
-    /**
-     * 获取最后产生的错误
-     * @return string
-     */
-    public function getError()
-    {
-        return $this->_error;
-    }
-
-    /**
-     * 设置错误
-     * @param string $error 信息信息
-     */
-    protected function setError($error)
-    {
-        $this->_error = $error;
-    }
-
-    /**
-     * 发送邮件
-     * @return boolean
-     */
-    public function send()
-    {
-        $result = false;
-        switch ($this->options['mail_type'])
-        {
-            case 1:
-                //使用phpmailer发送
-                $this->mail->setFrom($this->options['from'], $this->options['from_name']);
-                $this->mail->addAddress($this->options['to'], $this->options['to_name']);
-                $this->mail->Subject = $this->options['subject'];
-                if ($this->options['ishtml'])
-                {
-                    $this->mail->msgHTML($this->options['body']);
-                }
-                else
-                {
-                    $this->mail->Body = $this->options['body'];
-                }
-                try
-                {
-                    $result = $this->mail->send();
-                }
-                catch (\phpmailerException $e)
-                {
-                    $this->setError($e->getMessage());
-                }
-
-                $this->setError($result ? '' : $this->mail->ErrorInfo);
-                break;
-            case 2:
-                //使用mail方法发送邮件
-                $headers = 'MIME-Version: 1.0' . "\r\n";
-                $headers .= "Content-type: text/html; charset=" . $this->options['charset'] . "\r\n";
-                $headers .= "To: {$this->options['to_name']} <{$this->options['to']}>\r\n"; //收件人
-                $headers .= "From: {$this->options['from_name']} <{$this->options['from']}>\r\n"; //发件人
-                $result = mail($this->options['to'], $this->options['subject'], $this->options['body'], $headers);
-                $this->setError($result ? '' : error_get_last()['message']);
-                break;
-            default:
-                //邮件功能已关闭
-                $this->setError(__('Mail already closed'));
-                break;
-        }
-        return $result;
-    }
-
-}

+ 0 - 144
application/common/library/Ems.php

@@ -1,144 +0,0 @@
-<?php
-
-namespace app\common\library;
-
-use think\Hook;
-
-/**
- * 邮箱验证码类
- */
-class Ems
-{
-
-    /**
-     * 验证码有效时长
-     * @var int 
-     */
-    protected static $expire = 120;
-
-    /**
-     * 最大允许检测的次数
-     * @var int 
-     */
-    protected static $maxCheckNums = 10;
-
-    /**
-     * 获取最后一次邮箱发送的数据
-     *
-     * @param   int       $email   邮箱
-     * @param   string    $event    事件
-     * @return  Ems
-     */
-    public static function get($email, $event = 'default')
-    {
-        $ems = \app\common\model\Ems::
-                where(['email' => $email, 'event' => $event])
-                ->order('id', 'DESC')
-                ->find();
-        Hook::listen('ems_get', $ems, null, true);
-        return $ems ? $ems : NULL;
-    }
-
-    /**
-     * 发送验证码
-     *
-     * @param   int       $email   邮箱
-     * @param   int       $code     验证码,为空时将自动生成4位数字
-     * @param   string    $event    事件
-     * @return  boolean
-     */
-    public static function send($email, $code = NULL, $event = 'default')
-    {
-        $code = is_null($code) ? mt_rand(1000, 9999) : $code;
-        $time = time();
-        $ip = request()->ip();
-        $ems = \app\common\model\Ems::create(['event' => $event, 'email' => $email, 'code' => $code, 'ip' => $ip, 'createtime' => $time]);
-        $result = Hook::listen('ems_send', $ems, null, true);
-        if (!$result)
-        {
-            $ems->delete();
-            return FALSE;
-        }
-        return TRUE;
-    }
-
-    /**
-     * 发送通知
-     * 
-     * @param   mixed     $email   邮箱,多个以,分隔
-     * @param   string    $msg      消息内容
-     * @param   string    $template 消息模板
-     * @return  boolean
-     */
-    public static function notice($email, $msg = '', $template = NULL)
-    {
-        $params = [
-            'email'    => $email,
-            'msg'      => $msg,
-            'template' => $template
-        ];
-        $result = Hook::listen('ems_notice', $params, null, true);
-        return $result ? TRUE : FALSE;
-    }
-
-    /**
-     * 校验验证码
-     *
-     * @param   int       $email     邮箱
-     * @param   int       $code       验证码
-     * @param   string    $event      事件
-     * @return  boolean
-     */
-    public static function check($email, $code, $event = 'default')
-    {
-        $time = time() - self::$expire;
-        $ems = \app\common\model\Ems::where(['email' => $email, 'event' => $event])
-                ->order('id', 'DESC')
-                ->find();
-        if ($ems)
-        {
-            if (strtotime($ems['createtime']) > $time && $ems['times'] <= self::$maxCheckNums)
-            {
-                $correct = $code == $ems['code'];
-                if (!$correct)
-                {
-                    $ems->times = $ems->times + 1;
-                    $ems->save();
-                    return FALSE;
-                }
-                else
-                {
-                    $result = Hook::listen('ems_check', $ems, null, true);
-                    return TRUE;
-                }
-            }
-            else
-            {
-                // 过期则清空该邮箱验证码
-                self::flush($email, $event);
-                return FALSE;
-            }
-        }
-        else
-        {
-            return FALSE;
-        }
-    }
-
-    /**
-     * 清空指定邮箱验证码
-     *
-     * @param   int       $email     邮箱
-     * @param   string    $event      事件
-     * @return  boolean
-     */
-    public static function flush($email, $event = 'default')
-    {
-        \app\common\model\Ems::
-                where(['email' => $email, 'event' => $event])
-                ->delete();
-        Hook::listen('ems_flush');
-        return TRUE;
-    }
-
-}

+ 0 - 142
application/common/library/Hecheng.php

@@ -1,142 +0,0 @@
-<?php
-namespace app\common\library;
-
-use app\common\model\Config;
-use think\Controller;
-
-class Hecheng extends Controller
-{
-    //获取预支付订单
-    public function hecheng($money,$pay_type){
-        # 填写网页上申请的appkey 如 $apiKey="g8eBUMSokVB1BHGmgxxxxxx"
-        $apiKey = "9sjcD2OQB71wBwGMEdGOvh2l";
-# 填写网页上申请的APP SECRET 如 $secretKey="94dc99566550d87f8fa8ece112xxxxx"
-        $secretKey = "j4VzpHUmraneN6wNCiSx3lkMKoNXWa0X";
-
-# text 的内容为"欢迎使用百度语音合成"的urlencode,utf-8 编码
-# 可以百度搜索"urlencode"
-        if ($pay_type=='weixin' || $pay_type=='yue'){
-            $text = "全民创商家微信收款".$money."元。";
-        }elseif ($pay_type=='zfb'){
-            $text = "全民创商家支付宝收款".$money."元。";
-        }
-
-        $text2 = iconv("UTF-8", "GBK", $text);
-
-# 发音人选择, 基础音库:0为度小美,1为度小宇,3为度逍遥,4为度丫丫,
-# 精品音库:5为度小娇,103为度米朵,106为度博文,110为度小童,111为度小萌,默认为度小美
-        $per = 0;
-#语速,取值0-15,默认为5中语速
-        $spd = 4;
-#音调,取值0-15,默认为5中语调
-        $pit = 5;
-#音量,取值0-9,默认为5中音量
-        $vol = 6;
-// 下载的文件格式, 3:mp3(default) 4: pcm-16k 5: pcm-8k 6. wav
-        $aue = 3;
-
-        $formats = array(3 => 'mp3', 4 => 'pcm', 5 =>'pcm', 6 => 'wav');
-        $format = $formats[$aue];
-
-        $cuid = time();
-
-        /** 公共模块获取token开始 */
-
-        $auth_url = "https://openapi.baidu.com/oauth/2.0/token?grant_type=client_credentials&client_id=".$apiKey."&client_secret=".$secretKey;
-        $ch = curl_init();
-        curl_setopt($ch, CURLOPT_URL, $auth_url);
-        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
-        curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
-        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); //信任任何证书
-        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0); // 检查证书中是否设置域名,0不验证
-        curl_setopt($ch, CURLOPT_VERBOSE, false);
-        $res = curl_exec($ch);
-        if(curl_errno($ch))
-        {
-            print curl_error($ch);
-        }
-        curl_close($ch);
-
-        $response = json_decode($res, true);
-
-        if (!isset($response['access_token'])){
-            echo "ERROR TO OBTAIN TOKEN\n";
-            exit(1);
-        }
-        if (!isset($response['scope'])){
-            echo "ERROR TO OBTAIN scopes\n";
-            exit(2);
-        }
-
-        if (!in_array('audio_tts_post',explode(" ", $response['scope']))){
-            echo "DO NOT have tts permission\n";
-            // 请至网页上应用内开通语音合成权限
-            exit(3);
-        }
-
-        $token = $response['access_token'];
-        /** 公共模块获取token结束 */
-
-        /** 拼接参数开始 **/
-// tex=$text&lan=zh&ctp=1&cuid=$cuid&tok=$token&per=$per&spd=$spd&pit=$pit&vol=$vol
-        $params = array(
-            'tex' => urlencode($text), // 为避免+等特殊字符没有编码,此处需要2次urlencode。
-            'per' => $per,
-            'spd' => $spd,
-            'pit' => $pit,
-            'vol' => $vol,
-            'aue' => $aue,
-            'cuid' => $cuid,
-            'tok' => $token,
-            'lan' => 'zh', //固定参数
-            'ctp' => 1, // 固定参数
-        );
-        $paramsStr =  http_build_query($params);
-        $url = 'http://tsn.baidu.com/text2audio';
-        $urltest = $url . '?' . $paramsStr;
-        //echo $urltest . "\n"; // 反馈请带上此url
-        return $urltest;
-        //die;
-        /** 拼接参数结束 **/
-
-        $g_has_error = true;
-        $ch = curl_init();
-        curl_setopt($ch, CURLOPT_URL, $url);
-        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
-        curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
-        curl_setopt ($ch, CURLOPT_POST, 1);
-        curl_setopt($ch, CURLOPT_POSTFIELDS, $paramsStr);
-        function read_header($ch, $header){
-            global $g_has_error;
-
-            $comps = explode(":", $header);
-            // 正常返回的头部 Content-Type: audio/*
-            // 有错误的如 Content-Type: application/json
-            if (count($comps) >= 2){
-                if (strcasecmp(trim($comps[0]), "Content-Type") == 0){
-                    if (strpos($comps[1], "audio/") > 0 ){
-                        $g_has_error = false;
-                    }else{
-                        echo $header ." , has error \n";
-                    }
-                }
-            }
-            return strlen($header);
-        }
-        //echo $urltest . "\n"; // 反馈请带上此urlcurl_setopt($ch, CURLOPT_HEADERFUNCTION, 'read_header');
-        $data = curl_exec($ch);
-        if(curl_errno($ch))
-        {
-            echo curl_error($ch);
-            exit(2);
-        }
-        curl_close($ch);
-        echo $urltest . "\n"; // 反馈请带上此url
-        die;
-        $file = $g_has_error ? "result.txt" : "result." . $format;
-        file_put_contents($file, $data);
-        echo "\n$file saved successed, please open it \n";
-    }
-
-
-}

+ 0 - 217
application/common/library/HuijuH5Pay.php

@@ -1,217 +0,0 @@
-<?php
-namespace app\common\library;
-use think\Controller;
-
-//汇聚银联h5、支付宝h5
-
-class HuijuH5Pay extends Controller
-{
-
-    public function __construct(){
-        $this->mch_no_trade = "888117500004672";
-
-        //报备商户号
-        $this->TradeMerchantNo = "777171600367612";
-        //商户私钥
-        $this->mchPrivateKey = "40c310e1a575470cb660f08937bf6313";
-    }
-
-    //银联h5
-    public function ylh5Pay($order_no,$ReturnUrl,$notifyurl,$good_name,$amount,$m_id,$type='1'){
-        if ($type==1){
-            $q1_fr = "ALIPAY_H5";
-        }elseif ($type==2){
-            $q1_fr = "UNIONPAY_H5";
-        }
-        //1.版本号
-        $params["p0_Version"] = "2.1";
-        //2.商户编号
-        $params["p1_MerchantNo"] = $this->mch_no_trade;
-        //3.商户订单号
-        $params["p2_OrderNo"] = $order_no;
-        //4.订单金额
-        $params["p3_Amount"] = $amount;
-        //5.交易币种
-        $params["p4_Cur"] = "1";
-        //6.商品名称
-        $params["p5_ProductName"] = $good_name;
-        //7.商品描述
-        $params["p6_ProductDesc"] = "";
-        //8.公用回传参数
-        $params["p7_Mp"] = $m_id;
-        //9.商户页面通知地址
-        $params["p8_ReturnUrl"] = $ReturnUrl;
-        //10.服务器异步通知地址
-        $params["p9_NotifyUrl"] = $notifyurl;
-        //11.交易类型
-        $params["q1_FrpCode"] = $q1_fr;
-        //18.微信 H5 模 式
-        //$params["q9_TransactionModel"] = "MODEL1";  //新增
-        //19.报备商户号
-        $params["qa_TradeMerchantNo"] = $this->TradeMerchantNo;  //新增
-
-        $hmacVal = urlencode($this->hmacRequest($params,$this->mchPrivateKey));
-        $params['hmac'] = $hmacVal;
-        $url = 'https://www.joinpay.com/trade/uniPayApi.action';
-        $result = http_post($url,$params);
-        $result = json_decode($result,true);
-        //dump($result);die;
-        return $result;
-
-    }
-
-
-
-
-    /**
-     * 生成签名
-     * @param $params
-     * @param $key
-     * @param string $encryptType
-     * @return string
-     */
-    function hmacRequest($params, $key, $encryptType = "1")
-    {
-        if ("1" == $encryptType) {
-            return md5(implode("", $params) . $key);
-        } else {
-            $private_key = openssl_pkey_get_private($key);
-            $params = implode("", $params);
-            openssl_sign($params, $sign, $private_key, OPENSSL_ALGO_MD5);
-            openssl_free_key($private_key);
-            $sign = base64_encode($sign);
-            return $sign;
-        }
-
-    }
-
-
-    /**
-     *  批量代付生成签名,由于批量代付包含details的字段,需要特殊处理
-     * @param $params
-     * @param $key
-     * @param string $encryptType
-     * @return string
-     */
-    function batchHmacRequest($params, $key, $encryptType = "1")
-    {
-        $details=$params['details'];
-        unset($params['details']);
-        $detailsStr='';
-        foreach ($details as $k=>$value){
-            $detailsStr.= implode("", $value);
-        }
-        if ("1" == $encryptType) {
-            return md5(implode("", $params) . $detailsStr . $key);
-        } else {
-            $private_key = openssl_pkey_get_private($key);
-            $params = implode("", $params).$detailsStr;
-            openssl_sign($params, $sign, $private_key, OPENSSL_ALGO_MD5);
-            openssl_free_key($private_key);
-            $sign = base64_encode($sign);
-            return $sign;
-        }
-
-    }
-
-
-
-
-//生成订单号
-    function getOrderId()
-    {
-        return date('Ymd') . str_pad(mt_rand(1, 99999), 5, '0', STR_PAD_LEFT);
-    }
-
-    /**
-     * 生成批量代付detail
-     *
-     *$detail=array(
-     * 0=>array(
-     *         1, //detailId
-     *          '张三',//payee
-     *          '6228480402564890018',//'bankacount'
-     *         '0.1',// 'money'
-     *          '代付接口测试1',//'desc'
-     *         '广州市',// 'city'
-     *          0,//'isVerify'
-     *          1,//'PublicOrPrivate'
-     *         102902500019,// 'num'
-     *      )
-     *
-     * )
-     * return str
-     *
-     * example
-     *  代付明细序号(必填)|收款人姓名(必填)|收款银行帐号(必填)|代付金额(必填)|代付说明|收款银行所在城市(必填)|是否审核(1:审核 0:不审核)|对公对私(1:对公 2:对私)|联行号(对公必填)
-     *  1001|张三|6228480402564890018|10.01|代付接口测试1|广州市|1|1|102902500019^1001|李四|6228480402564890018|10.01|代付接口测试2|广州市|1|1|102902500019
-     **/
-    function getProxyPayDetail(Array $detail)
-    {
-        $result = '';
-        foreach ($detail as $key => $item) {
-            if ($key != 0) {
-                $result .= '^';
-            }
-
-            $result .= implode('|', array_values($item));
-
-        }
-        return $result;
-    }
-
-
-    function decodeUnicode($str)
-    {
-        return preg_replace_callback('/\\\\u([0-9a-f]{4})/i',
-            create_function(
-                '$matches',
-                'return mb_convert_encoding(pack("H*", $matches[1]), "UTF-8", "UCS-2BE");'
-            ),
-            $str);
-    }
-
-    function output($str){
-        echo '<pre>'.decodeUnicode(json_encode(json_decode($str), JSON_PRETTY_PRINT)).'</pre>';
-    }
-
-
-
-
-    /**
-     *   判断文件是是否是图片
-     * @param $fileName
-     * @param $fileTmpName
-     *  @return bool true|false
-     */
-    function checkIsImage($fileName,$fileTmpName){
-
-        if( !in_array(substr(strrchr ( $fileName , "." ),1), array('jpg','png','bmp','jpeg')) || !getimagesize($fileTmpName)){
-            return false;
-        }
-        return true;
-    }
-
-    /**
-     * 获取图片的base64
-     * @param $file  $_FILES["file"]["tmp_name"]
-     * @param $type  png/
-     * @return string
-     */
-    function getImageBase64($file,$type){
-        $bin_string = file_get_contents($file);
-        return 'data:' . $type . ';base64,' . base64_encode($bin_string);
-    }
-
-
-    /**
-     * 生成批次id
-     * @param $length
-     * @return string
-     */
-    function getBatchId()
-    {
-        return "batch".getOrderId();
-    }
-
-}

+ 0 - 156
application/common/library/HuijuKjPay.php

@@ -1,156 +0,0 @@
-<?php
-namespace app\common\library;
-use think\Controller;
-
-require_once env('root_path').'application/common/library/huiju/kuaijie/entity/Request.php';
-require_once env('root_path').'application/common/library/huiju/kuaijie/entity/Response.php';
-require_once env('root_path').'application/common/library/huiju/kuaijie/entity/NotifyResponse.php';
-require_once env('root_path').'application/common/library/huiju/kuaijie/entity/SecretKey.php';
-require_once env('root_path').'application/common/library/huiju/kuaijie/entity/Callback.php';
-require_once env('root_path').'application/common/library/huiju/kuaijie/exceptions/SDKException.php';
-require_once env('root_path').'application/common/library/huiju/kuaijie/utils/AESUtil.php';
-require_once env('root_path').'application/common/library/huiju/kuaijie/utils/HttpUtil.php';
-require_once env('root_path').'application/common/library/huiju/kuaijie/utils/MD5Util.php';
-require_once env('root_path').'application/common/library/huiju/kuaijie/utils/RandomUtil.php';
-require_once env('root_path').'application/common/library/huiju/kuaijie/utils/RequestUtil.php';
-require_once env('root_path').'application/common/library/huiju/kuaijie/utils/RSAUtil.php';
-require_once env('root_path').'application/common/library/huiju/kuaijie/utils/SignUtil.php';
-require_once env('root_path').'application/common/library/huiju/kuaijie/utils/ObjectUtil.php';
-
-
-use joinpay\Request;
-use joinpay\SecretKey;
-use joinpay\RequestUtil;
-use joinpay\RandomUtil;
-use joinpay\AESUtil;
-
-class HuijuKjPay extends Controller
-{
-
-    public function __construct(){
-        $this->mch_no_trade = "888117500004672";
-        //平台公钥
-        $this->platPublicKey = "-----BEGIN PUBLIC KEY-----
-MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCS4CHpmFRfFJR2cMjx2Ii7WBck6W3QXjr8ubrrlKkGVwMCpZT+Dg85jhsCqoTdVYJlbwfqpXNs5+I4KJ1K4cTz/9DgAjQW2oJF7owsGqPVbsz5APh5mWtlil71UNLwLWhlmmS2NcdcI/PdCH8/IY11q55Ymt+R55cst4ZSl62cTQIDAQAB
------END PUBLIC KEY-----";
-
-//商户私钥
-        $this->mchPrivateKey = "-----BEGIN RSA PRIVATE KEY-----
-MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBAKJ2zCsD/JMiFRRwGJvpf80NeWmduNGZ/sfU3mJRi00CYE5d9KbMpmq/A5gEurNiVkgFCOs+vF3F+qd+tla2+RuX/izTQlxlgHUh0W48BYm8FQYgL6YsJQj6sM8VeTSW7ynUAQdqU0kGe32QtFP829uggHhxj20yUsFM8nzDdX/rAgMBAAECgYANU7Fr1efiKemQw6FBKOZS68gJ4eZHS1qbCds0NXw31PoRc6OeCyublg+1aK3oCSkKv1777SmGh7cIBlzuwBOvDlMBTllA1xOrt0A//QLfWz0ELlEoGKJQZLxluYINbcoxjH7FvYxMlWWhYIJWr1JiK+OKV7A6NND9yxN9yzrIAQJBAM3g5ibq3xaUjdcFu2UXCXpm/DViNcwVymdbujzjRd1DLNhvvOMSZ3utgi6UJSiA3ryMRbBGITFUFXlaqXB2jucCQQDKBCab1sQmU2O5dshNpw4PkR0v4bR6/g16V6GEZ+NN4Vpg4rVexn5p7/Hyte+DKWSXfc5pKff0RWdxPwWruvpdAkEAhdLyx8lUSfE2YdawAP4Agzf+KRU1svtXHehaHsn8196af/Xh6hhEe/hE7tINdU6PejAT/IkZel8VtlRgX2IxcQJADnQnkwTVuexDeVSPVkb6kZCPZwqeECK3Mias7r1EHSFfhwkRcvt+tfOt+vCbd2XxxYkByLJxBDAnC4o3zKavHQJBAJIdMjx5OAxAswBFxL7smSDGbxfoeTAGrSlbyKpDXaw8qCxi3yMPHaljBr4yP/hqaA+4oSTZ84K4PqO7x3CJ0eA=
------END RSA PRIVATE KEY-----";
-    }
-    //短信
-    public function sms(){
-        $secKey = 'FbNzMFZMxmTxICn8';
-        $data = [];
-       // $data["mch_no_trade"] = $this->mch_no_trade;
-        $data["mch_order_no"] = get_order_sn();
-        $data["order_amount"] = "0.01";
-        $data["mch_req_time"] = date('Y-m-d H:i:s', time());
-        $data["order_desc"] = "测试sdk-php7";
-        $data["id_type"] = "1";
-        $data["callback_param"] =null;
-        $data["payer_name"] = AESUtil::encryptECB("宋星伟", $secKey);//加密
-        $data["id_no"] = AESUtil::encryptECB("371324199210037710", $secKey);//加密
-        $data["bank_card_no"] = AESUtil::encryptECB("6217682503488661", $secKey);//加密
-        $data["mobile_no"] = AESUtil::encryptECB("15801075991", $secKey);//加密
-        dump($data);
-
-        $request = new Request();
-        $request->setMethod("fastPay.agreement.signSms");
-        $request->setVersion("1.0");
-        $request->setMchNo($this->mch_no_trade);
-        $request->setSignType("2");
-        $request->setRandStr(RandomUtil::randomStr(32));
-        $request->setData($data);
-        $request->setSecKey($secKey);//rsa有效
-
-        $secretKey = new SecretKey();
-        $secretKey->setReqSignKey($this->mchPrivateKey);//签名:使用商户私钥
-        $secretKey->setRespVerifyKey($this->platPublicKey);//验签:使用平台公钥
-        $secretKey->setSecKeyEncryptKey($this->platPublicKey);//sec_key加密:使用平台公钥
-        $secretKey->setSecKeyDecryptKey($this->mchPrivateKey);//sec_key解密:使用商户私钥
-        $url = "https://api.joinpay.com/fastpay";
-        try {
-            $response = RequestUtil::doRequest($url, $request, $secretKey);
-            dump($response);die;
-        } catch (Exception $e) {
-            print_r($e);
-        }
-    }
-    //签约
-    public function signing(){
-        $secKey = 'FbNzMFZMxmTxICn8';
-        $data = [];
-        $data["mch_no_trade"] = "888117500004672";
-        $data["mch_order_no"] = "202206251510324416840933";
-        $data["sms_code"] = "821991";
-
-        $request = new Request();
-        $request->setMethod("fastPay.agreement.smsSign");
-        $request->setVersion("1.0");
-        $request->setMchNo($this->mch_no_trade);
-        $request->setSignType("2");
-        $request->setRandStr(RandomUtil::randomStr(32));
-        $request->setData($data);
-        $request->setSecKey($secKey);//rsa有效
-        $secretKey = new SecretKey();
-        $secretKey->setReqSignKey($this->mchPrivateKey);//签名:使用商户私钥
-        $secretKey->setRespVerifyKey($this->platPublicKey);//验签:使用平台公钥
-        $secretKey->setSecKeyEncryptKey($this->platPublicKey);//sec_key加密:使用平台公钥
-        $secretKey->setSecKeyDecryptKey($this->mchPrivateKey);//sec_key解密:使用商户私钥
-        $url = "https://api.joinpay.com/fastpay";
-
-        try {
-            $response = RequestUtil::doRequest($url, $request, $secretKey);
-            dump($response);die;
-        } catch (Exception $e) {
-            print_r($e);
-        }
-    }
-
-
-
-    //支付
-    public function kuaijiePay(){
-
-
-        //$secKey = 'FbNzMFZMxmTxICn8';
-        $secKey = RandomUtil::randomStr(16);
-        $data = [];
-       // $data["mch_order_no"] = '202206251446464089001232';
-        $data["mch_order_no"] = get_order_sn();
-        $data["order_amount"] = "0.02";
-        $data["mch_req_time"] = date('Y-m-d H:i:s', time());
-        $data["order_desc"] = "测试sdk-php7";
-        $data["callback_url"] = 'https://'.$_SERVER['SERVER_NAME'].'/index.php/api/Pay/kuaijiePayNotify';//回调地址
-        $data["callback_param"] =null;
-        $data["bank_card_no"] = AESUtil::encryptECB("6217682503488661", $secKey);//加密
-
-        dump($data);
-
-
-        $request = new Request();
-        $request->setMethod("fastPay.agreement.pay");
-        $request->setVersion("1.0");
-        $request->setMchNo($this->mch_no_trade);
-        $request->setSignType("2");
-        $request->setRandStr(RandomUtil::randomStr(32));
-        $request->setData($data);
-        $request->setSecKey($secKey);//rsa有效
-
-        $secretKey = new SecretKey();
-        $secretKey->setReqSignKey($this->mchPrivateKey);//签名:使用商户私钥
-        $secretKey->setRespVerifyKey($this->platPublicKey);//验签:使用平台公钥
-        $secretKey->setSecKeyEncryptKey($this->platPublicKey);//sec_key加密:使用平台公钥
-        $secretKey->setSecKeyDecryptKey($this->mchPrivateKey);//sec_key解密:使用商户私钥
-
-        $url = "https://api.joinpay.com/fastpay";
-        try {
-            $response = RequestUtil::doRequest($url, $request, $secretKey);
-            dump($response);
-        } catch (Exception $e) {
-            print_r($e);
-        }
-    }
-}

+ 0 - 81
application/common/library/Jiyan.php

@@ -1,81 +0,0 @@
-<?php
-namespace app\common\library;
-use think\Controller;
-
-header('Content-type:text/html;charset=utf-8');
-class Jiyan extends Controller
-{
-
-    public static function jy($lot_number,$captcha_output,$pass_token,$gen_time,$type)
-    {
-        //type 1:发送短信验证码验证   2:下单验证
-        error_reporting(0);
-        // 1.初始化极验参数信息
-        // 1.initialize geetest parameter
-        switch ($type){
-            case 1:
-                $captcha_id = "46c329019f54e6d6e2171bc93da4fc57";
-                $captcha_key = "fcea1180bef1b1a84d3acb6338a4200c";
-                break;
-            case 2:
-                $captcha_id = "f79240154d3834df7b73d5514d555fff";
-                $captcha_key = "97ad4e9039d04bc21222fc504152708e";
-                break;
-        }
-        $api_server = "http://gcaptcha4.geetest.com";
-
-        // 3.生成签名
-// 3.generate signature
-// 生成签名使用标准的hmac算法,使用用户当前完成验证的流水号lot_number作为原始消息message,使用客户验证私钥作为key
-// use standard hmac algorithms to generate signatures, and take the user's current verification serial number lot_number as the original message, and the client's verification private key as the key
-// 采用sha256散列算法将message和key进行单向散列生成最终的签名
-// use sha256 hash algorithm to hash message and key in one direction to generate the final signature
-        $sign_token = hash_hmac('sha256', $lot_number, $captcha_key);
-
-// 4.上传校验参数到极验二次验证接口, 校验用户验证状态
-// 4.upload verification parameters to the secondary verification interface of GeeTest to validate the user verification status
-// captcha_id 参数建议放在 url 后面, 方便请求异常时可以在日志中根据id快速定位到异常请求
-// geetest recommends to put captcha_id parameter after url, so that when a request exception occurs, it can be quickly located in the log according to the id
-        $query = array(
-            "lot_number" => $lot_number,
-            "captcha_output" => $captcha_output,
-            "pass_token" => $pass_token,
-            "gen_time" => $gen_time,
-            "sign_token" => $sign_token
-        );
-        $url = sprintf($api_server . "/validate" . "?captcha_id=%s", $captcha_id);
-        $res = self::post_request($url,$query);
-        $obj = json_decode($res,true);
-        return $obj;
-    }
-
-    // 注意处理接口异常情况,当请求极验二次验证接口异常时做出相应异常处理
-// pay attention to interface exceptions, and make corresponding exception handling when requesting GeeTest secondary verification interface exceptions or response status is not 200
-// 保证不会因为接口请求超时或服务未响应而阻碍业务流程
-// website's business will not be interrupted due to interface request timeout or server not-responding
-    public static function post_request($url, $postdata) {
-        $data = http_build_query($postdata);
-
-        $options    = array(
-            'http' => array(
-                'method'  => 'POST',
-                'header'  => "Content-type: application/x-www-form-urlencoded",
-                'content' => $data,
-                'timeout' => 5
-            )
-        );
-        $context = stream_context_create($options);
-        $result    = file_get_contents($url, false, $context);
-        if($http_response_header[0] != 'HTTP/1.1 200 OK'){
-            $result = array(
-                "result" => "success",
-                "reason" => "request geetest api fail"
-            );
-            return json_encode($result);
-        }else{
-            return $result;
-        }
-    }
-
-
-}

+ 0 - 148
application/common/library/JuheRecharge.php

@@ -1,148 +0,0 @@
-<?php
-namespace app\common\library;
-
-use app\common\model\Config;
-use think\Controller;
-// +----------------------------------------------------------------------
-// | JuhePHP [ NO ZUO NO DIE ]
-// +----------------------------------------------------------------------
-// | Copyright (c) 2010-2015 http://juhe.cn All rights reserved.
-// +----------------------------------------------------------------------
-// | Author: Juhedata <info@juhe.cn-->
-// +----------------------------------------------------------------------
-
-//----------------------------------
-// 聚合数据-手机话费充值API调用类
-//----------------------------------
-class JuheRecharge {
-
-    private $appkey;
-
-    private $openid;
-
-    private $telCheckUrl = 'http://op.juhe.cn/ofpay/mobile/telcheck';
-
-    private $telQueryUrl = 'http://op.juhe.cn/ofpay/mobile/telquery';
-
-    private $submitUrl = 'http://op.juhe.cn/ofpay/mobile/onlineorder';
-
-    private $staUrl = 'http://op.juhe.cn/ofpay/mobile/ordersta';
-
-    public function __construct(){
-        $this->appkey = Config::get_values('juhe_appkey');
-        $this->openid = Config::get_values('juhe_openid');
-    }
-
-    /**
-     * 根据手机号码及面额查询是否支持充值
-     * @param  string $mobile   [手机号码]
-     * @param  int $pervalue [充值金额]
-     * @return  boolean
-     */
-    public function telcheck($mobile,$pervalue){
-        $params = 'key='.$this->appkey.'&phoneno='.$mobile.'&cardnum='.$pervalue;
-        $content = $this->juhecurl($this->telCheckUrl,$params);
-        $result = $this->_returnArray($content);
-        return $result;
-//        print_r($result);die;
-//        if($result['error_code'] == '0'){
-//            return true;
-//        }else{
-//            return false;
-//        }
-    }
-
-    /**
-     * 根据手机号码和面额获取商品信息
-     * @param  string $mobile   [手机号码]
-     * @param  int $pervalue [充值金额]
-     * @return  array
-     */
-    public function telquery($mobile,$pervalue){
-        $params = 'key='.$this->appkey.'&phoneno='.$mobile.'&cardnum='.$pervalue;
-        $content = $this->juhecurl($this->telQueryUrl,$params);
-        return $this->_returnArray($content);
-    }
-
-    /**
-     * 提交话费充值
-     * @param  [string] $mobile   [手机号码]
-     * @param  [int] $pervalue [充值面额]
-     * @param  [string] $orderid  [自定义单号]
-     * @return  [array]
-     */
-    public function telcz($mobile,$pervalue,$orderid){
-        $pervalue = floatval($pervalue);
-        $sign = md5($this->openid.$this->appkey.$mobile.$pervalue.$orderid);//校验值计算
-        $params = array(
-            'key' => $this->appkey,
-            'phoneno'   => $mobile,
-            'cardnum'   => $pervalue,
-            'orderid'   => $orderid,
-            'sign' => $sign
-        );
-        $content = $this->juhecurl($this->submitUrl,$params,1);
-        return $this->_returnArray($content);
-    }
-
-    /**
-     * 查询订单的充值状态
-     * @param  [string] $orderid [自定义单号]
-     * @return  [array]
-     */
-    public function sta($orderid){
-        $params = 'key='.$this->appkey.'&orderid='.$orderid;
-        $content = $this->juhecurl($this->staUrl,$params);
-        return $this->_returnArray($content);
-    }
-
-    /**
-     * 将JSON内容转为数据,并返回
-     * @param string $content [内容]
-     * @return array
-     */
-    public function _returnArray($content){
-        return json_decode($content,true);
-    }
-
-    /**
-     * 请求接口返回内容
-     * @param  string $url [请求的URL地址]
-     * @param  string $params [请求的参数]
-     * @param  int $ipost [是否采用POST形式]
-     * @return  string
-     */
-    public function juhecurl($url,$params=false,$ispost=0){
-        $httpInfo = array();
-        $ch = curl_init();
-
-        curl_setopt( $ch, CURLOPT_HTTP_VERSION , CURL_HTTP_VERSION_1_1 );
-        curl_setopt( $ch, CURLOPT_USERAGENT , 'JuheData' );
-        curl_setopt( $ch, CURLOPT_CONNECTTIMEOUT , 60 );
-        curl_setopt( $ch, CURLOPT_TIMEOUT , 60);
-        curl_setopt( $ch, CURLOPT_RETURNTRANSFER , true );
-        if( $ispost )
-        {
-            curl_setopt( $ch , CURLOPT_POST , true );
-            curl_setopt( $ch , CURLOPT_POSTFIELDS , $params );
-            curl_setopt( $ch , CURLOPT_URL , $url );
-        }
-        else
-        {
-            if($params){
-                curl_setopt( $ch , CURLOPT_URL , $url.'?'.$params );
-            }else{
-                curl_setopt( $ch , CURLOPT_URL , $url);
-            }
-        }
-        $response = curl_exec( $ch );
-        if ($response === FALSE) {
-            //echo "cURL Error: " . curl_error($ch);
-            return false;
-        }
-        $httpCode = curl_getinfo( $ch , CURLINFO_HTTP_CODE );
-        $httpInfo = array_merge( $httpInfo , curl_getinfo( $ch ) );
-        curl_close( $ch );
-        return $response;
-    }
-}

+ 0 - 144
application/common/library/Menu.php

@@ -1,144 +0,0 @@
-<?php
-
-namespace app\common\library;
-
-use app\admin\model\AuthRule;
-use fast\Tree;
-use think\Exception;
-use think\exception\PDOException;
-
-class Menu
-{
-
-    /**
-     * 创建菜单
-     * @param array $menu
-     * @param mixed $parent 父类的name或pid
-     */
-    public static function create($menu, $parent = 0)
-    {
-        if (!is_numeric($parent))
-        {
-            $parentRule = AuthRule::getByName($parent);
-            $pid = $parentRule ? $parentRule['id'] : 0;
-        }
-        else
-        {
-            $pid = $parent;
-        }
-        $allow = array_flip(['file', 'name', 'title', 'icon', 'condition', 'remark', 'ismenu']);
-        foreach ($menu as $k => $v)
-        {
-            $hasChild = isset($v['sublist']) && $v['sublist'] ? true : false;
-
-            $data = array_intersect_key($v, $allow);
-
-            $data['ismenu'] = isset($data['ismenu']) ? $data['ismenu'] : ($hasChild ? 1 : 0);
-            $data['icon'] = isset($data['icon']) ? $data['icon'] : ($hasChild ? 'fa fa-list' : 'fa fa-circle-o');
-            $data['pid'] = $pid;
-            $data['status'] = 'normal';
-            try
-            {
-                $menu = AuthRule::create($data);
-                if ($hasChild)
-                {
-                    self::create($v['sublist'], $menu->id);
-                }
-            }
-            catch (PDOException $e)
-            {
-                throw new Exception($e->getMessage());
-            }
-        }
-    }
-
-    /**
-     * 删除菜单
-     * @param string $name 规则name 
-     * @return boolean
-     */
-    public static function delete($name)
-    {
-        $ids = self::getAuthRuleIdsByName($name);
-        if (!$ids)
-        {
-            return false;
-        }
-        AuthRule::destroy($ids);
-        return true;
-    }
-
-    /**
-     * 启用菜单
-     * @param string $name
-     * @return boolean
-     */
-    public static function enable($name)
-    {
-        $ids = self::getAuthRuleIdsByName($name);
-        if (!$ids)
-        {
-            return false;
-        }
-        AuthRule::where('id', 'in', $ids)->update(['status' => 'normal']);
-        return true;
-    }
-
-    /**
-     * 禁用菜单
-     * @param string $name
-     * @return boolean
-     */
-    public static function disable($name)
-    {
-        $ids = self::getAuthRuleIdsByName($name);
-        if (!$ids)
-        {
-            return false;
-        }
-        AuthRule::where('id', 'in', $ids)->update(['status' => 'hidden']);
-        return true;
-    }
-
-    /**
-     * 导出指定名称的菜单规则
-     * @param string $name
-     * @return array
-     */
-    public static function export($name)
-    {
-        $ids = self::getAuthRuleIdsByName($name);
-        if (!$ids)
-        {
-            return [];
-        }
-        $menuList = [];
-        $menu = AuthRule::getByName($name);
-        if ($menu)
-        {
-            $ruleList = collection(AuthRule::where('id', 'in', $ids)->select())->toArray();
-            $menuList = Tree::instance()->init($ruleList)->getTreeArray($menu['id']);
-        }
-        return $menuList;
-    }
-
-    /**
-     * 根据名称获取规则IDS
-     * @param string $name
-     * @return array
-     */
-    public static function getAuthRuleIdsByName($name)
-    {
-        $ids = [];
-        $menu = AuthRule::getByName($name);
-        if ($menu)
-        {
-            // 必须将结果集转换为数组
-            $ruleList = collection(AuthRule::order('weigh', 'desc')->field('id,pid,name')->select())->toArray();
-            // 构造菜单数据
-            $ids = Tree::instance()->init($ruleList)->getChildrenIds($menu['id'], true);
-        }
-        return $ids;
-    }
-
-}

+ 0 - 245
application/common/library/PHPExcelService.php

@@ -1,245 +0,0 @@
-<?php
-namespace app\common\library;
-
-use crmeb\services\JsonService as Json;
-
-class PHPExcelService
-{
-    //PHPExcel实例化对象
-    private static $PHPExcel=null;
-    //表头计数
-    protected static $count;
-    //表头占行数
-    protected static $topNumber = 1;
-    //表能占据表行的字母对应self::$cellkey
-    protected static $cells;
-    //表头数据
-    protected static $data=[];
-    //文件名
-    protected static $title='导出';
-    //行宽
-    protected static $where=20;
-    //行高
-    protected static $height=50;
-    //表行名
-    private static $cellKey = array(
-        'A','B','C','D','E','F','G','H','I','J','K','L','M',
-        'N','O','P','Q','R','S','T','U','V','W','X','Y','Z',
-        'AA','AB','AC','AD','AE','AF','AG','AH','AI','AJ','AK','AL','AM',
-        'AN','AO','AP','AQ','AR','AS','AT','AU','AV','AW','AX','AY','AZ'
-    );
-    //设置style
-    private static $styleArray = array(
-        'borders' => array(
-            'allborders' => array(
-//                PHPExcel_Style_Border里面有很多属性,想要其他的自己去看
-//                'style' => \PHPExcel_Style_Border::BORDER_THICK,//边框是粗的
-//                'style' => \PHPExcel_Style_Border::BORDER_DOUBLE,//双重的
-//                'style' => \PHPExcel_Style_Border::BORDER_HAIR,//虚线
-//                'style' => \PHPExcel_Style_Border::BORDER_MEDIUM,//实粗线
-//                'style' => \PHPExcel_Style_Border::BORDER_MEDIUMDASHDOT,//虚粗线
-//                'style' => \PHPExcel_Style_Border::BORDER_MEDIUMDASHDOTDOT,//点虚粗线
-                'style' => \PHPExcel_Style_Border::BORDER_THIN,//细边框
-                //'color' => array('argb' => 'FFFF0000'),
-            ),
-        ),
-        'font'=>[
-            'bold'=>true
-        ],
-        'alignment'=>[
-            'horizontal'=>\PHPExcel_Style_Alignment::HORIZONTAL_CENTER,
-            'vertical'=>\PHPExcel_Style_Alignment::VERTICAL_CENTER
-        ]
-    );
-    /**
-     *初始化PHPExcel类
-     *@param $data array()
-     *@param $fun function()
-     * return
-     */
-    private static function initialize($data,$fun){
-        self::$PHPExcel= new \PHPExcel();
-        if($fun!==null && is_callable($fun)){
-            self::$styleArray=$fun();
-        }
-        if(!is_array($data)) exit(Json::fail('data 为数组'));
-        self::$data=$data;
-    }
-    /**
-     *设置字体格式
-     *@param $title string 必选
-     * return string
-     */
-    public static function setUtf8($title){
-        return "";
-        //return iconv('utf-8', 'gb2312', $title);
-    }
-    /**
-     *
-     * execl数据导出
-     * @param  $list 需要导出的数据 格式和以前的可是一样
-     * @param  $list 也可以为匿名函数 匿名函数参数有 $sheet PHPExcel->getActiveSheet(),self::$topNumber 从第几行设置,$cellkey 行号为数组,self::$cells现在设置的最大行号
-     *
-     * 特殊处理:合并单元格需要先对数据进行处理
-     */
-    public function setExcelContent($list=null)
-    {
-        $sheet=self::$PHPExcel->getActiveSheet();
-        foreach(self::$data as $key=>$val){
-            $row=self::$cellKey[$key];
-            $sheet->getColumnDimension($row)->setWidth(isset($val['w'])?$val['w']:self::$where);
-            $sheet->setCellValue($row.self::$topNumber,isset($val['name'])?$val['name']:$val);
-        }
-        $cellkey=array_slice(self::$cellKey,0,self::$count);
-        if($list!==null && is_array($list)){
-            foreach ($cellkey as $k=>$v){
-                foreach ($list as $key=>$val){
-                    if(isset($val[$k]) && !is_array($val[$k])){
-                        $sheet->setCellValue($v.(self::$topNumber+1+$key),$val[$k]);
-                    }else if(isset($val[$k]) && is_array($val[$k])){
-                        $str='';
-                        foreach ($val[$k] as $value){
-                            $str.=$value.chr(10);
-                        }
-                        $sheet->setCellValue($v.(self::$topNumber+1+$key),$str);
-                    }
-                }
-            }
-            $sheet->getDefaultRowDimension()->setRowHeight(self::$height);
-            //设置边框
-            $sheet->getStyle('A1:'.self::$cells.(count($list)+self::$topNumber))->applyFromArray(self::$styleArray);
-            //设置自动换行
-            $sheet->getStyle('A4:'.self::$cells.(count($list)+self::$topNumber))->getAlignment()->setWrapText(true);
-        }else if($list!==null && is_callable($list)){
-            $list($sheet,self::$topNumber,$cellkey,self::$cells)->applyFromArray(self::$styleArray);
-        }
-
-        return $this;
-    }
-    /**
-     * 保存表格数据,并下载
-     * @param
-     * @return
-     */
-    public function ExcelSave(){
-        error_reporting(0);
-        $objWriter=\PHPExcel_IOFactory::createWriter(self::$PHPExcel,'Excel2007');
-        $filename=self::$title.'--'.time().'.xlsx';
-        ob_end_clean();
-        header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
-        header('Content-Type: application/vnd.ms-excel');
-        header('Content-Type: application/octet-stream');
-        header('Content-Disposition: attachment; filename="' . $filename . '"');
-        header('Cache-Control: max-age=0');
-        $objWriter->save('php://output');
-        exit;
-    }
-
-    /**
-     * 设置头部信息
-     * @param $data array
-     * @param $fun function() 主要设置边框的粗细
-     * @return $this
-     */
-    public static function setExcelHeader($data,$fun=null)
-    {
-        self::initialize($data,$fun);
-
-        if(self::$count=count(self::$data)){
-            if(self::$count>count(self::$cellKey)){
-                return Json::fail('表头长度过长');
-            }
-            self::$cells=self::$cellKey[self::$count-1];
-        }else{
-            return Json::fail('data 参数二不能为空');
-        }
-        return new self;
-    }
-    /**
-     * 设置标题
-     * @param $title string || array ['title'=>'','name'=>'','info'=>[]]
-     * @param $Name string
-     * @param $info string || array;
-     * @param $funName function($style,$A,$A2) 自定义设置头部样式
-     * @return $this
-     */
-    public function setExcelTile($title='',$Name='',$info=[],$funName=null){
-        //设置参数
-        if(is_array($title)){
-            if(isset($title['title'])) $title=$title['title'];
-            if(isset($title['name'])) $Name=$title['name'];
-            if(isset($title['info'])) $info=$title['info'];
-        }
-        if(empty($title))
-            $title=self::$title;
-        else
-            self::$title=$title;
-        if(empty($Name)) $Name=time();
-        //设置Excel属性
-        self::$PHPExcel ->getProperties()
-            ->setCreator("Neo")
-            ->setLastModifiedBy("Neo")
-            ->setTitle(self::setUtf8($title))
-            ->setSubject($Name)
-            ->setDescription("")
-            ->setKeywords($Name)
-            ->setCategory("");
-        //self::$PHPExcel ->getActiveSheet()->setCellValue('A1', $title);
-        //文字居中
-        self::$PHPExcel->getActiveSheet()->getStyle('A1')->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
-        self::$PHPExcel->getActiveSheet()->getStyle('A2')->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
-        self::$PHPExcel->setActiveSheetIndex(0);
-        self::$PHPExcel->getActiveSheet()->setTitle($Name);
-
-        //self::$PHPExcel->getActiveSheet()->setCellValue('A2',self::setCellInfo($info));
-        //合并表头单元格
-        self::$PHPExcel->getActiveSheet()->mergeCells('A1:'.self::$cells.'1');
-        self::$PHPExcel->getActiveSheet()->mergeCells('A2:'.self::$cells.'2');
-
-        self::$PHPExcel->getActiveSheet()->getRowDimension(1)->setRowHeight(40);
-        self::$PHPExcel->getActiveSheet()->getRowDimension(2)->setRowHeight(20);
-        //设置表头行高
-        if($funName!==null && is_callable($funName)){
-            $fontstyle=self::$PHPExcel->getActiveSheet();
-            $funName($fontstyle,'A1','A2');
-        }else{
-            //设置表头字体
-            //self::$PHPExcel->getActiveSheet()->getStyle('A1')->getFont()->setName('黑体');
-            //self::$PHPExcel->getActiveSheet()->getStyle('A1')->getFont()->setSize(20);
-           // self::$PHPExcel->getActiveSheet()->getStyle('A1')->getFont()->setBold(true);
-//            self::$PHPExcel->getActiveSheet()->getStyle('A2')->getFont()->setName('宋体');
-//            self::$PHPExcel->getActiveSheet()->getStyle('A2')->getFont()->setSize(14);
-        }
-        self::$PHPExcel->getActiveSheet()->getStyle('A3:'.self::$cells.'3')->getFont()->setBold(true);
-
-        return $this;
-    }
-    /**
-     * 设置第二行标题内容
-     * @param $info  array (['name'=>'','site'=>'','phone'=>123] || ['我是表名','我是地址','我是手机号码'] ) || string 自定义
-     * @return string
-     */
-    private static function setCellInfo($info){
-        $content=['操作者:','导出日期:'.date('Y-m-d',time()),'地址:','电话:'];
-        if(is_array($info) && !empty($info)){
-            if(isset($info['name'])){
-                $content[0].=$info['name'];
-            }else{
-                $content[0].=isset($info[0])?$info[0]:'';
-            }
-            if(isset($info['site'])){
-                $content[2].=$info['site'];
-            }else{
-                $content[2].=isset($info[1])?$info[1]:'';
-            }
-            if(isset($info['phone'])){
-                $content[3].=$info['phone'];
-            }else{
-                $content[3].=isset($info[2])?$info[2]:'';
-            }
-            return implode(' ',$content);
-        }else if(is_string($info)){
-            return empty($info)?implode(' ',$content):$info;
-        }
-    }
-}

+ 0 - 3223
application/common/library/QRcode.php

@@ -1,3223 +0,0 @@
-<?php
-   namespace app\common\library;
-	define('QR_MODE_NUL', -1);
-	define('QR_MODE_NUM', 0);
-	define('QR_MODE_AN', 1);
-	define('QR_MODE_8', 2);
-	define('QR_MODE_KANJI', 3);
-	define('QR_MODE_STRUCTURE', 4);
-
-	// Levels of error correction.
-
-	define('QR_ECLEVEL_L', 0);
-	define('QR_ECLEVEL_M', 1);
-	define('QR_ECLEVEL_Q', 2);
-	define('QR_ECLEVEL_H', 3);
-	
-	// Supported output formats
-	
-	define('QR_FORMAT_TEXT', 0);
-	define('QR_FORMAT_PNG',  1);
-	
-	class qrstr {
-		public static function set(&$srctab, $x, $y, $repl, $replLen = false) {
-			$srctab[$y] = substr_replace($srctab[$y], ($replLen !== false)?substr($repl,0,$replLen):$repl, $x, ($replLen !== false)?$replLen:strlen($repl));
-		}
-	}
-     
-    define('QR_CACHEABLE', false);       // use cache - more disk reads but less CPU power, masks and format templates are stored there
-    define('QR_CACHE_DIR', false);       // used when QR_CACHEABLE === true
-    define('QR_LOG_DIR', false);         // default error logs dir   
-    
-    define('QR_FIND_BEST_MASK', true);                                                          // if true, estimates best mask (spec. default, but extremally slow; set to false to significant performance boost but (propably) worst quality code
-    define('QR_FIND_FROM_RANDOM', 2);                                                       // if false, checks all masks available, otherwise value tells count of masks need to be checked, mask id are got randomly
-    define('QR_DEFAULT_MASK', 2);                                                               // when QR_FIND_BEST_MASK === false
-                                                  
-    define('QR_PNG_MAXIMUM_SIZE',  1024);                                                       // maximum allowed png image width (in pixels), tune to make sure GD and PHP can handle such big images
-                                                  
-
-
-
-//---- qrtools.php -----------------------------
-
-
-
-
-/*
- * PHP QR Code encoder
- *
- * Toolset, handy and debug utilites.
- *
- * PHP QR Code is distributed under LGPL 3
- * Copyright (C) 2010 Dominik Dzienia <deltalab at poczta dot fm>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
- */
-
-    class QRtools {
-    
-        //----------------------------------------------------------------------
-        public static function binarize($frame)
-        {
-            $len = count($frame);
-            foreach ($frame as &$frameLine) {
-                
-                for($i=0; $i<$len; $i++) {
-                    $frameLine[$i] = (ord($frameLine[$i])&1)?'1':'0';
-                }
-            }
-            
-            return $frame;
-        }
-        
-        //----------------------------------------------------------------------
-        public static function tcpdfBarcodeArray($code, $mode = 'QR,L', $tcPdfVersion = '4.5.037')
-        {
-            $barcode_array = array();
-            
-            if (!is_array($mode))
-                $mode = explode(',', $mode);
-                
-            $eccLevel = 'L';
-                
-            if (count($mode) > 1) {
-                $eccLevel = $mode[1];
-            }
-                
-            $qrTab = QRcode::text($code, false, $eccLevel);
-            $size = count($qrTab);
-                
-            $barcode_array['num_rows'] = $size;
-            $barcode_array['num_cols'] = $size;
-            $barcode_array['bcode'] = array();
-                
-            foreach ($qrTab as $line) {
-                $arrAdd = array();
-                foreach(str_split($line) as $char)
-                    $arrAdd[] = ($char=='1')?1:0;
-                $barcode_array['bcode'][] = $arrAdd;
-            }
-                    
-            return $barcode_array;
-        }
-        
-        //----------------------------------------------------------------------
-        public static function clearCache()
-        {
-            self::$frames = array();
-        }
-        
-        //----------------------------------------------------------------------
-        public static function buildCache()
-        {
-			QRtools::markTime('before_build_cache');
-			
-			$mask = new QRmask();
-            for ($a=1; $a <= QRSPEC_VERSION_MAX; $a++) {
-                $frame = QRspec::newFrame($a);
-                if (QR_IMAGE) {
-                    $fileName = QR_CACHE_DIR.'frame_'.$a.'.png';
-                    QRimage::png(self::binarize($frame), $fileName, 1, 0);
-                }
-				
-				$width = count($frame);
-				$bitMask = array_fill(0, $width, array_fill(0, $width, 0));
-				for ($maskNo=0; $maskNo<8; $maskNo++)
-					$mask->makeMaskNo($maskNo, $width, $frame, $bitMask, true);
-            }
-			
-			QRtools::markTime('after_build_cache');
-        }
-
-        //----------------------------------------------------------------------
-        public static function log($outfile, $err)
-        {
-            if (QR_LOG_DIR !== false) {
-                if ($err != '') {
-                    if ($outfile !== false) {
-                        file_put_contents(QR_LOG_DIR.basename($outfile).'-errors.txt', date('Y-m-d H:i:s').': '.$err, FILE_APPEND);
-                    } else {
-                        file_put_contents(QR_LOG_DIR.'errors.txt', date('Y-m-d H:i:s').': '.$err, FILE_APPEND);
-                    }
-                }    
-            }
-        }
-        
-        //----------------------------------------------------------------------
-        public static function dumpMask($frame) 
-        {
-            $width = count($frame);
-            for($y=0;$y<$width;$y++) {
-                for($x=0;$x<$width;$x++) {
-                    echo ord($frame[$y][$x]).',';
-                }
-            }
-        }
-        
-        //----------------------------------------------------------------------
-        public static function markTime($markerId)
-        {
-            list($usec, $sec) = explode(" ", microtime());
-            $time = ((float)$usec + (float)$sec);
-            
-            if (!isset($GLOBALS['qr_time_bench']))
-                $GLOBALS['qr_time_bench'] = array();
-            
-            $GLOBALS['qr_time_bench'][$markerId] = $time;
-        }
-        
-        //----------------------------------------------------------------------
-        public static function timeBenchmark()
-        {
-            self::markTime('finish');
-        
-            $lastTime = 0;
-            $startTime = 0;
-            $p = 0;
-
-            echo '<table cellpadding="3" cellspacing="1">
-                    <thead><tr style="border-bottom:1px solid silver"><td colspan="2" style="text-align:center">BENCHMARK</td></tr></thead>
-                    <tbody>';
-
-            foreach($GLOBALS['qr_time_bench'] as $markerId=>$thisTime) {
-                if ($p > 0) {
-                    echo '<tr><th style="text-align:right">till '.$markerId.': </th><td>'.number_format($thisTime-$lastTime, 6).'s</td></tr>';
-                } else {
-                    $startTime = $thisTime;
-                }
-                
-                $p++;
-                $lastTime = $thisTime;
-            }
-            
-            echo '</tbody><tfoot>
-                <tr style="border-top:2px solid black"><th style="text-align:right">TOTAL: </th><td>'.number_format($lastTime-$startTime, 6).'s</td></tr>
-            </tfoot>
-            </table>';
-        }
-        
-    }
-    
-    //##########################################################################
-    
-    QRtools::markTime('start');
-    
-
-
-
-//---- qrspec.php -----------------------------
-
-
-
-
-/*
- * PHP QR Code encoder
- *
- * QR Code specifications
- *
- * Based on libqrencode C library distributed under LGPL 2.1
- * Copyright (C) 2006, 2007, 2008, 2009 Kentaro Fukuchi <fukuchi@megaui.net>
- *
- * PHP QR Code is distributed under LGPL 3
- * Copyright (C) 2010 Dominik Dzienia <deltalab at poczta dot fm>
- *
- * The following data / specifications are taken from
- * "Two dimensional symbol -- QR-code -- Basic Specification" (JIS X0510:2004)
- *  or
- * "Automatic identification and data capture techniques -- 
- *  QR Code 2005 bar code symbology specification" (ISO/IEC 18004:2006)
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
- */
- 
-    define('QRSPEC_VERSION_MAX', 40);
-    define('QRSPEC_WIDTH_MAX',   177);
-
-    define('QRCAP_WIDTH',        0);
-    define('QRCAP_WORDS',        1);
-    define('QRCAP_REMINDER',     2);
-    define('QRCAP_EC',           3);
-
-    class QRspec {
-    
-        public static $capacity = array(
-            array(  0,    0, 0, array(   0,    0,    0,    0)),
-            array( 21,   26, 0, array(   7,   10,   13,   17)), // 1
-            array( 25,   44, 7, array(  10,   16,   22,   28)),
-            array( 29,   70, 7, array(  15,   26,   36,   44)),
-            array( 33,  100, 7, array(  20,   36,   52,   64)),
-            array( 37,  134, 7, array(  26,   48,   72,   88)), // 5
-            array( 41,  172, 7, array(  36,   64,   96,  112)),
-            array( 45,  196, 0, array(  40,   72,  108,  130)),
-            array( 49,  242, 0, array(  48,   88,  132,  156)),
-            array( 53,  292, 0, array(  60,  110,  160,  192)),
-            array( 57,  346, 0, array(  72,  130,  192,  224)), //10
-            array( 61,  404, 0, array(  80,  150,  224,  264)),
-            array( 65,  466, 0, array(  96,  176,  260,  308)),
-            array( 69,  532, 0, array( 104,  198,  288,  352)),
-            array( 73,  581, 3, array( 120,  216,  320,  384)),
-            array( 77,  655, 3, array( 132,  240,  360,  432)), //15
-            array( 81,  733, 3, array( 144,  280,  408,  480)),
-            array( 85,  815, 3, array( 168,  308,  448,  532)),
-            array( 89,  901, 3, array( 180,  338,  504,  588)),
-            array( 93,  991, 3, array( 196,  364,  546,  650)),
-            array( 97, 1085, 3, array( 224,  416,  600,  700)), //20
-            array(101, 1156, 4, array( 224,  442,  644,  750)),
-            array(105, 1258, 4, array( 252,  476,  690,  816)),
-            array(109, 1364, 4, array( 270,  504,  750,  900)),
-            array(113, 1474, 4, array( 300,  560,  810,  960)),
-            array(117, 1588, 4, array( 312,  588,  870, 1050)), //25
-            array(121, 1706, 4, array( 336,  644,  952, 1110)),
-            array(125, 1828, 4, array( 360,  700, 1020, 1200)),
-            array(129, 1921, 3, array( 390,  728, 1050, 1260)),
-            array(133, 2051, 3, array( 420,  784, 1140, 1350)),
-            array(137, 2185, 3, array( 450,  812, 1200, 1440)), //30
-            array(141, 2323, 3, array( 480,  868, 1290, 1530)),
-            array(145, 2465, 3, array( 510,  924, 1350, 1620)),
-            array(149, 2611, 3, array( 540,  980, 1440, 1710)),
-            array(153, 2761, 3, array( 570, 1036, 1530, 1800)),
-            array(157, 2876, 0, array( 570, 1064, 1590, 1890)), //35
-            array(161, 3034, 0, array( 600, 1120, 1680, 1980)),
-            array(165, 3196, 0, array( 630, 1204, 1770, 2100)),
-            array(169, 3362, 0, array( 660, 1260, 1860, 2220)),
-            array(173, 3532, 0, array( 720, 1316, 1950, 2310)),
-            array(177, 3706, 0, array( 750, 1372, 2040, 2430)) //40
-        );
-        
-        //----------------------------------------------------------------------
-        public static function getDataLength($version, $level)
-        {
-            return self::$capacity[$version][QRCAP_WORDS] - self::$capacity[$version][QRCAP_EC][$level];
-        }
-        
-        //----------------------------------------------------------------------
-        public static function getECCLength($version, $level)
-        {
-            return self::$capacity[$version][QRCAP_EC][$level];
-        }
-        
-        //----------------------------------------------------------------------
-        public static function getWidth($version)
-        {
-            return self::$capacity[$version][QRCAP_WIDTH];
-        }
-        
-        //----------------------------------------------------------------------
-        public static function getRemainder($version)
-        {
-            return self::$capacity[$version][QRCAP_REMINDER];
-        }
-        
-        //----------------------------------------------------------------------
-        public static function getMinimumVersion($size, $level)
-        {
-
-            for($i=1; $i<= QRSPEC_VERSION_MAX; $i++) {
-                $words  = self::$capacity[$i][QRCAP_WORDS] - self::$capacity[$i][QRCAP_EC][$level];
-                if($words >= $size) 
-                    return $i;
-            }
-
-            return -1;
-        }
-    
-        //######################################################################
-        
-        public static $lengthTableBits = array(
-            array(10, 12, 14),
-            array( 9, 11, 13),
-            array( 8, 16, 16),
-            array( 8, 10, 12)
-        );
-        
-        //----------------------------------------------------------------------
-        public static function lengthIndicator($mode, $version)
-        {
-            if ($mode == QR_MODE_STRUCTURE)
-                return 0;
-                
-            if ($version <= 9) {
-                $l = 0;
-            } else if ($version <= 26) {
-                $l = 1;
-            } else {
-                $l = 2;
-            }
-
-            return self::$lengthTableBits[$mode][$l];
-        }
-        
-        //----------------------------------------------------------------------
-        public static function maximumWords($mode, $version)
-        {
-            if($mode == QR_MODE_STRUCTURE) 
-                return 3;
-                
-            if($version <= 9) {
-                $l = 0;
-            } else if($version <= 26) {
-                $l = 1;
-            } else {
-                $l = 2;
-            }
-
-            $bits = self::$lengthTableBits[$mode][$l];
-            $words = (1 << $bits) - 1;
-            
-            if($mode == QR_MODE_KANJI) {
-                $words *= 2; // the number of bytes is required
-            }
-
-            return $words;
-        }
-
-        // Error correction code -----------------------------------------------
-        // Table of the error correction code (Reed-Solomon block)
-        // See Table 12-16 (pp.30-36), JIS X0510:2004.
-
-        public static $eccTable = array(
-            array(array( 0,  0), array( 0,  0), array( 0,  0), array( 0,  0)),
-            array(array( 1,  0), array( 1,  0), array( 1,  0), array( 1,  0)), // 1
-            array(array( 1,  0), array( 1,  0), array( 1,  0), array( 1,  0)),
-            array(array( 1,  0), array( 1,  0), array( 2,  0), array( 2,  0)),
-            array(array( 1,  0), array( 2,  0), array( 2,  0), array( 4,  0)),
-            array(array( 1,  0), array( 2,  0), array( 2,  2), array( 2,  2)), // 5
-            array(array( 2,  0), array( 4,  0), array( 4,  0), array( 4,  0)),
-            array(array( 2,  0), array( 4,  0), array( 2,  4), array( 4,  1)),
-            array(array( 2,  0), array( 2,  2), array( 4,  2), array( 4,  2)),
-            array(array( 2,  0), array( 3,  2), array( 4,  4), array( 4,  4)),
-            array(array( 2,  2), array( 4,  1), array( 6,  2), array( 6,  2)), //10
-            array(array( 4,  0), array( 1,  4), array( 4,  4), array( 3,  8)),
-            array(array( 2,  2), array( 6,  2), array( 4,  6), array( 7,  4)),
-            array(array( 4,  0), array( 8,  1), array( 8,  4), array(12,  4)),
-            array(array( 3,  1), array( 4,  5), array(11,  5), array(11,  5)),
-            array(array( 5,  1), array( 5,  5), array( 5,  7), array(11,  7)), //15
-            array(array( 5,  1), array( 7,  3), array(15,  2), array( 3, 13)),
-            array(array( 1,  5), array(10,  1), array( 1, 15), array( 2, 17)),
-            array(array( 5,  1), array( 9,  4), array(17,  1), array( 2, 19)),
-            array(array( 3,  4), array( 3, 11), array(17,  4), array( 9, 16)),
-            array(array( 3,  5), array( 3, 13), array(15,  5), array(15, 10)), //20
-            array(array( 4,  4), array(17,  0), array(17,  6), array(19,  6)),
-            array(array( 2,  7), array(17,  0), array( 7, 16), array(34,  0)),
-            array(array( 4,  5), array( 4, 14), array(11, 14), array(16, 14)),
-            array(array( 6,  4), array( 6, 14), array(11, 16), array(30,  2)),
-            array(array( 8,  4), array( 8, 13), array( 7, 22), array(22, 13)), //25
-            array(array(10,  2), array(19,  4), array(28,  6), array(33,  4)),
-            array(array( 8,  4), array(22,  3), array( 8, 26), array(12, 28)),
-            array(array( 3, 10), array( 3, 23), array( 4, 31), array(11, 31)),
-            array(array( 7,  7), array(21,  7), array( 1, 37), array(19, 26)),
-            array(array( 5, 10), array(19, 10), array(15, 25), array(23, 25)), //30
-            array(array(13,  3), array( 2, 29), array(42,  1), array(23, 28)),
-            array(array(17,  0), array(10, 23), array(10, 35), array(19, 35)),
-            array(array(17,  1), array(14, 21), array(29, 19), array(11, 46)),
-            array(array(13,  6), array(14, 23), array(44,  7), array(59,  1)),
-            array(array(12,  7), array(12, 26), array(39, 14), array(22, 41)), //35
-            array(array( 6, 14), array( 6, 34), array(46, 10), array( 2, 64)),
-            array(array(17,  4), array(29, 14), array(49, 10), array(24, 46)),
-            array(array( 4, 18), array(13, 32), array(48, 14), array(42, 32)),
-            array(array(20,  4), array(40,  7), array(43, 22), array(10, 67)),
-            array(array(19,  6), array(18, 31), array(34, 34), array(20, 61)),//40
-        );                                                                       
-
-        //----------------------------------------------------------------------
-        // CACHEABLE!!!
-        
-        public static function getEccSpec($version, $level, array &$spec)
-        {
-            if (count($spec) < 5) {
-                $spec = array(0,0,0,0,0);
-            }
-
-            $b1   = self::$eccTable[$version][$level][0];
-            $b2   = self::$eccTable[$version][$level][1];
-            $data = self::getDataLength($version, $level);
-            $ecc  = self::getECCLength($version, $level);
-
-            if($b2 == 0) {
-                $spec[0] = $b1;
-                $spec[1] = (int)($data / $b1);
-                $spec[2] = (int)($ecc / $b1);
-                $spec[3] = 0; 
-                $spec[4] = 0;
-            } else {
-                $spec[0] = $b1;
-                $spec[1] = (int)($data / ($b1 + $b2));
-                $spec[2] = (int)($ecc  / ($b1 + $b2));
-                $spec[3] = $b2;
-                $spec[4] = $spec[1] + 1;
-            }
-        }
-
-        // Alignment pattern ---------------------------------------------------
-
-        // Positions of alignment patterns.
-        // This array includes only the second and the third position of the 
-        // alignment patterns. Rest of them can be calculated from the distance 
-        // between them.
-         
-        // See Table 1 in Appendix E (pp.71) of JIS X0510:2004.
-         
-        public static $alignmentPattern = array(      
-            array( 0,  0),
-            array( 0,  0), array(18,  0), array(22,  0), array(26,  0), array(30,  0), // 1- 5
-            array(34,  0), array(22, 38), array(24, 42), array(26, 46), array(28, 50), // 6-10
-            array(30, 54), array(32, 58), array(34, 62), array(26, 46), array(26, 48), //11-15
-            array(26, 50), array(30, 54), array(30, 56), array(30, 58), array(34, 62), //16-20
-            array(28, 50), array(26, 50), array(30, 54), array(28, 54), array(32, 58), //21-25
-            array(30, 58), array(34, 62), array(26, 50), array(30, 54), array(26, 52), //26-30
-            array(30, 56), array(34, 60), array(30, 58), array(34, 62), array(30, 54), //31-35
-            array(24, 50), array(28, 54), array(32, 58), array(26, 54), array(30, 58), //35-40
-        );                                                                                  
-
-        
-        /** --------------------------------------------------------------------
-         * Put an alignment marker.
-         * @param frame
-         * @param width
-         * @param ox,oy center coordinate of the pattern
-         */
-        public static function putAlignmentMarker(array &$frame, $ox, $oy)
-        {
-            $finder = array(
-                "\xa1\xa1\xa1\xa1\xa1",
-                "\xa1\xa0\xa0\xa0\xa1",
-                "\xa1\xa0\xa1\xa0\xa1",
-                "\xa1\xa0\xa0\xa0\xa1",
-                "\xa1\xa1\xa1\xa1\xa1"
-            );                        
-            
-            $yStart = $oy-2;         
-            $xStart = $ox-2;
-            
-            for($y=0; $y<5; $y++) {
-                QRstr::set($frame, $xStart, $yStart+$y, $finder[$y]);
-            }
-        }
-
-        //----------------------------------------------------------------------
-        public static function putAlignmentPattern($version, &$frame, $width)
-        {
-            if($version < 2)
-                return;
-
-            $d = self::$alignmentPattern[$version][1] - self::$alignmentPattern[$version][0];
-            if($d < 0) {
-                $w = 2;
-            } else {
-                $w = (int)(($width - self::$alignmentPattern[$version][0]) / $d + 2);
-            }
-
-            if($w * $w - 3 == 1) {
-                $x = self::$alignmentPattern[$version][0];
-                $y = self::$alignmentPattern[$version][0];
-                self::putAlignmentMarker($frame, $x, $y);
-                return;
-            }
-
-            $cx = self::$alignmentPattern[$version][0];
-            for($x=1; $x<$w - 1; $x++) {
-                self::putAlignmentMarker($frame, 6, $cx);
-                self::putAlignmentMarker($frame, $cx,  6);
-                $cx += $d;
-            }
-
-            $cy = self::$alignmentPattern[$version][0];
-            for($y=0; $y<$w-1; $y++) {
-                $cx = self::$alignmentPattern[$version][0];
-                for($x=0; $x<$w-1; $x++) {
-                    self::putAlignmentMarker($frame, $cx, $cy);
-                    $cx += $d;
-                }
-                $cy += $d;
-            }
-        }
-
-        // Version information pattern -----------------------------------------
-
-		// Version information pattern (BCH coded).
-        // See Table 1 in Appendix D (pp.68) of JIS X0510:2004.
-        
-		// size: [QRSPEC_VERSION_MAX - 6]
-		
-        public static $versionPattern = array(
-            0x07c94, 0x085bc, 0x09a99, 0x0a4d3, 0x0bbf6, 0x0c762, 0x0d847, 0x0e60d,
-            0x0f928, 0x10b78, 0x1145d, 0x12a17, 0x13532, 0x149a6, 0x15683, 0x168c9,
-            0x177ec, 0x18ec4, 0x191e1, 0x1afab, 0x1b08e, 0x1cc1a, 0x1d33f, 0x1ed75,
-            0x1f250, 0x209d5, 0x216f0, 0x228ba, 0x2379f, 0x24b0b, 0x2542e, 0x26a64,
-            0x27541, 0x28c69
-        );
-
-        //----------------------------------------------------------------------
-        public static function getVersionPattern($version)
-        {
-            if($version < 7 || $version > QRSPEC_VERSION_MAX)
-                return 0;
-
-            return self::$versionPattern[$version -7];
-        }
-
-        // Format information --------------------------------------------------
-        // See calcFormatInfo in tests/test_qrspec.c (orginal qrencode c lib)
-        
-        public static $formatInfo = array(
-            array(0x77c4, 0x72f3, 0x7daa, 0x789d, 0x662f, 0x6318, 0x6c41, 0x6976),
-            array(0x5412, 0x5125, 0x5e7c, 0x5b4b, 0x45f9, 0x40ce, 0x4f97, 0x4aa0),
-            array(0x355f, 0x3068, 0x3f31, 0x3a06, 0x24b4, 0x2183, 0x2eda, 0x2bed),
-            array(0x1689, 0x13be, 0x1ce7, 0x19d0, 0x0762, 0x0255, 0x0d0c, 0x083b)
-        );
-
-        public static function getFormatInfo($mask, $level)
-        {
-            if($mask < 0 || $mask > 7)
-                return 0;
-                
-            if($level < 0 || $level > 3)
-                return 0;                
-
-            return self::$formatInfo[$level][$mask];
-        }
-
-        // Frame ---------------------------------------------------------------
-        // Cache of initial frames.
-         
-        public static $frames = array();
-
-        /** --------------------------------------------------------------------
-         * Put a finder pattern.
-         * @param frame
-         * @param width
-         * @param ox,oy upper-left coordinate of the pattern
-         */
-        public static function putFinderPattern(&$frame, $ox, $oy)
-        {
-            $finder = array(
-                "\xc1\xc1\xc1\xc1\xc1\xc1\xc1",
-                "\xc1\xc0\xc0\xc0\xc0\xc0\xc1",
-                "\xc1\xc0\xc1\xc1\xc1\xc0\xc1",
-                "\xc1\xc0\xc1\xc1\xc1\xc0\xc1",
-                "\xc1\xc0\xc1\xc1\xc1\xc0\xc1",
-                "\xc1\xc0\xc0\xc0\xc0\xc0\xc1",
-                "\xc1\xc1\xc1\xc1\xc1\xc1\xc1"
-            );                            
-            
-            for($y=0; $y<7; $y++) {
-                QRstr::set($frame, $ox, $oy+$y, $finder[$y]);
-            }
-        }
-
-        //----------------------------------------------------------------------
-        public static function createFrame($version)
-        {
-            $width = self::$capacity[$version][QRCAP_WIDTH];
-            $frameLine = str_repeat ("\0", $width);
-            $frame = array_fill(0, $width, $frameLine);
-
-            // Finder pattern
-            self::putFinderPattern($frame, 0, 0);
-            self::putFinderPattern($frame, $width - 7, 0);
-            self::putFinderPattern($frame, 0, $width - 7);
-            
-            // Separator
-            $yOffset = $width - 7;
-            
-            for($y=0; $y<7; $y++) {
-                $frame[$y][7] = "\xc0";
-                $frame[$y][$width - 8] = "\xc0";
-                $frame[$yOffset][7] = "\xc0";
-                $yOffset++;
-            }
-            
-            $setPattern = str_repeat("\xc0", 8);
-            
-            QRstr::set($frame, 0, 7, $setPattern);
-            QRstr::set($frame, $width-8, 7, $setPattern);
-            QRstr::set($frame, 0, $width - 8, $setPattern);
-        
-            // Format info
-            $setPattern = str_repeat("\x84", 9);
-            QRstr::set($frame, 0, 8, $setPattern);
-            QRstr::set($frame, $width - 8, 8, $setPattern, 8);
-            
-            $yOffset = $width - 8;
-
-            for($y=0; $y<8; $y++,$yOffset++) {
-                $frame[$y][8] = "\x84";
-                $frame[$yOffset][8] = "\x84";
-            }
-
-            // Timing pattern  
-            
-            for($i=1; $i<$width-15; $i++) {
-                $frame[6][7+$i] = chr(0x90 | ($i & 1));
-                $frame[7+$i][6] = chr(0x90 | ($i & 1));
-            }
-            
-            // Alignment pattern  
-            self::putAlignmentPattern($version, $frame, $width);
-            
-            // Version information 
-            if($version >= 7) {
-                $vinf = self::getVersionPattern($version);
-
-                $v = $vinf;
-                
-                for($x=0; $x<6; $x++) {
-                    for($y=0; $y<3; $y++) {
-                        $frame[($width - 11)+$y][$x] = chr(0x88 | ($v & 1));
-                        $v = $v >> 1;
-                    }
-                }
-
-                $v = $vinf;
-                for($y=0; $y<6; $y++) {
-                    for($x=0; $x<3; $x++) {
-                        $frame[$y][$x+($width - 11)] = chr(0x88 | ($v & 1));
-                        $v = $v >> 1;
-                    }
-                }
-            }
-    
-            // and a little bit...  
-            $frame[$width - 8][8] = "\x81";
-            
-            return $frame;
-        }
-
-        //----------------------------------------------------------------------
-        public static function debug($frame, $binary_mode = false)
-        {
-            if ($binary_mode) {
-            
-                    foreach ($frame as &$frameLine) {
-                        $frameLine = join('<span class="m">&nbsp;&nbsp;</span>', explode('0', $frameLine));
-                        $frameLine = join('&#9608;&#9608;', explode('1', $frameLine));
-                    }
-                    
-                    ?>
-                <style>
-                    .m { background-color: white; }
-                </style>
-                <?php
-                    echo '<pre><tt><br/ ><br/ ><br/ >&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;';
-                    echo join("<br/ >&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;", $frame);
-                    echo '</tt></pre><br/ ><br/ ><br/ ><br/ ><br/ ><br/ >';
-            
-            } else {
-            
-                foreach ($frame as &$frameLine) {
-                    $frameLine = join('<span class="m">&nbsp;</span>',  explode("\xc0", $frameLine));
-                    $frameLine = join('<span class="m">&#9618;</span>', explode("\xc1", $frameLine));
-                    $frameLine = join('<span class="p">&nbsp;</span>',  explode("\xa0", $frameLine));
-                    $frameLine = join('<span class="p">&#9618;</span>', explode("\xa1", $frameLine));
-                    $frameLine = join('<span class="s">&#9671;</span>', explode("\x84", $frameLine)); //format 0
-                    $frameLine = join('<span class="s">&#9670;</span>', explode("\x85", $frameLine)); //format 1
-                    $frameLine = join('<span class="x">&#9762;</span>', explode("\x81", $frameLine)); //special bit
-                    $frameLine = join('<span class="c">&nbsp;</span>',  explode("\x90", $frameLine)); //clock 0
-                    $frameLine = join('<span class="c">&#9719;</span>', explode("\x91", $frameLine)); //clock 1
-                    $frameLine = join('<span class="f">&nbsp;</span>',  explode("\x88", $frameLine)); //version
-                    $frameLine = join('<span class="f">&#9618;</span>', explode("\x89", $frameLine)); //version
-                    $frameLine = join('&#9830;', explode("\x01", $frameLine));
-                    $frameLine = join('&#8901;', explode("\0", $frameLine));
-                }
-                
-                ?>
-                <style>
-                    .p { background-color: yellow; }
-                    .m { background-color: #00FF00; }
-                    .s { background-color: #FF0000; }
-                    .c { background-color: aqua; }
-                    .x { background-color: pink; }
-                    .f { background-color: gold; }
-                </style>
-                <?php
-                echo "<pre><tt>";
-                echo join("<br/ >", $frame);
-                echo "</tt></pre>";
-            
-            }
-        }
-
-        //----------------------------------------------------------------------
-        public static function serial($frame)
-        {
-            return gzcompress(join("\n", $frame), 9);
-        }
-        
-        //----------------------------------------------------------------------
-        public static function unserial($code)
-        {
-            return explode("\n", gzuncompress($code));
-        }
-        
-        //----------------------------------------------------------------------
-        public static function newFrame($version)
-        {
-            if($version < 1 || $version > QRSPEC_VERSION_MAX) 
-                return null;
-
-            if(!isset(self::$frames[$version])) {
-                
-                $fileName = QR_CACHE_DIR.'frame_'.$version.'.dat';
-                
-                if (QR_CACHEABLE) {
-                    if (file_exists($fileName)) {
-                        self::$frames[$version] = self::unserial(file_get_contents($fileName));
-                    } else {
-                        self::$frames[$version] = self::createFrame($version);
-                        file_put_contents($fileName, self::serial(self::$frames[$version]));
-                    }
-                } else {
-                    self::$frames[$version] = self::createFrame($version);
-                }
-            }
-            
-            if(is_null(self::$frames[$version]))
-                return null;
-
-            return self::$frames[$version];
-        }
-
-        //----------------------------------------------------------------------
-        public static function rsBlockNum($spec)     { return $spec[0] + $spec[3]; }
-        public static function rsBlockNum1($spec)    { return $spec[0]; }
-        public static function rsDataCodes1($spec)   { return $spec[1]; }
-        public static function rsEccCodes1($spec)    { return $spec[2]; }
-        public static function rsBlockNum2($spec)    { return $spec[3]; }
-        public static function rsDataCodes2($spec)   { return $spec[4]; }
-        public static function rsEccCodes2($spec)    { return $spec[2]; }
-        public static function rsDataLength($spec)   { return ($spec[0] * $spec[1]) + ($spec[3] * $spec[4]);    }
-        public static function rsEccLength($spec)    { return ($spec[0] + $spec[3]) * $spec[2]; }
-        
-    }
-
-
-
-//---- qrimage.php -----------------------------
-
-
-
-
-/*
- * PHP QR Code encoder
- *
- * Image output of code using GD2
- *
- * PHP QR Code is distributed under LGPL 3
- * Copyright (C) 2010 Dominik Dzienia <deltalab at poczta dot fm>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
- */
- 
-    define('QR_IMAGE', true);
-
-    class QRimage {
-    
-        //----------------------------------------------------------------------
-        public static function png($frame, $filename = false, $pixelPerPoint = 4, $outerFrame = 4,$saveandprint=FALSE) 
-        {
-            $image = self::image($frame, $pixelPerPoint, $outerFrame);
-            
-            if ($filename === false) {
-                Header("Content-type: image/png");
-                ImagePng($image);
-            } else {
-                if($saveandprint===TRUE){
-                    ImagePng($image, $filename);
-                    header("Content-type: image/png");
-                    ImagePng($image);
-                }else{
-                    ImagePng($image, $filename);
-                }
-            }
-            
-            ImageDestroy($image);
-        }
-    
-        //----------------------------------------------------------------------
-        public static function jpg($frame, $filename = false, $pixelPerPoint = 8, $outerFrame = 4, $q = 85) 
-        {
-            $image = self::image($frame, $pixelPerPoint, $outerFrame);
-            
-            if ($filename === false) {
-                Header("Content-type: image/jpeg");
-                ImageJpeg($image, null, $q);
-            } else {
-                ImageJpeg($image, $filename, $q);            
-            }
-            
-            ImageDestroy($image);
-        }
-    
-        //----------------------------------------------------------------------
-        private static function image($frame, $pixelPerPoint = 4, $outerFrame = 4) 
-        {
-            $h = count($frame);
-            $w = strlen($frame[0]);
-            
-            $imgW = $w + 2*$outerFrame;
-            $imgH = $h + 2*$outerFrame;
-            
-            $base_image =ImageCreate($imgW, $imgH);
-            
-            $col[0] = ImageColorAllocate($base_image,255,255,255);
-            $col[1] = ImageColorAllocate($base_image,0,0,0);
-
-            imagefill($base_image, 0, 0, $col[0]);
-
-            for($y=0; $y<$h; $y++) {
-                for($x=0; $x<$w; $x++) {
-                    if ($frame[$y][$x] == '1') {
-                        ImageSetPixel($base_image,$x+$outerFrame,$y+$outerFrame,$col[1]); 
-                    }
-                }
-            }
-            
-            $target_image =ImageCreate($imgW * $pixelPerPoint, $imgH * $pixelPerPoint);
-            ImageCopyResized($target_image, $base_image, 0, 0, 0, 0, $imgW * $pixelPerPoint, $imgH * $pixelPerPoint, $imgW, $imgH);
-            ImageDestroy($base_image);
-            
-            return $target_image;
-        }
-    }
-
-
-
-//---- qrinput.php -----------------------------
-
-
-
-
-/*
- * PHP QR Code encoder
- *
- * Input encoding class
- *
- * Based on libqrencode C library distributed under LGPL 2.1
- * Copyright (C) 2006, 2007, 2008, 2009 Kentaro Fukuchi <fukuchi@megaui.net>
- *
- * PHP QR Code is distributed under LGPL 3
- * Copyright (C) 2010 Dominik Dzienia <deltalab at poczta dot fm>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
- */
- 
-    define('STRUCTURE_HEADER_BITS',  20);
-    define('MAX_STRUCTURED_SYMBOLS', 16);
-
-    class QRinputItem {
-    
-        public $mode;
-        public $size;
-        public $data;
-        public $bstream;
-
-        public function __construct($mode, $size, $data, $bstream = null) 
-        {
-            $setData = array_slice($data, 0, $size);
-            
-            if (count($setData) < $size) {
-                $setData = array_merge($setData, array_fill(0,$size-count($setData),0));
-            }
-        
-            if(!QRinput::check($mode, $size, $setData)) {
-                throw new Exception('Error m:'.$mode.',s:'.$size.',d:'.join(',',$setData));
-                return null;
-            }
-            
-            $this->mode = $mode;
-            $this->size = $size;
-            $this->data = $setData;
-            $this->bstream = $bstream;
-        }
-        
-        //----------------------------------------------------------------------
-        public function encodeModeNum($version)
-        {
-            try {
-            
-                $words = (int)($this->size / 3);
-                $bs = new QRbitstream();
-                
-                $val = 0x1;
-                $bs->appendNum(4, $val);
-                $bs->appendNum(QRspec::lengthIndicator(QR_MODE_NUM, $version), $this->size);
-
-                for($i=0; $i<$words; $i++) {
-                    $val  = (ord($this->data[$i*3  ]) - ord('0')) * 100;
-                    $val += (ord($this->data[$i*3+1]) - ord('0')) * 10;
-                    $val += (ord($this->data[$i*3+2]) - ord('0'));
-                    $bs->appendNum(10, $val);
-                }
-
-                if($this->size - $words * 3 == 1) {
-                    $val = ord($this->data[$words*3]) - ord('0');
-                    $bs->appendNum(4, $val);
-                } else if($this->size - $words * 3 == 2) {
-                    $val  = (ord($this->data[$words*3  ]) - ord('0')) * 10;
-                    $val += (ord($this->data[$words*3+1]) - ord('0'));
-                    $bs->appendNum(7, $val);
-                }
-
-                $this->bstream = $bs;
-                return 0;
-                
-            } catch (Exception $e) {
-                return -1;
-            }
-        }
-        
-        //----------------------------------------------------------------------
-        public function encodeModeAn($version)
-        {
-            try {
-                $words = (int)($this->size / 2);
-                $bs = new QRbitstream();
-                
-                $bs->appendNum(4, 0x02);
-                $bs->appendNum(QRspec::lengthIndicator(QR_MODE_AN, $version), $this->size);
-
-                for($i=0; $i<$words; $i++) {
-                    $val  = (int)QRinput::lookAnTable(ord($this->data[$i*2  ])) * 45;
-                    $val += (int)QRinput::lookAnTable(ord($this->data[$i*2+1]));
-
-                    $bs->appendNum(11, $val);
-                }
-
-                if($this->size & 1) {
-                    $val = QRinput::lookAnTable(ord($this->data[$words * 2]));
-                    $bs->appendNum(6, $val);
-                }
-        
-                $this->bstream = $bs;
-                return 0;
-            
-            } catch (Exception $e) {
-                return -1;
-            }
-        }
-        
-        //----------------------------------------------------------------------
-        public function encodeMode8($version)
-        {
-            try {
-                $bs = new QRbitstream();
-
-                $bs->appendNum(4, 0x4);
-                $bs->appendNum(QRspec::lengthIndicator(QR_MODE_8, $version), $this->size);
-
-                for($i=0; $i<$this->size; $i++) {
-                    $bs->appendNum(8, ord($this->data[$i]));
-                }
-
-                $this->bstream = $bs;
-                return 0;
-            
-            } catch (Exception $e) {
-                return -1;
-            }
-        }
-        
-        //----------------------------------------------------------------------
-        public function encodeModeKanji($version)
-        {
-            try {
-
-                $bs = new QRbitrtream();
-                
-                $bs->appendNum(4, 0x8);
-                $bs->appendNum(QRspec::lengthIndicator(QR_MODE_KANJI, $version), (int)($this->size / 2));
-
-                for($i=0; $i<$this->size; $i+=2) {
-                    $val = (ord($this->data[$i]) << 8) | ord($this->data[$i+1]);
-                    if($val <= 0x9ffc) {
-                        $val -= 0x8140;
-                    } else {
-                        $val -= 0xc140;
-                    }
-                    
-                    $h = ($val >> 8) * 0xc0;
-                    $val = ($val & 0xff) + $h;
-
-                    $bs->appendNum(13, $val);
-                }
-
-                $this->bstream = $bs;
-                return 0;
-            
-            } catch (Exception $e) {
-                return -1;
-            }
-        }
-
-        //----------------------------------------------------------------------
-        public function encodeModeStructure()
-        {
-            try {
-                $bs =  new QRbitstream();
-                
-                $bs->appendNum(4, 0x03);
-                $bs->appendNum(4, ord($this->data[1]) - 1);
-                $bs->appendNum(4, ord($this->data[0]) - 1);
-                $bs->appendNum(8, ord($this->data[2]));
-
-                $this->bstream = $bs;
-                return 0;
-            
-            } catch (Exception $e) {
-                return -1;
-            }
-        }
-        
-        //----------------------------------------------------------------------
-        public function estimateBitStreamSizeOfEntry($version)
-        {
-            $bits = 0;
-
-            if($version == 0) 
-                $version = 1;
-
-            switch($this->mode) {
-                case QR_MODE_NUM:        $bits = QRinput::estimateBitsModeNum($this->size);    break;
-                case QR_MODE_AN:        $bits = QRinput::estimateBitsModeAn($this->size);    break;
-                case QR_MODE_8:            $bits = QRinput::estimateBitsMode8($this->size);    break;
-                case QR_MODE_KANJI:        $bits = QRinput::estimateBitsModeKanji($this->size);break;
-                case QR_MODE_STRUCTURE:    return STRUCTURE_HEADER_BITS;            
-                default:
-                    return 0;
-            }
-
-            $l = QRspec::lengthIndicator($this->mode, $version);
-            $m = 1 << $l;
-            $num = (int)(($this->size + $m - 1) / $m);
-
-            $bits += $num * (4 + $l);
-
-            return $bits;
-        }
-        
-        //----------------------------------------------------------------------
-        public function encodeBitStream($version)
-        {
-            try {
-            
-                unset($this->bstream);
-                $words = QRspec::maximumWords($this->mode, $version);
-                
-                if($this->size > $words) {
-                
-                    $st1 = new QRinputItem($this->mode, $words, $this->data);
-                    $st2 = new QRinputItem($this->mode, $this->size - $words, array_slice($this->data, $words));
-
-                    $st1->encodeBitStream($version);
-                    $st2->encodeBitStream($version);
-                    
-                    $this->bstream = new QRbitstream();
-                    $this->bstream->append($st1->bstream);
-                    $this->bstream->append($st2->bstream);
-                    
-                    unset($st1);
-                    unset($st2);
-                    
-                } else {
-                    
-                    $ret = 0;
-                    
-                    switch($this->mode) {
-                        case QR_MODE_NUM:        $ret = $this->encodeModeNum($version);    break;
-                        case QR_MODE_AN:        $ret = $this->encodeModeAn($version);    break;
-                        case QR_MODE_8:            $ret = $this->encodeMode8($version);    break;
-                        case QR_MODE_KANJI:        $ret = $this->encodeModeKanji($version);break;
-                        case QR_MODE_STRUCTURE:    $ret = $this->encodeModeStructure();    break;
-                        
-                        default:
-                            break;
-                    }
-                    
-                    if($ret < 0)
-                        return -1;
-                }
-
-                return $this->bstream->size();
-            
-            } catch (Exception $e) {
-                return -1;
-            }
-        }
-    };
-    
-    //##########################################################################
-
-    class QRinput {
-
-        public $items;
-        
-        private $version;
-        private $level;
-        
-        //----------------------------------------------------------------------
-        public function __construct($version = 0, $level = QR_ECLEVEL_L)
-        {
-            if ($version < 0 || $version > QRSPEC_VERSION_MAX || $level > QR_ECLEVEL_H) {
-                throw new Exception('Invalid version no');
-                return NULL;
-            }
-            
-            $this->version = $version;
-            $this->level = $level;
-        }
-        
-        //----------------------------------------------------------------------
-        public function getVersion()
-        {
-            return $this->version;
-        }
-        
-        //----------------------------------------------------------------------
-        public function setVersion($version)
-        {
-            if($version < 0 || $version > QRSPEC_VERSION_MAX) {
-                throw new Exception('Invalid version no');
-                return -1;
-            }
-
-            $this->version = $version;
-
-            return 0;
-        }
-        
-        //----------------------------------------------------------------------
-        public function getErrorCorrectionLevel()
-        {
-            return $this->level;
-        }
-
-        //----------------------------------------------------------------------
-        public function setErrorCorrectionLevel($level)
-        {
-            if($level > QR_ECLEVEL_H) {
-                throw new Exception('Invalid ECLEVEL');
-                return -1;
-            }
-
-            $this->level = $level;
-
-            return 0;
-        }
-        
-        //----------------------------------------------------------------------
-        public function appendEntry(QRinputItem $entry)
-        {
-            $this->items[] = $entry;
-        }
-        
-        //----------------------------------------------------------------------
-        public function append($mode, $size, $data)
-        {
-            try {
-                $entry = new QRinputItem($mode, $size, $data);
-                $this->items[] = $entry;
-                return 0;
-            } catch (Exception $e) {
-                return -1;
-            }
-        }
-        
-        //----------------------------------------------------------------------
-        
-        public function insertStructuredAppendHeader($size, $index, $parity)
-        {
-            if( $size > MAX_STRUCTURED_SYMBOLS ) {
-                throw new Exception('insertStructuredAppendHeader wrong size');
-            }
-            
-            if( $index <= 0 || $index > MAX_STRUCTURED_SYMBOLS ) {
-                throw new Exception('insertStructuredAppendHeader wrong index');
-            }
-
-            $buf = array($size, $index, $parity);
-            
-            try {
-                $entry = new QRinputItem(QR_MODE_STRUCTURE, 3, buf);
-                array_unshift($this->items, $entry);
-                return 0;
-            } catch (Exception $e) {
-                return -1;
-            }
-        }
-
-        //----------------------------------------------------------------------
-        public function calcParity()
-        {
-            $parity = 0;
-            
-            foreach($this->items as $item) {
-                if($item->mode != QR_MODE_STRUCTURE) {
-                    for($i=$item->size-1; $i>=0; $i--) {
-                        $parity ^= $item->data[$i];
-                    }
-                }
-            }
-
-            return $parity;
-        }
-        
-        //----------------------------------------------------------------------
-        public static function checkModeNum($size, $data)
-        {
-            for($i=0; $i<$size; $i++) {
-                if((ord($data[$i]) < ord('0')) || (ord($data[$i]) > ord('9'))){
-                    return false;
-                }
-            }
-
-            return true;
-        }
-
-        //----------------------------------------------------------------------
-        public static function estimateBitsModeNum($size)
-        {
-            $w = (int)$size / 3;
-            $bits = $w * 10;
-            
-            switch($size - $w * 3) {
-                case 1:
-                    $bits += 4;
-                    break;
-                case 2:
-                    $bits += 7;
-                    break;
-                default:
-                    break;
-            }
-
-            return $bits;
-        }
-        
-        //----------------------------------------------------------------------
-        public static $anTable = array(
-            -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-            -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-            36, -1, -1, -1, 37, 38, -1, -1, -1, -1, 39, 40, -1, 41, 42, 43,
-             0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 44, -1, -1, -1, -1, -1,
-            -1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24,
-            25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, -1, -1, -1, -1, -1,
-            -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-            -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1
-        );
-        
-        //----------------------------------------------------------------------
-        public static function lookAnTable($c)
-        {
-            return (($c > 127)?-1:self::$anTable[$c]);
-        }
-        
-        //----------------------------------------------------------------------
-        public static function checkModeAn($size, $data)
-        {
-            for($i=0; $i<$size; $i++) {
-                if (self::lookAnTable(ord($data[$i])) == -1) {
-                    return false;
-                }
-            }
-
-            return true;
-        }
-        
-        //----------------------------------------------------------------------
-        public static function estimateBitsModeAn($size)
-        {
-            $w = (int)($size / 2);
-            $bits = $w * 11;
-            
-            if($size & 1) {
-                $bits += 6;
-            }
-
-            return $bits;
-        }
-    
-        //----------------------------------------------------------------------
-        public static function estimateBitsMode8($size)
-        {
-            return $size * 8;
-        }
-        
-        //----------------------------------------------------------------------
-        public function estimateBitsModeKanji($size)
-        {
-            return (int)(($size / 2) * 13);
-        }
-        
-        //----------------------------------------------------------------------
-        public static function checkModeKanji($size, $data)
-        {
-            if($size & 1)
-                return false;
-
-            for($i=0; $i<$size; $i+=2) {
-                $val = (ord($data[$i]) << 8) | ord($data[$i+1]);
-                if( $val < 0x8140 
-                || ($val > 0x9ffc && $val < 0xe040) 
-                || $val > 0xebbf) {
-                    return false;
-                }
-            }
-
-            return true;
-        }
-
-        /***********************************************************************
-         * Validation
-         **********************************************************************/
-
-        public static function check($mode, $size, $data)
-        {
-            if($size <= 0) 
-                return false;
-
-            switch($mode) {
-                case QR_MODE_NUM:       return self::checkModeNum($size, $data);   break;
-                case QR_MODE_AN:        return self::checkModeAn($size, $data);    break;
-                case QR_MODE_KANJI:     return self::checkModeKanji($size, $data); break;
-                case QR_MODE_8:         return true; break;
-                case QR_MODE_STRUCTURE: return true; break;
-                
-                default:
-                    break;
-            }
-
-            return false;
-        }
-        
-        
-        //----------------------------------------------------------------------
-        public function estimateBitStreamSize($version)
-        {
-            $bits = 0;
-
-            foreach($this->items as $item) {
-                $bits += $item->estimateBitStreamSizeOfEntry($version);
-            }
-
-            return $bits;
-        }
-        
-        //----------------------------------------------------------------------
-        public function estimateVersion()
-        {
-            $version = 0;
-            $prev = 0;
-            do {
-                $prev = $version;
-                $bits = $this->estimateBitStreamSize($prev);
-                $version = QRspec::getMinimumVersion((int)(($bits + 7) / 8), $this->level);
-                if ($version < 0) {
-                    return -1;
-                }
-            } while ($version > $prev);
-
-            return $version;
-        }
-        
-        //----------------------------------------------------------------------
-        public static function lengthOfCode($mode, $version, $bits)
-        {
-            $payload = $bits - 4 - QRspec::lengthIndicator($mode, $version);
-            switch($mode) {
-                case QR_MODE_NUM:
-                    $chunks = (int)($payload / 10);
-                    $remain = $payload - $chunks * 10;
-                    $size = $chunks * 3;
-                    if($remain >= 7) {
-                        $size += 2;
-                    } else if($remain >= 4) {
-                        $size += 1;
-                    }
-                    break;
-                case QR_MODE_AN:
-                    $chunks = (int)($payload / 11);
-                    $remain = $payload - $chunks * 11;
-                    $size = $chunks * 2;
-                    if($remain >= 6) 
-                        $size++;
-                    break;
-                case QR_MODE_8:
-                    $size = (int)($payload / 8);
-                    break;
-                case QR_MODE_KANJI:
-                    $size = (int)(($payload / 13) * 2);
-                    break;
-                case QR_MODE_STRUCTURE:
-                    $size = (int)($payload / 8);
-                    break;
-                default:
-                    $size = 0;
-                    break;
-            }
-            
-            $maxsize = QRspec::maximumWords($mode, $version);
-            if($size < 0) $size = 0;
-            if($size > $maxsize) $size = $maxsize;
-
-            return $size;
-        }
-        
-        //----------------------------------------------------------------------
-        public function createBitStream()
-        {
-            $total = 0;
-
-            foreach($this->items as $item) {
-                $bits = $item->encodeBitStream($this->version);
-                
-                if($bits < 0) 
-                    return -1;
-                    
-                $total += $bits;
-            }
-
-            return $total;
-        }
-        
-        //----------------------------------------------------------------------
-        public function convertData()
-        {
-            $ver = $this->estimateVersion();
-            if($ver > $this->getVersion()) {
-                $this->setVersion($ver);
-            }
-
-            for(;;) {
-                $bits = $this->createBitStream();
-                
-                if($bits < 0) 
-                    return -1;
-                    
-                $ver = QRspec::getMinimumVersion((int)(($bits + 7) / 8), $this->level);
-                if($ver < 0) {
-                    throw new Exception('WRONG VERSION');
-                    return -1;
-                } else if($ver > $this->getVersion()) {
-                    $this->setVersion($ver);
-                } else {
-                    break;
-                }
-            }
-
-            return 0;
-        }
-        
-        //----------------------------------------------------------------------
-        public function appendPaddingBit(&$bstream)
-        {
-            $bits = $bstream->size();
-            $maxwords = QRspec::getDataLength($this->version, $this->level);
-            $maxbits = $maxwords * 8;
-
-            if ($maxbits == $bits) {
-                return 0;
-            }
-
-            if ($maxbits - $bits < 5) {
-                return $bstream->appendNum($maxbits - $bits, 0);
-            }
-
-            $bits += 4;
-            $words = (int)(($bits + 7) / 8);
-
-            $padding = new QRbitstream();
-            $ret = $padding->appendNum($words * 8 - $bits + 4, 0);
-            
-            if($ret < 0) 
-                return $ret;
-
-            $padlen = $maxwords - $words;
-            
-            if($padlen > 0) {
-                
-                $padbuf = array();
-                for($i=0; $i<$padlen; $i++) {
-                    $padbuf[$i] = ($i&1)?0x11:0xec;
-                }
-                
-                $ret = $padding->appendBytes($padlen, $padbuf);
-                
-                if($ret < 0)
-                    return $ret;
-                
-            }
-
-            $ret = $bstream->append($padding);
-            
-            return $ret;
-        }
-
-        //----------------------------------------------------------------------
-        public function mergeBitStream()
-        {
-            if($this->convertData() < 0) {
-                return null;
-            }
-
-            $bstream = new QRbitstream();
-            
-            foreach($this->items as $item) {
-                $ret = $bstream->append($item->bstream);
-                if($ret < 0) {
-                    return null;
-                }
-            }
-
-            return $bstream;
-        }
-
-        //----------------------------------------------------------------------
-        public function getBitStream()
-        {
-
-            $bstream = $this->mergeBitStream();
-            
-            if($bstream == null) {
-                return null;
-            }
-            
-            $ret = $this->appendPaddingBit($bstream);
-            if($ret < 0) {
-                return null;
-            }
-
-            return $bstream;
-        }
-        
-        //----------------------------------------------------------------------
-        public function getByteStream()
-        {
-            $bstream = $this->getBitStream();
-            if($bstream == null) {
-                return null;
-            }
-            
-            return $bstream->toByte();
-        }
-    }
-        
-        
-    
-
-
-
-//---- qrbitstream.php -----------------------------
-
-
-
-
-/*
- * PHP QR Code encoder
- *
- * Bitstream class
- *
- * Based on libqrencode C library distributed under LGPL 2.1
- * Copyright (C) 2006, 2007, 2008, 2009 Kentaro Fukuchi <fukuchi@megaui.net>
- *
- * PHP QR Code is distributed under LGPL 3
- * Copyright (C) 2010 Dominik Dzienia <deltalab at poczta dot fm>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
- */
-     
-    class QRbitstream {
-    
-        public $data = array();
-        
-        //----------------------------------------------------------------------
-        public function size()
-        {
-            return count($this->data);
-        }
-        
-        //----------------------------------------------------------------------
-        public function allocate($setLength)
-        {
-            $this->data = array_fill(0, $setLength, 0);
-            return 0;
-        }
-    
-        //----------------------------------------------------------------------
-        public static function newFromNum($bits, $num)
-        {
-            $bstream = new QRbitstream();
-            $bstream->allocate($bits);
-            
-            $mask = 1 << ($bits - 1);
-            for($i=0; $i<$bits; $i++) {
-                if($num & $mask) {
-                    $bstream->data[$i] = 1;
-                } else {
-                    $bstream->data[$i] = 0;
-                }
-                $mask = $mask >> 1;
-            }
-
-            return $bstream;
-        }
-        
-        //----------------------------------------------------------------------
-        public static function newFromBytes($size, $data)
-        {
-            $bstream = new QRbitstream();
-            $bstream->allocate($size * 8);
-            $p=0;
-
-            for($i=0; $i<$size; $i++) {
-                $mask = 0x80;
-                for($j=0; $j<8; $j++) {
-                    if($data[$i] & $mask) {
-                        $bstream->data[$p] = 1;
-                    } else {
-                        $bstream->data[$p] = 0;
-                    }
-                    $p++;
-                    $mask = $mask >> 1;
-                }
-            }
-
-            return $bstream;
-        }
-        
-        //----------------------------------------------------------------------
-        public function append(QRbitstream $arg)
-        {
-            if (is_null($arg)) {
-                return -1;
-            }
-            
-            if($arg->size() == 0) {
-                return 0;
-            }
-            
-            if($this->size() == 0) {
-                $this->data = $arg->data;
-                return 0;
-            }
-            
-            $this->data = array_values(array_merge($this->data, $arg->data));
-
-            return 0;
-        }
-        
-        //----------------------------------------------------------------------
-        public function appendNum($bits, $num)
-        {
-            if ($bits == 0) 
-                return 0;
-
-            $b = QRbitstream::newFromNum($bits, $num);
-            
-            if(is_null($b))
-                return -1;
-
-            $ret = $this->append($b);
-            unset($b);
-
-            return $ret;
-        }
-
-        //----------------------------------------------------------------------
-        public function appendBytes($size, $data)
-        {
-            if ($size == 0) 
-                return 0;
-
-            $b = QRbitstream::newFromBytes($size, $data);
-            
-            if(is_null($b))
-                return -1;
-
-            $ret = $this->append($b);
-            unset($b);
-
-            return $ret;
-        }
-        
-        //----------------------------------------------------------------------
-        public function toByte()
-        {
-        
-            $size = $this->size();
-
-            if($size == 0) {
-                return array();
-            }
-            
-            $data = array_fill(0, (int)(($size + 7) / 8), 0);
-            $bytes = (int)($size / 8);
-
-            $p = 0;
-            
-            for($i=0; $i<$bytes; $i++) {
-                $v = 0;
-                for($j=0; $j<8; $j++) {
-                    $v = $v << 1;
-                    $v |= $this->data[$p];
-                    $p++;
-                }
-                $data[$i] = $v;
-            }
-            
-            if($size & 7) {
-                $v = 0;
-                for($j=0; $j<($size & 7); $j++) {
-                    $v = $v << 1;
-                    $v |= $this->data[$p];
-                    $p++;
-                }
-                $data[$bytes] = $v;
-            }
-
-            return $data;
-        }
-
-    }
-
-
-
-
-//---- qrsplit.php -----------------------------
-
-
-
-
-/*
- * PHP QR Code encoder
- *
- * Input splitting classes
- *
- * Based on libqrencode C library distributed under LGPL 2.1
- * Copyright (C) 2006, 2007, 2008, 2009 Kentaro Fukuchi <fukuchi@megaui.net>
- *
- * PHP QR Code is distributed under LGPL 3
- * Copyright (C) 2010 Dominik Dzienia <deltalab at poczta dot fm>
- *
- * The following data / specifications are taken from
- * "Two dimensional symbol -- QR-code -- Basic Specification" (JIS X0510:2004)
- *  or
- * "Automatic identification and data capture techniques -- 
- *  QR Code 2005 bar code symbology specification" (ISO/IEC 18004:2006)
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
- */
-    class QRsplit {
-
-        public $dataStr = '';
-        public $input;
-        public $modeHint;
-
-        //----------------------------------------------------------------------
-        public function __construct($dataStr, $input, $modeHint) 
-        {
-            $this->dataStr  = $dataStr;
-            $this->input    = $input;
-            $this->modeHint = $modeHint;
-        }
-        
-        //----------------------------------------------------------------------
-        public static function isdigitat($str, $pos)
-        {    
-            if ($pos >= strlen($str))
-                return false;
-            
-            return ((ord($str[$pos]) >= ord('0'))&&(ord($str[$pos]) <= ord('9')));
-        }
-        
-        //----------------------------------------------------------------------
-        public static function isalnumat($str, $pos)
-        {
-            if ($pos >= strlen($str))
-                return false;
-                
-            return (QRinput::lookAnTable(ord($str[$pos])) >= 0);
-        }
-
-        //----------------------------------------------------------------------
-        public function identifyMode($pos)
-        {
-            if ($pos >= strlen($this->dataStr)) 
-                return QR_MODE_NUL;
-                
-            $c = $this->dataStr[$pos];
-            
-            if(self::isdigitat($this->dataStr, $pos)) {
-                return QR_MODE_NUM;
-            } else if(self::isalnumat($this->dataStr, $pos)) {
-                return QR_MODE_AN;
-            } else if($this->modeHint == QR_MODE_KANJI) {
-            
-                if ($pos+1 < strlen($this->dataStr)) 
-                {
-                    $d = $this->dataStr[$pos+1];
-                    $word = (ord($c) << 8) | ord($d);
-                    if(($word >= 0x8140 && $word <= 0x9ffc) || ($word >= 0xe040 && $word <= 0xebbf)) {
-                        return QR_MODE_KANJI;
-                    }
-                }
-            }
-
-            return QR_MODE_8;
-        } 
-        
-        //----------------------------------------------------------------------
-        public function eatNum()
-        {
-            $ln = QRspec::lengthIndicator(QR_MODE_NUM, $this->input->getVersion());
-
-            $p = 0;
-            while(self::isdigitat($this->dataStr, $p)) {
-                $p++;
-            }
-            
-            $run = $p;
-            $mode = $this->identifyMode($p);
-            
-            if($mode == QR_MODE_8) {
-                $dif = QRinput::estimateBitsModeNum($run) + 4 + $ln
-                     + QRinput::estimateBitsMode8(1)         // + 4 + l8
-                     - QRinput::estimateBitsMode8($run + 1); // - 4 - l8
-                if($dif > 0) {
-                    return $this->eat8();
-                }
-            }
-            if($mode == QR_MODE_AN) {
-                $dif = QRinput::estimateBitsModeNum($run) + 4 + $ln
-                     + QRinput::estimateBitsModeAn(1)        // + 4 + la
-                     - QRinput::estimateBitsModeAn($run + 1);// - 4 - la
-                if($dif > 0) {
-                    return $this->eatAn();
-                }
-            }
-            
-            $ret = $this->input->append(QR_MODE_NUM, $run, str_split($this->dataStr));
-            if($ret < 0)
-                return -1;
-
-            return $run;
-        }
-        
-        //----------------------------------------------------------------------
-        public function eatAn()
-        {
-            $la = QRspec::lengthIndicator(QR_MODE_AN,  $this->input->getVersion());
-            $ln = QRspec::lengthIndicator(QR_MODE_NUM, $this->input->getVersion());
-
-            $p = 0;
-            
-            while(self::isalnumat($this->dataStr, $p)) {
-                if(self::isdigitat($this->dataStr, $p)) {
-                    $q = $p;
-                    while(self::isdigitat($this->dataStr, $q)) {
-                        $q++;
-                    }
-                    
-                    $dif = QRinput::estimateBitsModeAn($p) // + 4 + la
-                         + QRinput::estimateBitsModeNum($q - $p) + 4 + $ln
-                         - QRinput::estimateBitsModeAn($q); // - 4 - la
-                         
-                    if($dif < 0) {
-                        break;
-                    } else {
-                        $p = $q;
-                    }
-                } else {
-                    $p++;
-                }
-            }
-
-            $run = $p;
-
-            if(!self::isalnumat($this->dataStr, $p)) {
-                $dif = QRinput::estimateBitsModeAn($run) + 4 + $la
-                     + QRinput::estimateBitsMode8(1) // + 4 + l8
-                      - QRinput::estimateBitsMode8($run + 1); // - 4 - l8
-                if($dif > 0) {
-                    return $this->eat8();
-                }
-            }
-
-            $ret = $this->input->append(QR_MODE_AN, $run, str_split($this->dataStr));
-            if($ret < 0)
-                return -1;
-
-            return $run;
-        }
-        
-        //----------------------------------------------------------------------
-        public function eatKanji()
-        {
-            $p = 0;
-            
-            while($this->identifyMode($p) == QR_MODE_KANJI) {
-                $p += 2;
-            }
-            
-            $ret = $this->input->append(QR_MODE_KANJI, $p, str_split($this->dataStr));
-            if($ret < 0)
-                return -1;
-
-            return $run;
-        }
-
-        //----------------------------------------------------------------------
-        public function eat8()
-        {
-            $la = QRspec::lengthIndicator(QR_MODE_AN, $this->input->getVersion());
-            $ln = QRspec::lengthIndicator(QR_MODE_NUM, $this->input->getVersion());
-
-            $p = 1;
-            $dataStrLen = strlen($this->dataStr);
-            
-            while($p < $dataStrLen) {
-                
-                $mode = $this->identifyMode($p);
-                if($mode == QR_MODE_KANJI) {
-                    break;
-                }
-                if($mode == QR_MODE_NUM) {
-                    $q = $p;
-                    while(self::isdigitat($this->dataStr, $q)) {
-                        $q++;
-                    }
-                    $dif = QRinput::estimateBitsMode8($p) // + 4 + l8
-                         + QRinput::estimateBitsModeNum($q - $p) + 4 + $ln
-                         - QRinput::estimateBitsMode8($q); // - 4 - l8
-                    if($dif < 0) {
-                        break;
-                    } else {
-                        $p = $q;
-                    }
-                } else if($mode == QR_MODE_AN) {
-                    $q = $p;
-                    while(self::isalnumat($this->dataStr, $q)) {
-                        $q++;
-                    }
-                    $dif = QRinput::estimateBitsMode8($p)  // + 4 + l8
-                         + QRinput::estimateBitsModeAn($q - $p) + 4 + $la
-                         - QRinput::estimateBitsMode8($q); // - 4 - l8
-                    if($dif < 0) {
-                        break;
-                    } else {
-                        $p = $q;
-                    }
-                } else {
-                    $p++;
-                }
-            }
-
-            $run = $p;
-            $ret = $this->input->append(QR_MODE_8, $run, str_split($this->dataStr));
-            
-            if($ret < 0)
-                return -1;
-
-            return $run;
-        }
-
-        //----------------------------------------------------------------------
-        public function splitString()
-        {
-            while (strlen($this->dataStr) > 0)
-            {
-                if($this->dataStr == '')
-                    return 0;
-
-                $mode = $this->identifyMode(0);
-                
-                switch ($mode) {
-                    case QR_MODE_NUM: $length = $this->eatNum(); break;
-                    case QR_MODE_AN:  $length = $this->eatAn(); break;
-                    case QR_MODE_KANJI:
-                        if ($hint == QR_MODE_KANJI)
-                                $length = $this->eatKanji();
-                        else    $length = $this->eat8();
-                        break;
-                    default: $length = $this->eat8(); break;
-                
-                }
-
-                if($length == 0) return 0;
-                if($length < 0)  return -1;
-                
-                $this->dataStr = substr($this->dataStr, $length);
-            }
-        }
-
-        //----------------------------------------------------------------------
-        public function toUpper()
-        {
-            $stringLen = strlen($this->dataStr);
-            $p = 0;
-            
-            while ($p<$stringLen) {
-                $mode = self::identifyMode(substr($this->dataStr, $p), $this->modeHint);
-                if($mode == QR_MODE_KANJI) {
-                    $p += 2;
-                } else {
-                    if (ord($this->dataStr[$p]) >= ord('a') && ord($this->dataStr[$p]) <= ord('z')) {
-                        $this->dataStr[$p] = chr(ord($this->dataStr[$p]) - 32);
-                    }
-                    $p++;
-                }
-            }
-
-            return $this->dataStr;
-        }
-
-        //----------------------------------------------------------------------
-        public static function splitStringToQRinput($string, QRinput $input, $modeHint, $casesensitive = true)
-        {
-            if(is_null($string) || $string == '\0' || $string == '') {
-                throw new Exception('empty string!!!');
-            }
-
-            $split = new QRsplit($string, $input, $modeHint);
-            
-            if(!$casesensitive)
-                $split->toUpper();
-                
-            return $split->splitString();
-        }
-    }
-
-
-
-//---- qrrscode.php -----------------------------
-
-
-
-
-/*
- * PHP QR Code encoder
- *
- * Reed-Solomon error correction support
- * 
- * Copyright (C) 2002, 2003, 2004, 2006 Phil Karn, KA9Q
- * (libfec is released under the GNU Lesser General Public License.)
- *
- * Based on libqrencode C library distributed under LGPL 2.1
- * Copyright (C) 2006, 2007, 2008, 2009 Kentaro Fukuchi <fukuchi@megaui.net>
- *
- * PHP QR Code is distributed under LGPL 3
- * Copyright (C) 2010 Dominik Dzienia <deltalab at poczta dot fm>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
- */
- 
-    class QRrsItem {
-    
-        public $mm;                  // Bits per symbol 
-        public $nn;                  // Symbols per block (= (1<<mm)-1) 
-        public $alpha_to = array();  // log lookup table 
-        public $index_of = array();  // Antilog lookup table 
-        public $genpoly = array();   // Generator polynomial 
-        public $nroots;              // Number of generator roots = number of parity symbols 
-        public $fcr;                 // First consecutive root, index form 
-        public $prim;                // Primitive element, index form 
-        public $iprim;               // prim-th root of 1, index form 
-        public $pad;                 // Padding bytes in shortened block 
-        public $gfpoly;
-    
-        //----------------------------------------------------------------------
-        public function modnn($x)
-        {
-            while ($x >= $this->nn) {
-                $x -= $this->nn;
-                $x = ($x >> $this->mm) + ($x & $this->nn);
-            }
-            
-            return $x;
-        }
-        
-        //----------------------------------------------------------------------
-        public static function init_rs_char($symsize, $gfpoly, $fcr, $prim, $nroots, $pad)
-        {
-            // Common code for intializing a Reed-Solomon control block (char or int symbols)
-            // Copyright 2004 Phil Karn, KA9Q
-            // May be used under the terms of the GNU Lesser General Public License (LGPL)
-
-            $rs = null;
-            
-            // Check parameter ranges
-            if($symsize < 0 || $symsize > 8)                     return $rs;
-            if($fcr < 0 || $fcr >= (1<<$symsize))                return $rs;
-            if($prim <= 0 || $prim >= (1<<$symsize))             return $rs;
-            if($nroots < 0 || $nroots >= (1<<$symsize))          return $rs; // Can't have more roots than symbol values!
-            if($pad < 0 || $pad >= ((1<<$symsize) -1 - $nroots)) return $rs; // Too much padding
-
-            $rs = new QRrsItem();
-            $rs->mm = $symsize;
-            $rs->nn = (1<<$symsize)-1;
-            $rs->pad = $pad;
-
-            $rs->alpha_to = array_fill(0, $rs->nn+1, 0);
-            $rs->index_of = array_fill(0, $rs->nn+1, 0);
-          
-            // PHP style macro replacement ;)
-            $NN =& $rs->nn;
-            $A0 =& $NN;
-            
-            // Generate Galois field lookup tables
-            $rs->index_of[0] = $A0; // log(zero) = -inf
-            $rs->alpha_to[$A0] = 0; // alpha**-inf = 0
-            $sr = 1;
-          
-            for($i=0; $i<$rs->nn; $i++) {
-                $rs->index_of[$sr] = $i;
-                $rs->alpha_to[$i] = $sr;
-                $sr <<= 1;
-                if($sr & (1<<$symsize)) {
-                    $sr ^= $gfpoly;
-                }
-                $sr &= $rs->nn;
-            }
-            
-            if($sr != 1){
-                // field generator polynomial is not primitive!
-                $rs = NULL;
-                return $rs;
-            }
-
-            /* Form RS code generator polynomial from its roots */
-            $rs->genpoly = array_fill(0, $nroots+1, 0);
-        
-            $rs->fcr = $fcr;
-            $rs->prim = $prim;
-            $rs->nroots = $nroots;
-            $rs->gfpoly = $gfpoly;
-
-            /* Find prim-th root of 1, used in decoding */
-            for($iprim=1;($iprim % $prim) != 0;$iprim += $rs->nn)
-            ; // intentional empty-body loop!
-            
-            $rs->iprim = (int)($iprim / $prim);
-            $rs->genpoly[0] = 1;
-            
-            for ($i = 0,$root=$fcr*$prim; $i < $nroots; $i++, $root += $prim) {
-                $rs->genpoly[$i+1] = 1;
-
-                // Multiply rs->genpoly[] by  @**(root + x)
-                for ($j = $i; $j > 0; $j--) {
-                    if ($rs->genpoly[$j] != 0) {
-                        $rs->genpoly[$j] = $rs->genpoly[$j-1] ^ $rs->alpha_to[$rs->modnn($rs->index_of[$rs->genpoly[$j]] + $root)];
-                    } else {
-                        $rs->genpoly[$j] = $rs->genpoly[$j-1];
-                    }
-                }
-                // rs->genpoly[0] can never be zero
-                $rs->genpoly[0] = $rs->alpha_to[$rs->modnn($rs->index_of[$rs->genpoly[0]] + $root)];
-            }
-            
-            // convert rs->genpoly[] to index form for quicker encoding
-            for ($i = 0; $i <= $nroots; $i++)
-                $rs->genpoly[$i] = $rs->index_of[$rs->genpoly[$i]];
-
-            return $rs;
-        }
-        
-        //----------------------------------------------------------------------
-        public function encode_rs_char($data, &$parity)
-        {
-            $MM       =& $this->mm;
-            $NN       =& $this->nn;
-            $ALPHA_TO =& $this->alpha_to;
-            $INDEX_OF =& $this->index_of;
-            $GENPOLY  =& $this->genpoly;
-            $NROOTS   =& $this->nroots;
-            $FCR      =& $this->fcr;
-            $PRIM     =& $this->prim;
-            $IPRIM    =& $this->iprim;
-            $PAD      =& $this->pad;
-            $A0       =& $NN;
-
-            $parity = array_fill(0, $NROOTS, 0);
-
-            for($i=0; $i< ($NN-$NROOTS-$PAD); $i++) {
-                
-                $feedback = $INDEX_OF[$data[$i] ^ $parity[0]];
-                if($feedback != $A0) {      
-                    // feedback term is non-zero
-            
-                    // This line is unnecessary when GENPOLY[NROOTS] is unity, as it must
-                    // always be for the polynomials constructed by init_rs()
-                    $feedback = $this->modnn($NN - $GENPOLY[$NROOTS] + $feedback);
-            
-                    for($j=1;$j<$NROOTS;$j++) {
-                        $parity[$j] ^= $ALPHA_TO[$this->modnn($feedback + $GENPOLY[$NROOTS-$j])];
-                    }
-                }
-                
-                // Shift 
-                array_shift($parity);
-                if($feedback != $A0) {
-                    array_push($parity, $ALPHA_TO[$this->modnn($feedback + $GENPOLY[0])]);
-                } else {
-                    array_push($parity, 0);
-                }
-            }
-        }
-    }
-    
-    //##########################################################################
-    
-    class QRrs {
-    
-        public static $items = array();
-        
-        //----------------------------------------------------------------------
-        public static function init_rs($symsize, $gfpoly, $fcr, $prim, $nroots, $pad)
-        {
-            foreach(self::$items as $rs) {
-                if($rs->pad != $pad)       continue;
-                if($rs->nroots != $nroots) continue;
-                if($rs->mm != $symsize)    continue;
-                if($rs->gfpoly != $gfpoly) continue;
-                if($rs->fcr != $fcr)       continue;
-                if($rs->prim != $prim)     continue;
-
-                return $rs;
-            }
-
-            $rs = QRrsItem::init_rs_char($symsize, $gfpoly, $fcr, $prim, $nroots, $pad);
-            array_unshift(self::$items, $rs);
-
-            return $rs;
-        }
-    }
-
-
-
-//---- qrmask.php -----------------------------
-
-
-
-
-/*
- * PHP QR Code encoder
- *
- * Masking
- *
- * Based on libqrencode C library distributed under LGPL 2.1
- * Copyright (C) 2006, 2007, 2008, 2009 Kentaro Fukuchi <fukuchi@megaui.net>
- *
- * PHP QR Code is distributed under LGPL 3
- * Copyright (C) 2010 Dominik Dzienia <deltalab at poczta dot fm>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
- */
- 
-	define('N1', 3);
-	define('N2', 3);
-	define('N3', 40);
-	define('N4', 10);
-
-	class QRmask {
-	
-		public $runLength = array();
-		
-		//----------------------------------------------------------------------
-		public function __construct() 
-        {
-            $this->runLength = array_fill(0, QRSPEC_WIDTH_MAX + 1, 0);
-        }
-        
-        //----------------------------------------------------------------------
-        public function writeFormatInformation($width, &$frame, $mask, $level)
-        {
-            $blacks = 0;
-            $format =  QRspec::getFormatInfo($mask, $level);
-
-            for($i=0; $i<8; $i++) {
-                if($format & 1) {
-                    $blacks += 2;
-                    $v = 0x85;
-                } else {
-                    $v = 0x84;
-                }
-                
-                $frame[8][$width - 1 - $i] = chr($v);
-                if($i < 6) {
-                    $frame[$i][8] = chr($v);
-                } else {
-                    $frame[$i + 1][8] = chr($v);
-                }
-                $format = $format >> 1;
-            }
-            
-            for($i=0; $i<7; $i++) {
-                if($format & 1) {
-                    $blacks += 2;
-                    $v = 0x85;
-                } else {
-                    $v = 0x84;
-                }
-                
-                $frame[$width - 7 + $i][8] = chr($v);
-                if($i == 0) {
-                    $frame[8][7] = chr($v);
-                } else {
-                    $frame[8][6 - $i] = chr($v);
-                }
-                
-                $format = $format >> 1;
-            }
-
-            return $blacks;
-        }
-        
-        //----------------------------------------------------------------------
-        public function mask0($x, $y) { return ($x+$y)&1;                       }
-        public function mask1($x, $y) { return ($y&1);                          }
-        public function mask2($x, $y) { return ($x%3);                          }
-        public function mask3($x, $y) { return ($x+$y)%3;                       }
-        public function mask4($x, $y) { return (((int)($y/2))+((int)($x/3)))&1; }
-        public function mask5($x, $y) { return (($x*$y)&1)+($x*$y)%3;           }
-        public function mask6($x, $y) { return ((($x*$y)&1)+($x*$y)%3)&1;       }
-        public function mask7($x, $y) { return ((($x*$y)%3)+(($x+$y)&1))&1;     }
-        
-        //----------------------------------------------------------------------
-        private function generateMaskNo($maskNo, $width, $frame)
-        {
-            $bitMask = array_fill(0, $width, array_fill(0, $width, 0));
-            
-            for($y=0; $y<$width; $y++) {
-                for($x=0; $x<$width; $x++) {
-                    if(ord($frame[$y][$x]) & 0x80) {
-                        $bitMask[$y][$x] = 0;
-                    } else {
-                        $maskFunc = call_user_func(array($this, 'mask'.$maskNo), $x, $y);
-                        $bitMask[$y][$x] = ($maskFunc == 0)?1:0;
-                    }
-                    
-                }
-            }
-            
-            return $bitMask;
-        }
-        
-        //----------------------------------------------------------------------
-        public static function serial($bitFrame)
-        {
-            $codeArr = array();
-            
-            foreach ($bitFrame as $line)
-                $codeArr[] = join('', $line);
-                
-            return gzcompress(join("\n", $codeArr), 9);
-        }
-        
-        //----------------------------------------------------------------------
-        public static function unserial($code)
-        {
-            $codeArr = array();
-            
-            $codeLines = explode("\n", gzuncompress($code));
-            foreach ($codeLines as $line)
-                $codeArr[] = str_split($line);
-            
-            return $codeArr;
-        }
-        
-        //----------------------------------------------------------------------
-        public function makeMaskNo($maskNo, $width, $s, &$d, $maskGenOnly = false) 
-        {
-            $b = 0;
-            $bitMask = array();
-            
-            $fileName = QR_CACHE_DIR.'mask_'.$maskNo.DIRECTORY_SEPARATOR.'mask_'.$width.'_'.$maskNo.'.dat';
-
-            if (QR_CACHEABLE) {
-                if (file_exists($fileName)) {
-                    $bitMask = self::unserial(file_get_contents($fileName));
-                } else {
-                    $bitMask = $this->generateMaskNo($maskNo, $width, $s, $d);
-                    if (!file_exists(QR_CACHE_DIR.'mask_'.$maskNo))
-                        mkdir(QR_CACHE_DIR.'mask_'.$maskNo);
-                    file_put_contents($fileName, self::serial($bitMask));
-                }
-            } else {
-                $bitMask = $this->generateMaskNo($maskNo, $width, $s, $d);
-            }
-
-            if ($maskGenOnly)
-                return;
-                
-            $d = $s;
-
-            for($y=0; $y<$width; $y++) {
-                for($x=0; $x<$width; $x++) {
-                    if($bitMask[$y][$x] == 1) {
-                        $d[$y][$x] = chr(ord($s[$y][$x]) ^ (int)$bitMask[$y][$x]);
-                    }
-                    $b += (int)(ord($d[$y][$x]) & 1);
-                }
-            }
-
-            return $b;
-        }
-        
-        //----------------------------------------------------------------------
-        public function makeMask($width, $frame, $maskNo, $level)
-        {
-            $masked = array_fill(0, $width, str_repeat("\0", $width));
-            $this->makeMaskNo($maskNo, $width, $frame, $masked);
-            $this->writeFormatInformation($width, $masked, $maskNo, $level);
-       
-            return $masked;
-        }
-        
-        //----------------------------------------------------------------------
-        public function calcN1N3($length)
-        {
-            $demerit = 0;
-
-            for($i=0; $i<$length; $i++) {
-                
-                if($this->runLength[$i] >= 5) {
-                    $demerit += (N1 + ($this->runLength[$i] - 5));
-                }
-                if($i & 1) {
-                    if(($i >= 3) && ($i < ($length-2)) && ($this->runLength[$i] % 3 == 0)) {
-                        $fact = (int)($this->runLength[$i] / 3);
-                        if(($this->runLength[$i-2] == $fact) &&
-                           ($this->runLength[$i-1] == $fact) &&
-                           ($this->runLength[$i+1] == $fact) &&
-                           ($this->runLength[$i+2] == $fact)) {
-                            if(($this->runLength[$i-3] < 0) || ($this->runLength[$i-3] >= (4 * $fact))) {
-                                $demerit += N3;
-                            } else if((($i+3) >= $length) || ($this->runLength[$i+3] >= (4 * $fact))) {
-                                $demerit += N3;
-                            }
-                        }
-                    }
-                }
-            }
-            return $demerit;
-        }
-        
-        //----------------------------------------------------------------------
-        public function evaluateSymbol($width, $frame)
-        {
-            $head = 0;
-            $demerit = 0;
-
-            for($y=0; $y<$width; $y++) {
-                $head = 0;
-                $this->runLength[0] = 1;
-                
-                $frameY = $frame[$y];
-                
-                if ($y>0)
-                    $frameYM = $frame[$y-1];
-                
-                for($x=0; $x<$width; $x++) {
-                    if(($x > 0) && ($y > 0)) {
-                        $b22 = ord($frameY[$x]) & ord($frameY[$x-1]) & ord($frameYM[$x]) & ord($frameYM[$x-1]);
-                        $w22 = ord($frameY[$x]) | ord($frameY[$x-1]) | ord($frameYM[$x]) | ord($frameYM[$x-1]);
-                        
-                        if(($b22 | ($w22 ^ 1))&1) {                                                                     
-                            $demerit += N2;
-                        }
-                    }
-                    if(($x == 0) && (ord($frameY[$x]) & 1)) {
-                        $this->runLength[0] = -1;
-                        $head = 1;
-                        $this->runLength[$head] = 1;
-                    } else if($x > 0) {
-                        if((ord($frameY[$x]) ^ ord($frameY[$x-1])) & 1) {
-                            $head++;
-                            $this->runLength[$head] = 1;
-                        } else {
-                            $this->runLength[$head]++;
-                        }
-                    }
-                }
-    
-                $demerit += $this->calcN1N3($head+1);
-            }
-
-            for($x=0; $x<$width; $x++) {
-                $head = 0;
-                $this->runLength[0] = 1;
-                
-                for($y=0; $y<$width; $y++) {
-                    if($y == 0 && (ord($frame[$y][$x]) & 1)) {
-                        $this->runLength[0] = -1;
-                        $head = 1;
-                        $this->runLength[$head] = 1;
-                    } else if($y > 0) {
-                        if((ord($frame[$y][$x]) ^ ord($frame[$y-1][$x])) & 1) {
-                            $head++;
-                            $this->runLength[$head] = 1;
-                        } else {
-                            $this->runLength[$head]++;
-                        }
-                    }
-                }
-            
-                $demerit += $this->calcN1N3($head+1);
-            }
-
-            return $demerit;
-        }
-        
-        
-        //----------------------------------------------------------------------
-        public function mask($width, $frame, $level)
-        {
-            $minDemerit = PHP_INT_MAX;
-            $bestMaskNum = 0;
-            $bestMask = array();
-            
-            $checked_masks = array(0,1,2,3,4,5,6,7);
-            
-            if (QR_FIND_FROM_RANDOM !== false) {
-            
-                $howManuOut = 8-(QR_FIND_FROM_RANDOM % 9);
-                for ($i = 0; $i <  $howManuOut; $i++) {
-                    $remPos = rand (0, count($checked_masks)-1);
-                    unset($checked_masks[$remPos]);
-                    $checked_masks = array_values($checked_masks);
-                }
-            
-            }
-            
-            $bestMask = $frame;
-             
-            foreach($checked_masks as $i) {
-                $mask = array_fill(0, $width, str_repeat("\0", $width));
-
-                $demerit = 0;
-                $blacks = 0;
-                $blacks  = $this->makeMaskNo($i, $width, $frame, $mask);
-                $blacks += $this->writeFormatInformation($width, $mask, $i, $level);
-                $blacks  = (int)(100 * $blacks / ($width * $width));
-                $demerit = (int)((int)(abs($blacks - 50) / 5) * N4);
-                $demerit += $this->evaluateSymbol($width, $mask);
-                
-                if($demerit < $minDemerit) {
-                    $minDemerit = $demerit;
-                    $bestMask = $mask;
-                    $bestMaskNum = $i;
-                }
-            }
-            
-            return $bestMask;
-        }
-        
-        //----------------------------------------------------------------------
-    }
-
-
-
-
-//---- qrencode.php -----------------------------
-
-
-
-
-/*
- * PHP QR Code encoder
- *
- * Main encoder classes.
- *
- * Based on libqrencode C library distributed under LGPL 2.1
- * Copyright (C) 2006, 2007, 2008, 2009 Kentaro Fukuchi <fukuchi@megaui.net>
- *
- * PHP QR Code is distributed under LGPL 3
- * Copyright (C) 2010 Dominik Dzienia <deltalab at poczta dot fm>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
- */
- 
-    class QRrsblock {
-        public $dataLength;
-        public $data = array();
-        public $eccLength;
-        public $ecc = array();
-        
-        public function __construct($dl, $data, $el, &$ecc, QRrsItem $rs)
-        {
-            $rs->encode_rs_char($data, $ecc);
-        
-            $this->dataLength = $dl;
-            $this->data = $data;
-            $this->eccLength = $el;
-            $this->ecc = $ecc;
-        }
-    };
-    
-    //##########################################################################
-
-    class QRrawcode {
-        public $version;
-        public $datacode = array();
-        public $ecccode = array();
-        public $blocks;
-        public $rsblocks = array(); //of RSblock
-        public $count;
-        public $dataLength;
-        public $eccLength;
-        public $b1;
-        
-        //----------------------------------------------------------------------
-        public function __construct(QRinput $input)
-        {
-            $spec = array(0,0,0,0,0);
-            
-            $this->datacode = $input->getByteStream();
-            if(is_null($this->datacode)) {
-                throw new Exception('null imput string');
-            }
-
-            QRspec::getEccSpec($input->getVersion(), $input->getErrorCorrectionLevel(), $spec);
-
-            $this->version = $input->getVersion();
-            $this->b1 = QRspec::rsBlockNum1($spec);
-            $this->dataLength = QRspec::rsDataLength($spec);
-            $this->eccLength = QRspec::rsEccLength($spec);
-            $this->ecccode = array_fill(0, $this->eccLength, 0);
-            $this->blocks = QRspec::rsBlockNum($spec);
-            
-            $ret = $this->init($spec);
-            if($ret < 0) {
-                throw new Exception('block alloc error');
-                return null;
-            }
-
-            $this->count = 0;
-        }
-        
-        //----------------------------------------------------------------------
-        public function init(array $spec)
-        {
-            $dl = QRspec::rsDataCodes1($spec);
-            $el = QRspec::rsEccCodes1($spec);
-            $rs = QRrs::init_rs(8, 0x11d, 0, 1, $el, 255 - $dl - $el);
-            
-
-            $blockNo = 0;
-            $dataPos = 0;
-            $eccPos = 0;
-            for($i=0; $i<QRspec::rsBlockNum1($spec); $i++) {
-                $ecc = array_slice($this->ecccode,$eccPos);
-                $this->rsblocks[$blockNo] = new QRrsblock($dl, array_slice($this->datacode, $dataPos), $el,  $ecc, $rs);
-                $this->ecccode = array_merge(array_slice($this->ecccode,0, $eccPos), $ecc);
-                
-                $dataPos += $dl;
-                $eccPos += $el;
-                $blockNo++;
-            }
-
-            if(QRspec::rsBlockNum2($spec) == 0)
-                return 0;
-
-            $dl = QRspec::rsDataCodes2($spec);
-            $el = QRspec::rsEccCodes2($spec);
-            $rs = QRrs::init_rs(8, 0x11d, 0, 1, $el, 255 - $dl - $el);
-            
-            if($rs == NULL) return -1;
-            
-            for($i=0; $i<QRspec::rsBlockNum2($spec); $i++) {
-                $ecc = array_slice($this->ecccode,$eccPos);
-                $this->rsblocks[$blockNo] = new QRrsblock($dl, array_slice($this->datacode, $dataPos), $el, $ecc, $rs);
-                $this->ecccode = array_merge(array_slice($this->ecccode,0, $eccPos), $ecc);
-                
-                $dataPos += $dl;
-                $eccPos += $el;
-                $blockNo++;
-            }
-
-            return 0;
-        }
-        
-        //----------------------------------------------------------------------
-        public function getCode()
-        {
-            $ret;
-
-            if($this->count < $this->dataLength) {
-                $row = $this->count % $this->blocks;
-                $col = $this->count / $this->blocks;
-                if($col >= $this->rsblocks[0]->dataLength) {
-                    $row += $this->b1;
-                }
-                $ret = $this->rsblocks[$row]->data[$col];
-            } else if($this->count < $this->dataLength + $this->eccLength) {
-                $row = ($this->count - $this->dataLength) % $this->blocks;
-                $col = ($this->count - $this->dataLength) / $this->blocks;
-                $ret = $this->rsblocks[$row]->ecc[$col];
-            } else {
-                return 0;
-            }
-            $this->count++;
-            
-            return $ret;
-        }
-    }
-
-    //##########################################################################
-    
-    class QRcode {
-    
-        public $version;
-        public $width;
-        public $data; 
-        
-        //----------------------------------------------------------------------
-        public function encodeMask(QRinput $input, $mask)
-        {
-            if($input->getVersion() < 0 || $input->getVersion() > QRSPEC_VERSION_MAX) {
-                throw new Exception('wrong version');
-            }
-            if($input->getErrorCorrectionLevel() > QR_ECLEVEL_H) {
-                throw new Exception('wrong level');
-            }
-
-            $raw = new QRrawcode($input);
-            
-            QRtools::markTime('after_raw');
-            
-            $version = $raw->version;
-            $width = QRspec::getWidth($version);
-            $frame = QRspec::newFrame($version);
-            
-            $filler = new FrameFiller($width, $frame);
-            if(is_null($filler)) {
-                return NULL;
-            }
-
-            // inteleaved data and ecc codes
-            for($i=0; $i<$raw->dataLength + $raw->eccLength; $i++) {
-                $code = $raw->getCode();
-                $bit = 0x80;
-                for($j=0; $j<8; $j++) {
-                    $addr = $filler->next();
-                    $filler->setFrameAt($addr, 0x02 | (($bit & $code) != 0));
-                    $bit = $bit >> 1;
-                }
-            }
-            
-            QRtools::markTime('after_filler');
-            
-            unset($raw);
-            
-            // remainder bits
-            $j = QRspec::getRemainder($version);
-            for($i=0; $i<$j; $i++) {
-                $addr = $filler->next();
-                $filler->setFrameAt($addr, 0x02);
-            }
-            
-            $frame = $filler->frame;
-            unset($filler);
-            
-            
-            // masking
-            $maskObj = new QRmask();
-            if($mask < 0) {
-            
-                if (QR_FIND_BEST_MASK) {
-                    $masked = $maskObj->mask($width, $frame, $input->getErrorCorrectionLevel());
-                } else {
-                    $masked = $maskObj->makeMask($width, $frame, (intval(QR_DEFAULT_MASK) % 8), $input->getErrorCorrectionLevel());
-                }
-            } else {
-                $masked = $maskObj->makeMask($width, $frame, $mask, $input->getErrorCorrectionLevel());
-            }
-            
-            if($masked == NULL) {
-                return NULL;
-            }
-            
-            QRtools::markTime('after_mask');
-            
-            $this->version = $version;
-            $this->width = $width;
-            $this->data = $masked;
-            
-            return $this;
-        }
-    
-        //----------------------------------------------------------------------
-        public function encodeInput(QRinput $input)
-        {
-            return $this->encodeMask($input, -1);
-        }
-        
-        //----------------------------------------------------------------------
-        public function encodeString8bit($string, $version, $level)
-        {
-            if(string == NULL) {
-                throw new Exception('empty string!');
-                return NULL;
-            }
-
-            $input = new QRinput($version, $level);
-            if($input == NULL) return NULL;
-
-            $ret = $input->append($input, QR_MODE_8, strlen($string), str_split($string));
-            if($ret < 0) {
-                unset($input);
-                return NULL;
-            }
-            return $this->encodeInput($input);
-        }
-
-        //----------------------------------------------------------------------
-        public function encodeString($string, $version, $level, $hint, $casesensitive)
-        {
-
-            if($hint != QR_MODE_8 && $hint != QR_MODE_KANJI) {
-                throw new Exception('bad hint');
-                return NULL;
-            }
-
-            $input = new QRinput($version, $level);
-            if($input == NULL) return NULL;
-
-            $ret = QRsplit::splitStringToQRinput($string, $input, $hint, $casesensitive);
-            if($ret < 0) {
-                return NULL;
-            }
-
-            return $this->encodeInput($input);
-        }
-        
-        //----------------------------------------------------------------------
-        public static function png($text, $outfile = false, $level = QR_ECLEVEL_L, $size = 3, $margin = 4, $saveandprint=false) 
-        {
-            $enc = QRencode::factory($level, $size, $margin);
-            return $enc->encodePNG($text, $outfile, $saveandprint=false);
-        }
-
-        //----------------------------------------------------------------------
-        public static function text($text, $outfile = false, $level = QR_ECLEVEL_L, $size = 3, $margin = 4) 
-        {
-            $enc = QRencode::factory($level, $size, $margin);
-            return $enc->encode($text, $outfile);
-        }
-
-        //----------------------------------------------------------------------
-        public static function raw($text, $outfile = false, $level = QR_ECLEVEL_L, $size = 3, $margin = 4) 
-        {
-            $enc = QRencode::factory($level, $size, $margin);
-            return $enc->encodeRAW($text, $outfile);
-        }
-    }
-    
-    //##########################################################################
-    
-    class FrameFiller {
-    
-        public $width;
-        public $frame;
-        public $x;
-        public $y;
-        public $dir;
-        public $bit;
-        
-        //----------------------------------------------------------------------
-        public function __construct($width, &$frame)
-        {
-            $this->width = $width;
-            $this->frame = $frame;
-            $this->x = $width - 1;
-            $this->y = $width - 1;
-            $this->dir = -1;
-            $this->bit = -1;
-        }
-        
-        //----------------------------------------------------------------------
-        public function setFrameAt($at, $val)
-        {
-            $this->frame[$at['y']][$at['x']] = chr($val);
-        }
-        
-        //----------------------------------------------------------------------
-        public function getFrameAt($at)
-        {
-            return ord($this->frame[$at['y']][$at['x']]);
-        }
-        
-        //----------------------------------------------------------------------
-        public function next()
-        {
-            do {
-            
-                if($this->bit == -1) {
-                    $this->bit = 0;
-                    return array('x'=>$this->x, 'y'=>$this->y);
-                }
-
-                $x = $this->x;
-                $y = $this->y;
-                $w = $this->width;
-
-                if($this->bit == 0) {
-                    $x--;
-                    $this->bit++;
-                } else {
-                    $x++;
-                    $y += $this->dir;
-                    $this->bit--;
-                }
-
-                if($this->dir < 0) {
-                    if($y < 0) {
-                        $y = 0;
-                        $x -= 2;
-                        $this->dir = 1;
-                        if($x == 6) {
-                            $x--;
-                            $y = 9;
-                        }
-                    }
-                } else {
-                    if($y == $w) {
-                        $y = $w - 1;
-                        $x -= 2;
-                        $this->dir = -1;
-                        if($x == 6) {
-                            $x--;
-                            $y -= 8;
-                        }
-                    }
-                }
-                if($x < 0 || $y < 0) return null;
-
-                $this->x = $x;
-                $this->y = $y;
-
-            } while(ord($this->frame[$y][$x]) & 0x80);
-                        
-            return array('x'=>$x, 'y'=>$y);
-        }
-        
-    } ;
-    
-    //##########################################################################    
-    
-    class QRencode {
-    
-        public $casesensitive = true;
-        public $eightbit = false;
-        
-        public $version = 0;
-        public $size = 3;
-        public $margin = 4;
-        
-        public $structured = 0; // not supported yet
-        
-        public $level = QR_ECLEVEL_L;
-        public $hint = QR_MODE_8;
-        
-        //----------------------------------------------------------------------
-        public static function factory($level = QR_ECLEVEL_L, $size = 3, $margin = 4)
-        {
-            $enc = new QRencode();
-            $enc->size = $size;
-            $enc->margin = $margin;
-            
-            switch ($level.'') {
-                case '0':
-                case '1':
-                case '2':
-                case '3':
-                        $enc->level = $level;
-                    break;
-                case 'l':
-                case 'L':
-                        $enc->level = QR_ECLEVEL_L;
-                    break;
-                case 'm':
-                case 'M':
-                        $enc->level = QR_ECLEVEL_M;
-                    break;
-                case 'q':
-                case 'Q':
-                        $enc->level = QR_ECLEVEL_Q;
-                    break;
-                case 'h':
-                case 'H':
-                        $enc->level = QR_ECLEVEL_H;
-                    break;
-            }
-            
-            return $enc;
-        }
-        
-        //----------------------------------------------------------------------
-        public function encodeRAW($intext, $outfile = false) 
-        {
-            $code = new QRcode();
-
-            if($this->eightbit) {
-                $code->encodeString8bit($intext, $this->version, $this->level);
-            } else {
-                $code->encodeString($intext, $this->version, $this->level, $this->hint, $this->casesensitive);
-            }
-            
-            return $code->data;
-        }
-
-        //----------------------------------------------------------------------
-        public function encode($intext, $outfile = false) 
-        {
-            $code = new QRcode();
-
-            if($this->eightbit) {
-                $code->encodeString8bit($intext, $this->version, $this->level);
-            } else {
-                $code->encodeString($intext, $this->version, $this->level, $this->hint, $this->casesensitive);
-            }
-            
-            QRtools::markTime('after_encode');
-            
-            if ($outfile!== false) {
-                file_put_contents($outfile, join("\n", QRtools::binarize($code->data)));
-            } else {
-                return QRtools::binarize($code->data);
-            }
-        }
-        
-        //----------------------------------------------------------------------
-        public function encodePNG($intext, $outfile = false,$saveandprint=false) 
-        {
-            try {
-            
-                ob_start();
-                $tab = $this->encode($intext);
-                $err = ob_get_contents();
-                ob_end_clean();
-                
-                if ($err != '')
-                    QRtools::log($outfile, $err);
-                
-                $maxSize = (int)(QR_PNG_MAXIMUM_SIZE / (count($tab)+2*$this->margin));
-                
-                QRimage::png($tab, $outfile, min(max(1, $this->size), $maxSize), $this->margin,$saveandprint);
-            
-            } catch (Exception $e) {
-            
-                QRtools::log($outfile, $e->getMessage());
-            
-            }
-        }
-    }
-
-

+ 0 - 129
application/common/library/Shande.php

@@ -1,129 +0,0 @@
-<?php
-namespace app\common\library;
-use think\Controller;
-use function EasyWeChat\Kernel\Support\get_client_ip;
-
-date_default_timezone_set('Asia/Shanghai');
-header('Content-type:text/html;charset=utf-8');
-//require_once './class/common.php';
-//require_once './class/H5FastPay.php';
-
-require_once env('root_path').'application/common/library/shande/Common.php';
-require_once env('root_path').'application/common/library/shande/H5FastPay.php';
-
-class Shande extends Controller
-{
-    // 统一下单接口
-    // https://open.sandpay.com.cn/product/detail/43308/43720/43721
-    public static function orderPay($order_no,$amout,$body,$notifyurl,$frontUrl)
-    {
-        $client = new \H5FastPay;
-        // 参数
-        $client->body = array(
-            'orderCode'   => $order_no,
-            //'totalAmount' => '000000000012',
-            'totalAmount' => $amout,
-            'subject'     => $body,
-            'body'        => $body,
-            'payMode'     => 'sand_h5',
-            'clientIp'    => get_client_ip(),
-            //'notifyUrl'   => 'http://192.168.1.66/sandpay-qr-phpdemo/notifyurl.php',
-            'notifyUrl'   => $notifyurl,
-            //'frontUrl'    => 'http://192.168.1.66/sandpay-qr-phpdemo/notifyurl.php',
-            'frontUrl'    => $frontUrl,
-        );
-        // 返回结果
-        $ret = $client->request('orderPay');
-        return $ret;
-    }
-
-    // 订单查询接口
-    public function orderQuery()
-    {
-        $client = new \H5FastPay;
-        // 参数, 每次需要重新赋值
-        $client->body = array(
-            'orderCode' => date('YmdHis', time()) + '0601',
-            'extend'    => ''
-        );
-        // 返回结果
-        $ret = $client->request('orderQuery');
-        echo '<pre class="myCode">';
-        print_r($ret);
-        echo '</pre>';
-    }
-
-    // 退款申请
-    public function orderRefund()
-    {
-        $client = new \H5FastPay;
-        // 参数
-        $client->body = array(
-            'orderCode'          => 'Y20181204170925675836', //新的订单号
-            'oriOrderCode'       => '2017091551421977', //原订单号
-            'refundAmount'       => '000000000012', //退款金额
-            'refundMarketAmount' => '000000000012', //退营销金额
-            'notifyUrl'          => 'http://192.168.22.171/sandpay-qr-phpdemo.bak/test/dist/notifyUrl.php',
-            'refundReason'       => 'test',
-            'extend'             => ''
-        );
-        // 返回结果
-        $ret = $client->request('orderRefund');
-        echo '<pre class="myCode">';
-        print_r($ret);
-        echo '</pre>';
-    }
-
-    // 异步通知通用接口
-    public function notify()
-    {
-        $client = new H5FastPay;
-        $sign   = $_POST['sign']; //签名
-        $data   = stripslashes($_POST['data']); //支付数据
-
-        // 验签
-        try {
-            $verifyFlag = $client->verify($data, $sign);
-            if ($verifyFlag) {
-                echo '签名正确';
-            } else {
-                echo '签名错误';
-            }
-        } catch (\Exception $e) {
-            echo $e->getMessage();
-        }
-    }
-
-    // 商户自主重发异步通知接口
-    public function orderMcAutoNotice()
-    {
-        $client = new H5FastPay;
-        // 参数
-        $client->body = array(
-            'orderCode'  => 'Y201805071725592',
-            'noticeType' => '00',
-        );
-        // 返回结果
-        $ret = $client->request('orderMcAutoNotice');
-        echo '<pre class="myCode">';
-        print_r($ret);
-        echo '</pre>';
-    }
-
-    // 对账单申请接口
-    public function clearfileDownload()
-    {
-        $client = new H5FastPay;
-        // 参数
-        $client->body = array(
-            'clearDate' => '20200611', // 结算日期
-            'fileType'  => '1', // 文件返回类型
-            'extend'    => ''
-        );
-        // 返回值
-        $ret = $client->request('clearfileDownload');
-        echo '<pre class="myCode">';
-        print_r($ret);
-        echo '</pre>';
-    }
-}

+ 0 - 158
application/common/library/Token.php

@@ -1,158 +0,0 @@
-<?php
-
-namespace app\common\library;
-
-use app\common\library\token\Driver;
-use think\App;
-use think\Config;
-use think\Log;
-
-/**
- * Token操作类
- */
-class Token
-{
-    /**
-     * @var array Token的实例
-     */
-    public static $instance = [];
-
-    /**
-     * @var object 操作句柄
-     */
-    public static $handler;
-
-    /**
-     * 连接Token驱动
-     * @access public
-     * @param  array $options 配置数组
-     * @param  bool|string $name Token连接标识 true 强制重新连接
-     * @return Driver
-     */
-    public static function connect(array $options = [], $name = false)
-    {
-        $type = !empty($options['type']) ? $options['type'] : 'File';
-
-        if (false === $name) {
-            $name = md5(serialize($options));
-        }
-
-        if (true === $name || !isset(self::$instance[$name])) {
-            $class = false === strpos($type, '\\') ?
-                '\\app\\common\\library\\token\\driver\\' . ucwords($type) :
-                $type;
-
-            // 记录初始化信息
-            App::$debug && Log::record('[ TOKEN ] INIT ' . $type, 'info');
-
-            if (true === $name) {
-                return new $class($options);
-            }
-
-            self::$instance[$name] = new $class($options);
-        }
-
-        return self::$instance[$name];
-    }
-
-    /**
-     * 自动初始化Token
-     * @access public
-     * @param  array $options 配置数组
-     * @return Driver
-     */
-    public static function init(array $options = [])
-    {
-        if (is_null(self::$handler)) {
-            if (empty($options) && 'complex' == Config::get('token.type')) {
-                $default = Config::get('token.default');
-                // 获取默认Token配置,并连接
-                $options = Config::get('token.' . $default['type']) ?: $default;
-            } elseif (empty($options)) {
-                $options = Config::get('token');
-            }
-            self::$handler = self::connect($options);
-        }
-
-        return self::$handler;
-    }
-
-    /**
-     * 判断Token是否可用(check别名)
-     * @access public
-     * @param  string $token Token标识
-     * @return bool
-     */
-    public static function has($token, $user_id)
-    {
-        return self::check($token, $user_id);
-    }
-
-    /**
-     * 判断Token是否可用
-     * @param string $token Token标识
-     * @return bool
-     */
-    public static function check($token, $user_id)
-    {
-        return self::init()->check($token, $user_id);
-    }
-
-    /**
-     * 读取Token
-     * @access public
-     * @param  string $token Token标识
-     * @param  mixed $default 默认值
-     * @return mixed
-     */
-    public static function get($token, $default = false)
-    {
-        return self::init()->get($token, $default);
-    }
-
-    /**
-     * 写入Token
-     * @access public
-     * @param  string $token Token标识
-     * @param  mixed $user_id 存储数据
-     * @param  int|null $expire 有效时间 0为永久
-     * @return boolean
-     */
-    public static function set($token, $user_id, $expire = null)
-    {
-        return self::init()->set($token, $user_id, $expire);
-    }
-
-    /**
-     * 删除Token(delete别名)
-     * @access public
-     * @param  string $token Token标识
-     * @return boolean
-     */
-    public static function rm($token)
-    {
-        return self::delete($token);
-    }
-
-    /**
-     * 删除Token
-     * @param string $token 标签名
-     * @return bool
-     */
-    public static function delete($token)
-    {
-        return self::init()->delete($token);
-    }
-
-    /**
-     * 清除Token
-     * @access public
-     * @param  string $token Token标记
-     * @return boolean
-     */
-    public static function clear($user_id = null)
-    {
-        return self::init()->clear($user_id);
-    }
-
-}

+ 0 - 189
application/common/library/WxMerchPay.php

@@ -1,189 +0,0 @@
-<?php
-namespace app\common\library;
-
-use think\Controller;
-use app\common\model\Config;
-
-class WxMerchPay extends Controller
-{
-    //企业付款到微信零钱,PHP接口调用方法
-    /*
-      配置参数
-      */
-    /*
-  配置参数
-  */
-    public function __construct()
-    {
-        $this->appid = Config::get_values('wechat_appid');
-        $this->api_key = Config::get_values('wechat_mch_key');
-        $this->mch_id = Config::get_values('wechat_mch_id');
-    }
-//    private $config = array(
-//        'appid' => "wx57f0ba125c0f9351" ,//"wxcf1dded808489e2c",    /*微信开放平台上的应用id*/
-//        'mch_id' => "1526848461",//"1440493402",   /*微信申请成功之后邮件中的商户id*/
-//        'api_key' => "quanminchuangquanminchuang123521"    /*在微信商户平台上自己设定的api密钥 32位*/
-//    );
-
-
-    /**
-     * [xmltoarray xml格式转换为数组]
-     * @param [type] $xml [xml]
-     * @return [type]  [xml 转化为array]
-     */
-    function xmltoarray($xml) {
-        //禁止引用外部xml实体
-        libxml_disable_entity_loader(true);
-        $xmlstring = simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA);
-        $val = json_decode(json_encode($xmlstring),true);
-        return $val;
-    }
-
-    /**
-     * [arraytoxml 将数组转换成xml格式(简单方法):]
-     * @param [type] $data [数组]
-     * @return [type]  [array 转 xml]
-     */
-    function arraytoxml($data){
-        $str='<xml>';
-        foreach($data as $k=>$v) {
-            $str.='<'.$k.'>'.$v.'</'.$k.'>';
-        }
-        $str.='</xml>';
-        return $str;
-    }
-
-    /**
-     * [createNoncestr 生成随机字符串]
-     * @param integer $length [长度]
-     * @return [type]   [字母大小写加数字]
-     */
-    function createNoncestr($length =32){
-        $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYabcdefghijklmnopqrstuvwxyz0123456789";
-        $str ="";
-
-        for($i=0;$i<$length;$i++){
-            $str.= substr($chars, mt_rand(0, strlen($chars)-1), 1);
-        }
-        return $str;
-    }
-
-    /**
-     * [curl_post_ssl 发送curl_post数据]
-     * @param [type] $url  [发送地址]
-     * @param [type] $xmldata [发送文件格式]
-     * @param [type] $second [设置执行最长秒数]
-     * @param [type] $aHeader [设置头部]
-     * @return [type]   [description]
-     */
-    function curl_post_ssl($url, $xmldata, $second = 30, $aHeader = array()){
-        $isdir = dirname(__DIR__) . "/wxcert/";//证书位置;绝对路径
-        $ch = curl_init();//初始化curl
-        curl_setopt($ch, CURLOPT_TIMEOUT, $second);//设置执行最长秒数
-        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);//要求结果为字符串且输出到屏幕上
-        curl_setopt($ch, CURLOPT_URL, $url);//抓取指定网页
-        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);// 终止从服务端进行验证
-        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);//
-        curl_setopt($ch, CURLOPT_SSLCERTTYPE, 'PEM');//证书类型
-        curl_setopt($ch, CURLOPT_SSLCERT, $isdir . 'apiclient_cert.pem');//证书位置
-        curl_setopt($ch, CURLOPT_SSLKEYTYPE, 'PEM');//CURLOPT_SSLKEY中规定的私钥的加密类型
-        curl_setopt($ch, CURLOPT_SSLKEY, $isdir . 'apiclient_key.pem');//证书位置
-        curl_setopt($ch, CURLOPT_CAINFO, 'PEM');
-        curl_setopt($ch, CURLOPT_CAINFO, $isdir . 'rootca.pem');
-        if (count($aHeader) >= 1) {
-            curl_setopt($ch, CURLOPT_HTTPHEADER, $aHeader);//设置头部
-        }
-        curl_setopt($ch, CURLOPT_POST, 1);//post提交方式
-        curl_setopt($ch, CURLOPT_POSTFIELDS, $xmldata);//全部数据使用HTTP协议中的"POST"操作来发送
-
-        $data = curl_exec($ch);//执行回话
-        if ($data) {
-            curl_close($ch);
-            return $data;
-        } else {
-            $error = curl_errno($ch);
-            echo "call faild, errorCode:$error\n";
-            curl_close($ch);
-            return false;
-        }
-    }
-
-
-    /**
-     * [sendMoney 企业付款到零钱]
-     * @param [type] $amount  [发送的金额(分)目前发送金额不能少于1元]
-     * @param [type] $re_openid [发送人的 openid]
-     * @param string $desc  [企业付款描述信息 (必填)]
-     * @param string $check_name [收款用户姓名 (选填)]
-     * @return [type]    [description]
-     */
-    function sendMoney($amount,$re_openid,$partner_trade_no,$desc='测试',$check_name=''){
-
-        $total_amount = (100) * $amount;
-        $data=array(
-            'mch_appid'=> $this->appid,//商户账号appid
-            'mchid'=>  $this->mch_id,//商户号
-            'nonce_str'=>$this->createNoncestr(),//随机字符串
-            'partner_trade_no'=> $partner_trade_no,//商户订单号
-            'openid'=> $re_openid,//用户openid
-            'check_name'=>'NO_CHECK',//校验用户姓名选项,
-            're_user_name'=> $check_name,//收款用户姓名
-            'amount'=>$total_amount,//金额
-            'desc'=> $desc,//企业付款描述信息
-            'spbill_create_ip'=> request()->ip(),//Ip地址
-        );
-
-        //生成签名算法
-        $secrect_key=$this->api_key;///这个就是个API密码。MD5 32位。
-        $data=array_filter($data);
-        ksort($data);
-        $str='';
-        foreach($data as $k=>$v) {
-            $str.=$k.'='.$v.'&';
-        }
-        $str.='key='.$secrect_key;
-        $data['sign']=md5($str);
-        //生成签名算法
-
-        $xml=$this->arraytoxml($data);
-
-        $url='https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers'; //调用接口
-        $res=$this->curl_post_ssl($url,$xml);
-        $return=$this->xmltoarray($res);
-
-        return $return;
-
-//        print_r($return);
-//        die;
-        //返回来的结果是xml,最后转换成数组
-        /*
-        array(9) {
-         ["return_code"]=>
-         string(7) "SUCCESS"
-         ["return_msg"]=>
-         array(0) {
-         }
-         ["mch_appid"]=>
-         string(18) "wx57676786465544b2a5"
-         ["mchid"]=>
-         string(10) "143345612"
-         ["nonce_str"]=>
-         string(32) "iw6TtHdOySMAfS81qcnqXojwUMn8l8mY"
-         ["result_code"]=>
-         string(7) "SUCCESS"
-         ["partner_trade_no"]=>
-         string(18) "201807011410504098"
-         ["payment_no"]=>
-         string(28) "1000018301201807019357038738"
-         ["payment_time"]=>
-         string(19) "2018-07-01 14:56:35"
-        }
-        */
-
-
-//        $responseObj = simplexml_load_string($res, 'SimpleXMLElement', LIBXML_NOCDATA);
-       // echo $res= $responseObj->return_code; //SUCCESS 如果返回来SUCCESS,则发生成功,处理自己的逻辑
-      //  return $responseObj;
-    }
-
-}

+ 0 - 394
application/common/library/WxPay.php

@@ -1,394 +0,0 @@
-<?php
-namespace app\common\library;
-
-use app\common\model\Config;
-use think\Controller;
-use think\Facade;
-use EasyWeChat\Factory;
-
-class WxPay extends Controller
-{
-    /*
-   配置参数
-   */
-    public function __construct()
-    {
-       // $this->appid = Config::get_values('small_wechat_id');
-        $this->appid = Config::get_values('wechat_appid');
-        $this->api_key = Config::get_values('wechat_mch_key');
-        $this->mch_id = Config::get_values('wechat_mch_id');
-
-    }
-//    private $config = array(
-//        'appid' => "wx57f0ba125c0f9351" ,//"wxcf1dded808489e2c",    /*微信开放平台上的应用id*/
-//        'mch_id' => "1526848461",//"1440493402",   /*微信申请成功之后邮件中的商户id*/
-//        'api_key' => "quanminchuangquanminchuang123521"    /*在微信商户平台上自己设定的api密钥 32位*/
-//    );
-
-    public function retrunconfig(){
-        $config = [
-           // 'app_id' => Config::get_values('small_wechat_id'),
-            'app_id' => Config::get_values('wechat_appid'),
-            'mch_id' =>Config::get_values('wechat_mch_id'),
-            'key' =>Config::get_values('wechat_mch_key'),
-            'sub_mch_id'=>'1612529165'
-        ];
-        return $config;
-    }
-
-    public function retrunconfig2(){
-        $config = [
-            'app_id' => Config::get_values('wechat_appid'),
-            'mch_id' =>Config::get_values('wechat_mch_id'),
-            'key' =>Config::get_values('wechat_mch_key'),
-            'sub_mch_id'=>'1612529165'
-        ];
-        return $config;
-    }
-
-    //获取预支付订单
-    public function getPrePayOrder($body, $out_trade_no, $total_fee, $notify_url,$come,$openid){
-
-        $url = "https://api.mch.weixin.qq.com/pay/unifiedorder";
-
-        $onoce_str = $this->getRandChar(32);
-
-        $data["appid"] =  $this->appid;
-        $data["body"] = $body;
-        $data["mch_id"] = $this->mch_id;
-        $data["nonce_str"] = $onoce_str;
-        $data["notify_url"] = $notify_url;
-        $data["out_trade_no"] = $out_trade_no;
-        $data["spbill_create_ip"] = $this->get_client_ip();
-        $data["total_fee"] = floatval($total_fee);
-        //$data["trade_type"] = $come=='weixin' ? "JSAPI" : "APP";
-        $data["trade_type"] = "APP";
-        $data['sign_type'] = "MD5";
-//        if ($come=='weixin'){
-//            $data['openid'] = $openid;
-//        }
-        $s = $this->getSign($data);
-
-        $data["sign"] = $s;
-
-        $xml = $this->arrayToXml($data);
-
-        $response = $this->postXmlCurl($xml, $url);
-
-        //将微信返回的结果xml转成数组
-       //return $this->xmlstr_to_array($response);
-        return $this->xmlToArray($response);
-    }
-
-
-    public function wxrefund($out_trade_no,$out_refund_no,$total_fee,$refund_fee)
-    {
-        $param = array(
-            'appid'=> $this->appid,
-            'mch_id'=> $this->mch_id,
-            'nonce_str'=>  $this->getRandChar(32),
-            'out_trade_no'=>$out_trade_no,
-            'out_refund_no'=>$out_refund_no,//订单号
-          //  'transaction_id'=> $transactionId,//微信订单号
-            'total_fee'=> $total_fee*100,
-            'refund_fee'=>$refund_fee*100
-        );
-
-        $param['sign'] = $this->getSign($param);
-        $xmldata = $this->arrayToXml($param);
-        $xmlresult = $this->postXmlSSLCurl($xmldata,'https://api.mch.weixin.qq.com/secapi/pay/refund');
-        $result = $this->xmlToArray($xmlresult);
-        return $result;
-    }
-
-
-    //执行第二次签名,才能返回给客户端使用
-    public function getOrder($prepayId){
-        $data["appid"] = $this->appid;
-        $data["noncestr"] = $this->getRandChar(32);
-        $data["package"] = "Sign=WXPay";
-       // $data['package'] = "prepay_id=".$prepayId;
-        $data["partnerid"] = $this->mch_id;
-        $data["prepayid"] = $prepayId;
-        $data["signType"] = "MD5";
-        $data["timestamp"] = '' . time() . '';
-        $s = $this->getSign($data, false);
-        $data["sign"] = $s;
-
-        return $data;
-    }
-
-    /*
-        生成签名
-    */
-    function getSign($Obj)
-    {
-        foreach ($Obj as $k => $v)
-        {
-            $Parameters[strtolower($k)] = $v;
-        }
-        //签名步骤一:按字典序排序参数
-        ksort($Parameters);
-        $String = $this->formatBizQueryParaMap($Parameters, false);
-        //echo "【string】 =".$String."</br>";
-        //签名步骤二:在string后加入KEY
-        $String = $String."&key=".$this->api_key;
-//        echo "<textarea style='width: 50%; height: 150px;'>$String</textarea> <br />";
-        //签名步骤三:MD5加密
-        $result_ = strtoupper(md5($String));
-        return $result_;
-    }
-
-
-
-
-    //获取指定长度的随机字符串
-    function getRandChar($length){
-        $str = null;
-        $strPol = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz";
-        $max = strlen($strPol)-1;
-
-        for($i=0;$i<$length;$i++){
-            $str.=$strPol[rand(0,$max)];//rand($min,$max)生成介于min和max两个数之间的一个随机整数
-        }
-
-        return $str;
-    }
-
-    //数组转xml
-    function arrayToXml($arr)
-    {
-        $xml = "<xml>";
-        foreach ($arr as $key=>$val)
-        {
-
-            if (is_numeric($val))
-            {
-                $xml.="<".$key.">".$val."</".$key.">";
-
-            }
-            else
-                $xml.="<".$key."><![CDATA[".$val."]]></".$key.">";
-        }
-        $xml.="</xml>";
-        return $xml;
-    }
-
-    //post https请求,CURLOPT_POSTFIELDS xml格式
-    function postXmlCurl($xml,$url,$second=30)
-    {
-        //初始化curl
-        $ch = curl_init();
-        //超时时间
-        curl_setopt($ch,CURLOPT_TIMEOUT,$second);
-        //这里设置代理,如果有的话
-        //curl_setopt($ch,CURLOPT_PROXY, '8.8.8.8');
-        //curl_setopt($ch,CURLOPT_PROXYPORT, 8080);
-        curl_setopt($ch,CURLOPT_URL, $url);
-        curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,FALSE);
-        curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,FALSE);
-        //设置header
-        curl_setopt($ch, CURLOPT_HEADER, FALSE);
-        //要求结果为字符串且输出到屏幕上
-        curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
-        //post提交方式
-        curl_setopt($ch, CURLOPT_POST, TRUE);
-        curl_setopt($ch, CURLOPT_POSTFIELDS, $xml);
-        //运行curl
-        $data = curl_exec($ch);
-        //返回结果
-        if($data)
-        {
-            curl_close($ch);
-            return $data;
-        }
-        else
-        {
-            $error = curl_errno($ch);
-            echo "curl出错,错误码:$error"."<br>";
-            echo "<a href='http://curl.haxx.se/libcurl/c/libcurl-errors.html'>错误原因查询</a></br>";
-            curl_close($ch);
-            return false;
-        }
-    }
-
-
-
-   //需要使用证书的请求
-    private function postXmlSSLCurl($xml,$url,$second=30)
-    {
-        $ch = curl_init();
-        //超时时间
-        curl_setopt($ch,CURLOPT_TIMEOUT,$second);
-        //这里设置代理,如果有的话
-        //curl_setopt($ch,CURLOPT_PROXY, '8.8.8.8');
-        //curl_setopt($ch,CURLOPT_PROXYPORT, 8080);
-        curl_setopt($ch,CURLOPT_URL, $url);
-        curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,FALSE);
-        curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,FALSE);
-        //设置header
-        curl_setopt($ch,CURLOPT_HEADER,FALSE);
-        //要求结果为字符串且输出到屏幕上
-        curl_setopt($ch,CURLOPT_RETURNTRANSFER,TRUE);
-        //设置证书
-        //使用证书:cert 与 key 分别属于两个.pem文件
-        //默认格式为PEM,可以注释
-        curl_setopt($ch,CURLOPT_SSLCERTTYPE,'PEM');
-        curl_setopt($ch,CURLOPT_SSLCERT, dirname(__DIR__) . '/wxcert/apiclient_cert.pem');
-        //默认格式为PEM,可以注释
-        curl_setopt($ch,CURLOPT_SSLKEYTYPE,'PEM');
-        curl_setopt($ch,CURLOPT_SSLKEY, dirname(__DIR__) . '/wxcert/apiclient_key.pem');
-        //post提交方式
-        curl_setopt($ch,CURLOPT_POST, true);
-        curl_setopt($ch,CURLOPT_POSTFIELDS,$xml);
-        $data = curl_exec($ch);
-        //返回结果
-        if($data){
-            curl_close($ch);
-            return $data;
-        }
-        else {
-            $error = curl_errno($ch);
-            echo "curl出错,错误码:$error"."<br>";
-            curl_close($ch);
-            return false;
-        }
-    }
-    /*
-        获取当前服务器的IP
-    */
-    function get_client_ip()
-    {
-        if ($_SERVER['REMOTE_ADDR']) {
-            $cip = $_SERVER['REMOTE_ADDR'];
-        } elseif (getenv("REMOTE_ADDR")) {
-            $cip = getenv("REMOTE_ADDR");
-        } elseif (getenv("HTTP_CLIENT_IP")) {
-            $cip = getenv("HTTP_CLIENT_IP");
-        } else {
-            $cip = "unknown";
-        }
-        return $cip;
-    }
-
-    //将数组转成uri字符串
-    function formatBizQueryParaMap($paraMap, $urlencode)
-    {
-        $buff = "";
-        ksort($paraMap);
-        foreach ($paraMap as $k => $v)
-        {
-            if($urlencode)
-            {
-                $v = urlencode($v);
-            }
-            $buff .= strtolower($k) . "=" . $v . "&";
-        }
-        $reqPar;
-        if (strlen($buff) > 0)
-        {
-            $reqPar = substr($buff, 0, strlen($buff)-1);
-        }
-        return $reqPar;
-    }
-
-    /**
-    xml转成数组
-     */
-//    function xmlstr_to_array($xmlstr) {
-//        $doc = new DOMDocument();
-//        $doc->loadXML($xmlstr);
-//        return $this->domnode_to_array($doc->documentElement);
-//    }
-    function domnode_to_array($node) {
-        $output = array();
-        switch ($node->nodeType) {
-            case XML_CDATA_SECTION_NODE:
-            case XML_TEXT_NODE:
-                $output = trim($node->textContent);
-                break;
-            case XML_ELEMENT_NODE:
-                for ($i=0, $m=$node->childNodes->length; $i<$m; $i++) {
-                    $child = $node->childNodes->item($i);
-                    $v = $this->domnode_to_array($child);
-                    if(isset($child->tagName)) {
-                        $t = $child->tagName;
-                        if(!isset($output[$t])) {
-                            $output[$t] = array();
-                        }
-                        $output[$t][] = $v;
-                    }
-                    elseif($v) {
-                        $output = (string) $v;
-                    }
-                }
-                if(is_array($output)) {
-                    if($node->attributes->length) {
-                        $a = array();
-                        foreach($node->attributes as $attrName => $attrNode) {
-                            $a[$attrName] = (string) $attrNode->value;
-                        }
-                        $output['@attributes'] = $a;
-                    }
-                    foreach ($output as $t => $v) {
-                        if(is_array($v) && count($v)==1 && $t!='@attributes') {
-                            $output[$t] = $v[0];
-                        }
-                    }
-                }
-                break;
-        }
-        return $output;
-    }
-//    public function xmltoarray( $xml )
-//    {
-//        $arr = $this->xml_to_array($xml);
-//        $key = array_keys($arr);
-//        return $arr[$key[0]];
-//    }
-
-    /**
-     * 	作用:将xml转为array
-     */
-    public function xmlToArray($xml)
-    {
-        //将XML转为array
-        $array_data = json_decode(json_encode(simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA)), true);
-        return $array_data;
-    }
-
-
-    public function xml_to_array( $xml )
-    {
-        $reg = "/<(\\w+)[^>]*?>([\\x00-\\xFF]*?)<\\/\\1>/";
-        if(preg_match_all($reg, $xml, $matches))
-        {
-            $count = count($matches[0]);
-            $arr = array();
-            for($i = 0; $i < $count; $i++)
-            {
-                $key = $matches[1][$i];
-                $val = $this->xml_to_array( $matches[2][$i] );  // 递归
-                if(array_key_exists($key, $arr))
-                {
-                    if(is_array($arr[$key]))
-                    {
-                        if(!array_key_exists(0,$arr[$key]))
-                        {
-                            $arr[$key] = array($arr[$key]);
-                        }
-                    }else{
-                        $arr[$key] = array($arr[$key]);
-                    }
-                    $arr[$key][] = $val;
-                }else{
-                    $arr[$key] = $val;
-                }
-            }
-            return $arr;
-        }else{
-            return $xml;
-        }
-    }
-
-}

+ 0 - 188
application/common/library/alipay/aop/AlipayMobilePublicMultiMediaClient.php

@@ -1,188 +0,0 @@
-<?php
-
-/**
- * 多媒体文件客户端
- * @author yikai.hu
- * @version $Id: AlipayMobilePublicMultiMediaClient.php, v 0.1 Aug 15, 2014 10:19:01 AM yikai.hu Exp $
- */
-
-include("AlipayMobilePublicMultiMediaExecute.php");
-
-class AlipayMobilePublicMultiMediaClient
-{
-    private $DEFAULT_CHARSET = 'UTF-8';
-    private $METHOD_POST = "POST";
-    private $METHOD_GET = "GET";
-    private $SIGN = 'sign'; //get name
-
-    private $timeout = 10;// 超时时间
-    private $serverUrl;
-    private $appId;
-    private $privateKey;
-    private $prodCode;
-    private $format = 'json'; //todo
-    private $sign_type = 'RSA'; //todo
-
-    private $charset;
-    private $apiVersion = "1.0";
-    private $apiMethodName = "alipay.mobile.public.multimedia.download";
-    private $media_id = "L21pZnMvVDFQV3hYWGJKWFhYYUNucHJYP3Q9YW13ZiZ4c2lnPTU0MzRhYjg1ZTZjNWJmZTMxZGJiNjIzNDdjMzFkNzkw575";
-    //此处写死的,实际开发中,请传入
-
-    private $connectTimeout = 3000;
-    private $readTimeout = 15000;
-
-    function __construct($serverUrl = '', $appId = '', $partner_private_key = '', $format = '', $charset = 'GBK')
-    {
-        $this->serverUrl = $serverUrl;
-        $this->appId = $appId;
-        $this->privateKey = $partner_private_key;
-        $this->format = $format;
-        $this->charset = $charset;
-    }
-
-    /**
-     * getContents 获取网址内容
-     * @param $request
-     * @return text | bin
-     */
-    public function getContents()
-    {
-        $datas = array(
-            "app_id" => $this->appId,
-            "method" => $this->METHOD_POST,
-            "sign_type" => $this->sign_type,
-            "version" => $this->apiVersion,
-            "timestamp" => date('Y-m-d H:i:s'),//yyyy-MM-dd HH:mm:ss
-            "biz_content" => '{"mediaId":"' . $this->media_id . '"}',
-            "charset" => $this->charset
-        );
-
-        //要提交的数据
-        $data_sign = $this->buildGetUrl($datas);
-
-        $post_data = $data_sign;
-        //初始化 curl
-        $ch = curl_init();
-        //设置目标服务器
-        curl_setopt($ch, CURLOPT_URL, $this->serverUrl);
-        curl_setopt($ch, CURLOPT_HEADER, TRUE);
-        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
-        //超时时间
-        curl_setopt($ch, CURLOPT_TIMEOUT, $this->timeout);
-
-        if ($this->METHOD_POST == 'POST') {
-            // post数据
-            curl_setopt($ch, CURLOPT_POST, 1);
-            // post的变量
-            curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);
-        }
-
-
-        $output = curl_exec($ch);
-        $httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
-        curl_close($ch);
-
-        echo $output;
-
-        $datas = explode("\r\n\r\n", $output, 2);
-        $header = $datas[0];
-
-        if ($httpCode == '200') {
-            $body = $datas[1];
-        } else {
-            $body = '';
-
-        }
-
-        return $this->execute($header, $body, $httpCode);
-    }
-
-    /**
-     *
-     * @param $request
-     * @return text | bin
-     */
-    public function execute($header = '', $body = '', $httpCode = '')
-    {
-        $exe = new AlipayMobilePublicMultiMediaExecute($header, $body, $httpCode);
-        return $exe;
-    }
-
-    public function buildGetUrl($query = array())
-    {
-        if (!is_array($query)) {
-            //exit;
-        }
-        //排序参数,
-        $data = $this->buildQuery($query);
-
-        // 私钥密码
-        $passphrase = '';
-        $key_width = 64;
-
-        //私钥
-        $privateKey = $this->privateKey;
-        $p_key = array();
-        //如果私钥是 1行
-        if (!stripos($privateKey, "\n")) {
-            $i = 0;
-            while ($key_str = substr($privateKey, $i * $key_width, $key_width)) {
-                $p_key[] = $key_str;
-                $i++;
-            }
-        } else {
-            //echo '一行?';
-        }
-        $privateKey = "-----BEGIN RSA PRIVATE KEY-----\n" . implode("\n", $p_key);
-        $privateKey = $privateKey . "\n-----END RSA PRIVATE KEY-----";
-
-        //私钥
-        $private_id = openssl_pkey_get_private($privateKey, $passphrase);
-
-        // 签名
-        $signature = '';
-
-        if ("RSA2" == $this->sign_type) {
-
-            openssl_sign($data, $signature, $private_id, OPENSSL_ALGO_SHA256);
-        } else {
-
-            openssl_sign($data, $signature, $private_id, OPENSSL_ALGO_SHA1);
-        }
-
-        openssl_free_key($private_id);
-
-        //加密后的内容通常含有特殊字符,需要编码转换下
-        $signature = base64_encode($signature);
-
-        $signature = urlencode($signature);
-
-        //$signature = 'XjUN6YM1Mc9HXebKMv7GTLy7gmyhktyOgKk2/Jf+cz4DtP6udkzTdpkjW2j/Z4ZSD7xD6CNYI1Spz4yS93HPT0a5X9LgFWYY8SaADqe+ArXg+FBSiTwUz49SE//Xd9+LEiIRsSFkbpkuiGoO6mqJmB7vXjlD5lx6qCM3nb41wb8=';
-
-        $out = $data . '&' . $this->SIGN . '=' . $signature;
-
-        return $out;
-    }
-
-    /*
-     * 查询参数排序 a-z
-     * */
-    public function buildQuery($query)
-    {
-        if (!$query) {
-            return null;
-        }
-        //将要 参数 排序
-        ksort($query);
-
-        //重新组装参数
-        $params = array();
-        foreach ($query as $key => $value) {
-            $params[] = $key . '=' . $value;
-        }
-        $data = implode('&', $params);
-        return $data;
-    }
-
-}

+ 0 - 115
application/common/library/alipay/aop/AlipayMobilePublicMultiMediaExecute.php

@@ -1,115 +0,0 @@
-<?php
-
-/**
- * 多媒体文件客户端
- * @author yuanwai.wang
- * @version $Id: AlipayMobilePublicMultiMediaExecute.php, v 0.1 Aug 15, 2014 10:19:01 AM yuanwai.wang Exp $
- */
-
-//namespace alipay\api ;
-
-
-class AlipayMobilePublicMultiMediaExecute
-{
-
-    private $code = 200;
-    private $msg = '';
-    private $body = '';
-    private $params = '';
-
-    private $fileSuffix = array(
-        "image/jpeg" => 'jpg', //+
-        "text/plain" => 'text'
-    );
-
-    /*
-     * @$header : 头部
-     * */
-    function __construct($header, $body, $httpCode)
-    {
-        $this->code = $httpCode;
-        $this->msg = '';
-        $this->params = $header;
-        $this->body = $body;
-    }
-
-    /**
-     *
-     * @return text | bin
-     */
-    public function getCode()
-    {
-        return $this->code;
-    }
-
-    /**
-     *
-     * @return text | bin
-     */
-    public function getMsg()
-    {
-        return $this->msg;
-    }
-
-    /**
-     *
-     * @return text | bin
-     */
-    public function getType()
-    {
-        $subject = $this->params;
-        $pattern = '/Content\-Type:([^;]+)/';
-        preg_match($pattern, $subject, $matches);
-        if ($matches) {
-            $type = $matches[1];
-        } else {
-            $type = 'application/download';
-        }
-
-        return str_replace(' ', '', $type);
-    }
-
-    /**
-     *
-     * @return text | bin
-     */
-    public function getContentLength()
-    {
-        $subject = $this->params;
-        $pattern = '/Content-Length:\s*([^\n]+)/';
-        preg_match($pattern, $subject, $matches);
-        return (int)(isset($matches[1]) ? $matches[1] : '');
-    }
-
-
-    public function getFileSuffix($fileType)
-    {
-        $type = isset($this->fileSuffix[$fileType]) ? $this->fileSuffix[$fileType] : 'text/plain';
-        if (!$type) {
-            $type = 'json';
-        }
-        return $type;
-    }
-
-
-    /**
-     *
-     * @return text | bin
-     */
-    public function getBody()
-    {
-        //header('Content-type: image/jpeg');
-        return $this->body;
-    }
-
-    /**
-     * 获取参数
-     * @return text | bin
-     */
-    public function getParams()
-    {
-        return $this->params;
-    }
-
-
-}

+ 0 - 1237
application/common/library/alipay/aop/AopCertClient.php

@@ -1,1237 +0,0 @@
-<?php
-
-require_once 'AopEncrypt.php';
-require_once 'AopCertification.php';
-require_once 'EncryptParseItem.php';
-require_once 'EncryptResponseData.php';
-require_once 'SignData.php';
-
-class AopCertClient
-{
-    //应用证书地址
-    public $appCertSN;
-
-    //支付宝公钥证书地址
-    public $alipayCertSN;
-
-    //支付宝根证书地址
-    public $alipayRootCertSN;
-
-    //支付宝根证书地址
-    public $alipayRootCertContent;
-
-    //是否校验支付宝公钥证书
-    public $isCheckAlipayPublicCert;
-
-    //应用ID
-    public $appId;
-
-    //私钥文件路径
-    public $rsaPrivateKeyFilePath;
-
-    //私钥值
-    public $rsaPrivateKey;
-
-    //网关
-    public $gatewayUrl = "https://openapi.alipay.com/gateway.do";
-    //返回数据格式
-    public $format = "json";
-
-    //api版本
-    public $apiVersion = "1.0";
-
-    // 表单提交字符集编码
-    public $postCharset = "UTF-8";
-
-    //使用文件读取文件格式,请只传递该值
-    public $alipayPublicKey = null;
-
-    //使用读取字符串格式,请只传递该值
-    public $alipayrsaPublicKey;
-
-    public $debugInfo = false;
-
-    //签名类型
-    public $signType = "RSA";
-
-    //加密密钥和类型
-    public $encryptKey;
-
-    public $encryptType = "AES";
-
-    protected $alipaySdkVersion = "alipay-sdk-php-2020-04-15";
-
-    private $fileCharset = "UTF-8";
-
-    private $RESPONSE_SUFFIX = "_response";
-
-    private $ERROR_RESPONSE = "error_response";
-
-    private $SIGN_NODE_NAME = "sign";
-
-    private $ALIPAY_CERT_SN = "alipay_cert_sn";
-
-
-    //加密XML节点名称
-    private $ENCRYPT_XML_NODE_NAME = "response_encrypted";
-
-    private $needEncrypt = false;
-
-    private $targetServiceUrl = "";
-
-    /**
-     * 从证书中提取序列号
-     * @param $cert
-     * @return string
-     */
-    public function getCertSN($certPath)
-    {
-        $cert = file_get_contents($certPath);
-        $ssl = openssl_x509_parse($cert);
-        $SN = md5(array2string(array_reverse($ssl['issuer'])) . $ssl['serialNumber']);
-        return $SN;
-    }
-
-    /**
-     * 提取根证书序列号
-     * @param $cert  根证书
-     * @return string|null
-     */
-    public function getRootCertSN($certPath)
-    {
-        $cert = file_get_contents($certPath);
-        $this->alipayRootCertContent = $cert;
-        $array = explode("-----END CERTIFICATE-----", $cert);
-        $SN = null;
-        for ($i = 0; $i < count($array) - 1; $i++) {
-            $ssl[$i] = openssl_x509_parse($array[$i] . "-----END CERTIFICATE-----");
-            if(strpos($ssl[$i]['serialNumber'],'0x') === 0){
-                $ssl[$i]['serialNumber'] = $this->hex2dec($ssl[$i]['serialNumber']);
-            }
-            if ($ssl[$i]['signatureTypeLN'] == "sha1WithRSAEncryption" || $ssl[$i]['signatureTypeLN'] == "sha256WithRSAEncryption") {
-                if ($SN == null) {
-                    $SN = md5(array2string(array_reverse($ssl[$i]['issuer'])) . $ssl[$i]['serialNumber']);
-                } else {
-
-                    $SN = $SN . "_" . md5(array2string(array_reverse($ssl[$i]['issuer'])) . $ssl[$i]['serialNumber']);
-                }
-            }
-        }
-        return $SN;
-    }
-
-    /**
-     * 0x转高精度数字
-     * @param $hex
-     * @return int|string
-     */
-    function hex2dec($hex)
-    {
-        $dec = 0;
-        $len = strlen($hex);
-        for ($i = 1; $i <= $len; $i++) {
-            $dec = bcadd($dec, bcmul(strval(hexdec($hex[$i - 1])), bcpow('16', strval($len - $i))));
-        }
-        return round($dec,0);
-    }
-
-    /**
-     * 从证书中提取公钥
-     * @param $cert
-     * @return mixed
-     */
-    public function getPublicKey($certPath)
-    {
-        $cert = file_get_contents($certPath);
-        $pkey = openssl_pkey_get_public($cert);
-        $keyData = openssl_pkey_get_details($pkey);
-        $public_key = str_replace('-----BEGIN PUBLIC KEY-----', '', $keyData['key']);
-        $public_key = trim(str_replace('-----END PUBLIC KEY-----', '', $public_key));
-        return $public_key;
-    }
-
-
-    /**
-     * 验证签名
-     * 在使用本方法前,必须初始化AopCertClient且传入公钥参数。
-     * 公钥是否是读取字符串还是读取文件,是根据初始化传入的值判断的。
-     *
-     * @param $params
-     * @param $rsaPublicKeyFilePath
-     * @param string $signType
-     * @return bool
-     */
-    public function rsaCheckV1($params, $rsaPublicKeyFilePath,$signType='RSA') {
-        $sign = $params['sign'];
-        unset($params['sign']);
-        unset($params['sign_type']);
-        return $this->verify($this->getCheckSignContent($params), $sign, $rsaPublicKeyFilePath,$signType);
-    }
-
-    /**
-     * 验证签名
-     * 在使用本方法前,必须初始化AopCertClient且传入公钥参数。
-     * 公钥是否是读取字符串还是读取文件,是根据初始化传入的值判断的。
-     *
-     * @param $params
-     * @param $rsaPublicKeyFilePath
-     * @param string $signType
-     * @return bool
-     */
-    public function rsaCheckV2($params, $rsaPublicKeyFilePath, $signType='RSA') {
-        $sign = $params['sign'];
-        unset($params['sign']);
-        unset($params['sign_type']);
-        return $this->verify($this->getCheckSignContent($params), $sign, $rsaPublicKeyFilePath, $signType);
-    }
-
-
-    function getCheckSignContent($params)
-    {
-        ksort($params);
-
-        $stringToBeSigned = "";
-        $i = 0;
-        foreach ($params as $k => $v) {
-            // 转换成目标字符集
-            $v = $this->characet($v, $this->postCharset);
-
-            if ($i == 0) {
-                $stringToBeSigned .= "$k" . "=" . "$v";
-            } else {
-                $stringToBeSigned .= "&" . "$k" . "=" . "$v";
-            }
-            $i++;
-        }
-
-        unset ($k, $v);
-        return $stringToBeSigned;
-    }
-
-
-    /**
-     *  在使用本方法前,必须初始化AopCertClient且传入公私钥参数。
-     *  公钥是否是读取字符串还是读取文件,是根据初始化传入的值判断的。
-     **/
-    public function checkSignAndDecrypt($params, $rsaPublicKeyPem, $rsaPrivateKeyPem, $isCheckSign, $isDecrypt, $signType='RSA') {
-        $charset = $params['charset'];
-        $bizContent = $params['biz_content'];
-        if ($isCheckSign) {
-            if (!$this->rsaCheckV2($params, $rsaPublicKeyPem, $signType)) {
-                echo "<br/>checkSign failure<br/>";
-                exit;
-            }
-        }
-        if ($isDecrypt) {
-            return $this->rsaDecrypt($bizContent, $rsaPrivateKeyPem, $charset);
-        }
-
-        return $bizContent;
-    }
-
-    /**
-     *  在使用本方法前,必须初始化AopCertClient且传入公私钥参数。
-     *  公钥是否是读取字符串还是读取文件,是根据初始化传入的值判断的。
-     **/
-    public function encryptAndSign($bizContent, $rsaPublicKeyPem, $rsaPrivateKeyPem, $charset, $isEncrypt, $isSign, $signType='RSA') {
-        // 加密,并签名
-        if ($isEncrypt && $isSign) {
-            $encrypted = $this->rsaEncrypt($bizContent, $rsaPublicKeyPem, $charset);
-            $sign = $this->sign($encrypted, $signType);
-            $response = "<?xml version=\"1.0\" encoding=\"$charset\"?><alipay><response>$encrypted</response><encryption_type>RSA</encryption_type><sign>$sign</sign><sign_type>$signType</sign_type></alipay>";
-            return $response;
-        }
-        // 加密,不签名
-        if ($isEncrypt && (!$isSign)) {
-            $encrypted = $this->rsaEncrypt($bizContent, $rsaPublicKeyPem, $charset);
-            $response = "<?xml version=\"1.0\" encoding=\"$charset\"?><alipay><response>$encrypted</response><encryption_type>$signType</encryption_type></alipay>";
-            return $response;
-        }
-        // 不加密,但签名
-        if ((!$isEncrypt) && $isSign) {
-            $sign = $this->sign($bizContent, $signType);
-            $response = "<?xml version=\"1.0\" encoding=\"$charset\"?><alipay><response>$bizContent</response><sign>$sign</sign><sign_type>$signType</sign_type></alipay>";
-            return $response;
-        }
-        // 不加密,不签名
-        $response = "<?xml version=\"1.0\" encoding=\"$charset\"?>$bizContent";
-        return $response;
-    }
-
-    /**
-     *  在使用本方法前,必须初始化AopCertClient且传入公私钥参数。
-     **/
-    public function rsaEncrypt($data, $rsaPublicKeyFilePath, $charset) {
-        if($this->checkEmpty($this->alipayPublicKey)){
-            //读取字符串
-            $pubKey= $this->alipayrsaPublicKey;
-            $res = "-----BEGIN PUBLIC KEY-----\n" .
-                wordwrap($pubKey, 64, "\n", true) .
-                "\n-----END PUBLIC KEY-----";
-        }else {
-            //读取公钥文件
-            $pubKey = file_get_contents($rsaPublicKeyFilePath);
-            //转换为openssl格式密钥
-            $res = openssl_get_publickey($pubKey);
-        }
-
-        ($res) or die('支付宝RSA公钥错误。请检查公钥文件格式是否正确');
-        $blocks = $this->splitCN($data, 0, 30, $charset);
-        $chrtext  = null;
-        $encodes  = array();
-        foreach ($blocks as $n => $block) {
-            if (!openssl_public_encrypt($block, $chrtext , $res)) {
-                echo "<br/>" . openssl_error_string() . "<br/>";
-            }
-            $encodes[] = $chrtext ;
-        }
-        $chrtext = implode(",", $encodes);
-
-        return base64_encode($chrtext);
-    }
-
-    /**
-     *  在使用本方法前,必须初始化AopCertClient且传入公私钥参数。
-     *  公钥是否是读取字符串还是读取文件,是根据初始化传入的值判断的。
-     **/
-    public function rsaDecrypt($data, $rsaPrivateKeyPem, $charset) {
-
-        if($this->checkEmpty($this->rsaPrivateKeyFilePath)){
-            //读字符串
-            $priKey=$this->rsaPrivateKey;
-            $res = "-----BEGIN RSA PRIVATE KEY-----\n" .
-                wordwrap($priKey, 64, "\n", true) .
-                "\n-----END RSA PRIVATE KEY-----";
-        }else {
-            $priKey = file_get_contents($this->rsaPrivateKeyFilePath);
-            $res = openssl_get_privatekey($priKey);
-        }
-        ($res) or die('您使用的私钥格式错误,请检查RSA私钥配置');
-        //转换为openssl格式密钥
-        $decodes = explode(',', $data);
-        $strnull = "";
-        $dcyCont = "";
-        foreach ($decodes as $n => $decode) {
-            if (!openssl_private_decrypt($decode, $dcyCont, $res)) {
-                echo "<br/>" . openssl_error_string() . "<br/>";
-            }
-            $strnull .= $dcyCont;
-        }
-        return $strnull;
-    }
-
-    function splitCN($cont, $n = 0, $subnum, $charset) {
-        //$len = strlen($cont) / 3;
-        $arrr = array();
-        for ($i = $n; $i < strlen($cont); $i += $subnum) {
-            $res = $this->subCNchar($cont, $i, $subnum, $charset);
-            if (!empty ($res)) {
-                $arrr[] = $res;
-            }
-        }
-
-        return $arrr;
-    }
-
-    function subCNchar($str, $start = 0, $length, $charset = "gbk") {
-        if (strlen($str) <= $length) {
-            return $str;
-        }
-        $re['utf-8'] = "/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|[\xe0-\xef][\x80-\xbf]{2}|[\xf0-\xff][\x80-\xbf]{3}/";
-        $re['gb2312'] = "/[\x01-\x7f]|[\xb0-\xf7][\xa0-\xfe]/";
-        $re['gbk'] = "/[\x01-\x7f]|[\x81-\xfe][\x40-\xfe]/";
-        $re['big5'] = "/[\x01-\x7f]|[\x81-\xfe]([\x40-\x7e]|\xa1-\xfe])/";
-        preg_match_all($re[$charset], $str, $match);
-        $slice = join("", array_slice($match[0], $start, $length));
-        return $slice;
-    }
-
-    /**
-     * 生成用于调用收银台SDK的字符串
-     * @param $request SDK接口的请求参数对象
-     * @param $appAuthToken 三方应用授权token
-     * @return string
-     */
-    public function sdkExecute($request, $appAuthToken = null) {
-
-        $this->setupCharsets($request);
-        $params['app_id'] = $this->appId;
-        $params['method'] = $request->getApiMethodName();
-        $params['format'] = $this->format;
-        $params['sign_type'] = $this->signType;
-        $params['timestamp'] = date("Y-m-d H:i:s");
-        $params['alipay_sdk'] = $this->alipaySdkVersion;
-        $params['charset'] = $this->postCharset;
-        $version = $request->getApiVersion();
-        $params['version'] = $this->checkEmpty($version) ? $this->apiVersion : $version;
-        $params["app_cert_sn"] = $this->appCertSN;
-        $params["alipay_root_cert_sn"] = $this->alipayRootCertSN;
-        if ($notify_url = $request->getNotifyUrl()) {
-            $params['notify_url'] = $notify_url;
-        }
-        $params['app_auth_token'] = $appAuthToken;
-        $dict = $request->getApiParas();
-        $params['biz_content'] = $dict['biz_content'];
-        ksort($params);
-        $params['sign'] = $this->generateSign($params, $this->signType);
-        foreach ($params as &$value) {
-            $value = $this->characet($value, $params['charset']);
-        }
-        return http_build_query($params);
-    }
-
-
-    /**
-     * 页面提交执行方法
-     * @param $request 跳转类接口的request
-     * @param string $httpmethod 提交方式,两个值可选:post、get;
-     * @param null $appAuthToken 三方应用授权token
-     * @return 构建好的、签名后的最终跳转URL(GET)或String形式的form(POST)
-     * @throws Exception
-     */
-    public function pageExecute($request, $httpmethod = "POST", $appAuthToken = null) {
-
-        $this->setupCharsets($request);
-        if (strcasecmp($this->fileCharset, $this->postCharset)) {
-            throw new Exception("文件编码:[" . $this->fileCharset . "] 与表单提交编码:[" . $this->postCharset . "]两者不一致!");
-        }
-        $iv=null;
-        if(!$this->checkEmpty($request->getApiVersion())){
-            $iv=$request->getApiVersion();
-        }else{
-            $iv=$this->apiVersion;
-        }
-
-        //组装系统参数
-        $sysParams["app_id"] = $this->appId;
-        $sysParams["version"] = $iv;
-        $sysParams["format"] = $this->format;
-        $sysParams["sign_type"] = $this->signType;
-        $sysParams["method"] = $request->getApiMethodName();
-        $sysParams["timestamp"] = date("Y-m-d H:i:s");
-        $sysParams["alipay_sdk"] = $this->alipaySdkVersion;
-        $sysParams["terminal_type"] = $request->getTerminalType();
-        $sysParams["terminal_info"] = $request->getTerminalInfo();
-        $sysParams["prod_code"] = $request->getProdCode();
-        $sysParams["notify_url"] = $request->getNotifyUrl();
-        $sysParams["return_url"] = $request->getReturnUrl();
-        $sysParams["charset"] = $this->postCharset;
-        $sysParams["app_auth_token"] = $appAuthToken;
-        $sysParams["app_cert_sn"] = $this->appCertSN;
-        $sysParams["alipay_root_cert_sn"] = $this->alipayRootCertSN;
-
-        //获取业务参数
-        $apiParams = $request->getApiParas();
-        if (method_exists($request,"getNeedEncrypt") &&$request->getNeedEncrypt()){
-            $sysParams["encrypt_type"] = $this->encryptType;
-            if ($this->checkEmpty($apiParams['biz_content'])) {
-                throw new Exception(" api request Fail! The reason : encrypt request is not supperted!");
-            }
-            if ($this->checkEmpty($this->encryptKey) || $this->checkEmpty($this->encryptType)) {
-                throw new Exception(" encryptType and encryptKey must not null! ");
-            }
-            if ("AES" != $this->encryptType) {
-                throw new Exception("加密类型只支持AES");
-            }
-            // 执行加密
-            $enCryptContent = encrypt($apiParams['biz_content'], $this->encryptKey);
-            $apiParams['biz_content'] = $enCryptContent;
-        }
-        $totalParams = array_merge($apiParams, $sysParams);
-        //待签名字符串
-        $preSignStr = $this->getSignContent($totalParams);
-        //签名
-        $totalParams["sign"] = $this->generateSign($totalParams, $this->signType);
-
-        if ("GET" == strtoupper($httpmethod)) {
-            //value做urlencode
-            $preString=$this->getSignContentUrlencode($totalParams);
-            //拼接GET请求串
-            $requestUrl = $this->gatewayUrl."?".$preString;
-            return $requestUrl;
-        } else {
-            //拼接表单字符串
-            return $this->buildRequestForm($totalParams);
-        }
-    }
-
-    //此方法对value做urlencode
-    public function getSignContentUrlencode($params) {
-        ksort($params);
-        $stringToBeSigned = "";
-        $i = 0;
-        foreach ($params as $k => $v) {
-            if (false === $this->checkEmpty($v) && "@" != substr($v, 0, 1)) {
-
-                // 转换成目标字符集
-                $v = $this->characet($v, $this->postCharset);
-
-                if ($i == 0) {
-                    $stringToBeSigned .= "$k" . "=" . urlencode($v);
-                } else {
-                    $stringToBeSigned .= "&" . "$k" . "=" . urlencode($v);
-                }
-                $i++;
-            }
-        }
-        unset ($k, $v);
-        return $stringToBeSigned;
-    }
-
-
-    /**
-     * 建立请求,以表单HTML形式构造(默认)
-     * @param $para_temp 请求参数数组
-     * @return 提交表单HTML文本
-     */
-    protected function buildRequestForm($para_temp) {
-        $sHtml = "<form id='alipaysubmit' name='alipaysubmit' action='".$this->gatewayUrl."?charset=".trim($this->postCharset)."' method='POST'>";
-        while (list ($key, $val) = $this->fun_adm_each($para_temp)) {
-            if (false === $this->checkEmpty($val)) {
-                //$val = $this->characet($val, $this->postCharset);
-                $val = str_replace("'","&apos;",$val);
-                //$val = str_replace("\"","&quot;",$val);
-                $sHtml.= "<input type='hidden' name='".$key."' value='".$val."'/>";
-            }
-        }
-        //submit按钮控件请不要含有name属性
-        $sHtml = $sHtml."<input type='submit' value='ok' style='display:none;''></form>";
-        $sHtml = $sHtml."<script>document.forms['alipaysubmit'].submit();</script>";
-        return $sHtml;
-    }
-
-    protected function fun_adm_each(&$array)
-    {
-        $res = array();
-        $key = key($array);
-        if ($key !== null) {
-            next($array);
-            $res[1] = $res['value'] = $array[$key];
-            $res[0] = $res['key'] = $key;
-        } else {
-            $res = false;
-        }
-        return $res;
-    }
-
-    public function execute($request, $authToken = null, $appInfoAuthtoken = null,$targetAppId = null) {
-        $this->setupCharsets($request);
-        //如果两者编码不一致,会出现签名验签或者乱码
-        if (strcasecmp($this->fileCharset, $this->postCharset)) {
-            throw new Exception("文件编码:[" . $this->fileCharset . "] 与表单提交编码:[" . $this->postCharset . "]两者不一致!");
-        }
-        $iv = null;
-        if (!$this->checkEmpty($request->getApiVersion())) {
-            $iv = $request->getApiVersion();
-        } else {
-            $iv = $this->apiVersion;
-        }
-        //组装系统参数
-        $sysParams["app_id"] = $this->appId;
-        $sysParams["version"] = $iv;
-        $sysParams["format"] = $this->format;
-        $sysParams["sign_type"] = $this->signType;
-        $sysParams["method"] = $request->getApiMethodName();
-        $sysParams["timestamp"] = date("Y-m-d H:i:s");
-        $sysParams["auth_token"] = $authToken;
-        $sysParams["alipay_sdk"] = $this->alipaySdkVersion;
-        $sysParams["terminal_type"] = $request->getTerminalType();
-        $sysParams["terminal_info"] = $request->getTerminalInfo();
-        $sysParams["prod_code"] = $request->getProdCode();
-        $sysParams["notify_url"] = $request->getNotifyUrl();
-        $sysParams["charset"] = $this->postCharset;
-        $sysParams["app_auth_token"] = $appInfoAuthtoken;
-        $sysParams["app_cert_sn"] = $this->appCertSN;
-        $sysParams["alipay_root_cert_sn"] = $this->alipayRootCertSN;
-        $sysParams["target_app_id"] = $targetAppId;
-        if(!$this->checkEmpty($this->targetServiceUrl)){
-            $sysParams["ws_service_url"] = $this->targetServiceUrl;
-        }
-
-        //获取业务参数
-        $apiParams = $request->getApiParas();
-
-        if (method_exists($request,"getNeedEncrypt") && $request->getNeedEncrypt()){
-            $sysParams["encrypt_type"] = $this->encryptType;
-            if ($this->checkEmpty($apiParams['biz_content'])) {
-                throw new Exception(" api request Fail! The reason : encrypt request is not supperted!");
-            }
-            if ($this->checkEmpty($this->encryptKey) || $this->checkEmpty($this->encryptType)) {
-                throw new Exception(" encryptType and encryptKey must not null! ");
-            }
-            if ("AES" != $this->encryptType) {
-                throw new Exception("加密类型只支持AES");
-            }
-            // 执行加密
-            $enCryptContent = encrypt($apiParams['biz_content'], $this->encryptKey);
-            $apiParams['biz_content'] = $enCryptContent;
-        }
-
-        //签名
-        $sysParams["sign"] = $this->generateSign(array_merge($apiParams, $sysParams), $this->signType);
-
-        //系统参数放入GET请求串
-        $requestUrl = $this->gatewayUrl . "?";
-        foreach ($sysParams as $sysParamKey => $sysParamValue) {
-            $requestUrl .= "$sysParamKey=" . urlencode($this->characet($sysParamValue, $this->postCharset)) . "&";
-        }
-        $requestUrl = substr($requestUrl, 0, -1);
-
-        //发起HTTP请求
-        try {
-            $resp = $this->curl($requestUrl, $apiParams);
-        } catch (Exception $e) {
-            $this->logCommunicationError($sysParams["method"], $requestUrl, "HTTP_ERROR_" . $e->getCode(), $e->getMessage());
-            return false;
-        }
-
-        //解析AOP返回结果
-        $respWellFormed = false;
-
-        // 将返回结果转换本地文件编码
-        $r = iconv($this->postCharset, $this->fileCharset . "//IGNORE", $resp);
-        $signData = null;
-
-        if ("json" == $this->format) {
-            $respObject = json_decode($r);
-            if (null !== $respObject) {
-                $respWellFormed = true;
-                $signData = $this->parserJSONSignData($request, $resp, $respObject);
-            }
-        } else if ("xml" == $this->format) {
-            $disableLibxmlEntityLoader = libxml_disable_entity_loader(true);
-            $respObject = @ simplexml_load_string($resp);
-            if (false !== $respObject) {
-                $respWellFormed = true;
-                $signData = $this->parserXMLSignData($request, $resp);
-            }
-            libxml_disable_entity_loader($disableLibxmlEntityLoader);
-        }
-
-        //返回的HTTP文本不是标准JSON或者XML,记下错误日志
-        if (false === $respWellFormed) {
-            $this->logCommunicationError($sysParams["method"], $requestUrl, "HTTP_RESPONSE_NOT_WELL_FORMED", $resp);
-            return false;
-        }
-
-        // 验签
-        $this->checkResponseSign($request, $signData, $resp, $respObject);
-
-        // 解密
-        if (method_exists($request,"getNeedEncrypt") &&$request->getNeedEncrypt()){
-
-            if ("json" == $this->format) {
-                $resp = $this->encryptJSONSignSource($request, $resp);
-                // 将返回结果转换本地文件编码
-                $r = iconv($this->postCharset, $this->fileCharset . "//IGNORE", $resp);
-                $respObject = json_decode($r);
-            }else{
-                $resp = $this->encryptXMLSignSource($request, $resp);
-                $r = iconv($this->postCharset, $this->fileCharset . "//IGNORE", $resp);
-                $disableLibxmlEntityLoader = libxml_disable_entity_loader(true);
-                $respObject = @ simplexml_load_string($r);
-                libxml_disable_entity_loader($disableLibxmlEntityLoader);
-            }
-        }
-        return $respObject;
-    }
-
-
-    /**
-     * 设置编码格式
-     * @param $request
-     */
-    private function setupCharsets($request) {
-        if ($this->checkEmpty($this->postCharset)) {
-            $this->postCharset = 'UTF-8';
-        }
-        $str = preg_match('/[\x80-\xff]/', $this->appId) ? $this->appId : print_r($request, true);
-        $this->fileCharset = mb_detect_encoding($str, "UTF-8, GBK") == 'UTF-8' ? 'UTF-8' : 'GBK';
-    }
-
-    /**
-     * 校验$value是否非空
-     *  if not set ,return true;
-     *    if is null , return true;
-     **/
-    protected function checkEmpty($value) {
-        if (!isset($value))
-            return true;
-        if ($value === null)
-            return true;
-        if (trim($value) === "")
-            return true;
-
-        return false;
-    }
-
-    /**
-     * 加签
-     * @param $params
-     * @param string $signType
-     * @return mixed
-     */
-    public function generateSign($params, $signType = "RSA") {
-        return $this->sign($this->getSignContent($params), $signType);
-    }
-
-    public function rsaSign($params, $signType = "RSA") {
-        return $this->sign($this->getSignContent($params), $signType);
-    }
-
-    protected function sign($data, $signType = "RSA") {
-        if($this->checkEmpty($this->rsaPrivateKeyFilePath)){
-            $priKey=$this->rsaPrivateKey;
-            $res = "-----BEGIN RSA PRIVATE KEY-----\n" .
-                wordwrap($priKey, 64, "\n", true) .
-                "\n-----END RSA PRIVATE KEY-----";
-        }else {
-            $priKey = file_get_contents($this->rsaPrivateKeyFilePath);
-            $res = openssl_get_privatekey($priKey);
-        }
-
-        ($res) or die('您使用的私钥格式错误,请检查RSA私钥配置');
-
-        if ("RSA2" == $signType) {
-            openssl_sign($data, $sign, $res, OPENSSL_ALGO_SHA256);
-        } else {
-            openssl_sign($data, $sign, $res);
-        }
-
-        if(!$this->checkEmpty($this->rsaPrivateKeyFilePath)){
-            openssl_free_key($res);
-        }
-        $sign = base64_encode($sign);
-        return $sign;
-    }
-
-    public function getSignContent($params) {
-        ksort($params);
-
-        $stringToBeSigned = "";
-        $i = 0;
-        foreach ($params as $k => $v) {
-            if (false === $this->checkEmpty($v) && "@" != substr($v, 0, 1)) {
-
-                // 转换成目标字符集
-                $v = $this->characet($v, $this->postCharset);
-
-                if ($i == 0) {
-                    $stringToBeSigned .= "$k" . "=" . "$v";
-                } else {
-                    $stringToBeSigned .= "&" . "$k" . "=" . "$v";
-                }
-                $i++;
-            }
-        }
-        unset ($k, $v);
-        return $stringToBeSigned;
-    }
-
-
-    /**
-     * RSA单独签名方法,未做字符串处理,字符串处理见getSignContent()
-     * @param $data 待签名字符串
-     * @param $privatekey 商户私钥,根据keyfromfile来判断是读取字符串还是读取文件,false:填写私钥字符串去回车和空格 true:填写私钥文件路径
-     * @param $signType 签名方式,RSA:SHA1     RSA2:SHA256
-     * @param $keyfromfile 私钥获取方式,读取字符串还是读文件
-     * @return string
-     */
-    public function alonersaSign($data,$privatekey,$signType = "RSA",$keyfromfile=false) {
-        if(!$keyfromfile){
-            $priKey=$privatekey;
-            $res = "-----BEGIN RSA PRIVATE KEY-----\n" .
-                wordwrap($priKey, 64, "\n", true) .
-                "\n-----END RSA PRIVATE KEY-----";
-        }
-        else{
-            $priKey = file_get_contents($privatekey);
-            $res = openssl_get_privatekey($priKey);
-        }
-        ($res) or die('您使用的私钥格式错误,请检查RSA私钥配置');
-        if ("RSA2" == $signType) {
-            openssl_sign($data, $sign, $res, OPENSSL_ALGO_SHA256);
-        } else {
-            openssl_sign($data, $sign, $res);
-        }
-        if($keyfromfile){
-            openssl_free_key($res);
-        }
-        $sign = base64_encode($sign);
-        return $sign;
-    }
-
-    /**
-     * 转换字符集编码
-     * @param $data
-     * @param $targetCharset
-     * @return string
-     */
-    function characet($data, $targetCharset) {
-
-        if (!empty($data)) {
-            $fileType = $this->fileCharset;
-            if (strcasecmp($fileType, $targetCharset) != 0) {
-                $data = mb_convert_encoding($data, $targetCharset, $fileType);
-            }
-        }
-        return $data;
-    }
-
-    /**
-     * 发送curl请求
-     * @param $url
-     * @param null $postFields
-     * @return bool|string
-     * @throws Exception
-     */
-    protected function curl($url, $postFields = null) {
-        $ch = curl_init();
-        curl_setopt($ch, CURLOPT_URL, $url);
-        curl_setopt($ch, CURLOPT_FAILONERROR, false);
-        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
-        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, true);
-        $postBodyString = "";
-        $encodeArray = Array();
-        $postMultipart = false;
-
-        if (is_array($postFields) && 0 < count($postFields)) {
-            foreach ($postFields as $k => $v) {
-                if ("@" != substr($v, 0, 1)) //判断是不是文件上传
-                {
-                    $postBodyString .= "$k=" . urlencode($this->characet($v, $this->postCharset)) . "&";
-                    $encodeArray[$k] = $this->characet($v, $this->postCharset);
-                } else //文件上传用multipart/form-data,否则用www-form-urlencoded
-                {
-                    $postMultipart = true;
-                    $encodeArray[$k] = new \CURLFile(substr($v, 1));
-                }
-            }
-            unset ($k, $v);
-            curl_setopt($ch, CURLOPT_POST, true);
-            if ($postMultipart) {
-                curl_setopt($ch, CURLOPT_POSTFIELDS, $encodeArray);
-            } else {
-                curl_setopt($ch, CURLOPT_POSTFIELDS, substr($postBodyString, 0, -1));
-            }
-        }
-
-        if (!$postMultipart) {
-            $headers = array('content-type: application/x-www-form-urlencoded;charset=' . $this->postCharset);
-            curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
-        }
-        curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
-        $reponse = curl_exec($ch);
-        if (curl_errno($ch)) {
-            throw new Exception(curl_error($ch), 0);
-        } else {
-            $httpStatusCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
-            if (200 !== $httpStatusCode) {
-                throw new Exception($reponse, $httpStatusCode);
-            }
-        }
-        curl_close($ch);
-        return $reponse;
-    }
-
-    protected function getMillisecond() {
-        list($s1, $s2) = explode(' ', microtime());
-        return (float)sprintf('%.0f', (floatval($s1) + floatval($s2)) * 1000);
-    }
-
-    /**
-     * 打印日志信息
-     * @param $apiName
-     * @param $requestUrl
-     * @param $errorCode
-     * @param $responseTxt
-     */
-    protected function logCommunicationError($apiName, $requestUrl, $errorCode, $responseTxt) {
-        $logData = array(
-            date("Y-m-d H:i:s"),
-            $apiName,
-            $this->appId,
-            PHP_OS,
-            $this->alipaySdkVersion,
-            $requestUrl,
-            $errorCode,
-            str_replace("\n", "", $responseTxt)
-        );
-        echo json_encode($logData);
-    }
-
-    /**
-     * Json格式签名内容
-     * @param $request
-     * @param $responseContent
-     * @param $responseJSON
-     * @return SignData
-     */
-    function parserJSONSignData($request, $responseContent, $responseJSON) {
-        $signData = new SignData();
-        $signData->sign = $this->parserJSONSign($responseJSON);
-        $signData->signSourceData = $this->parserJSONSignSource($request, $responseContent);
-        return $signData;
-    }
-
-    function parserJSONSign($responseJSon) {
-        return $responseJSon->sign;
-    }
-
-    function parserJSONSignSource($request, $responseContent) {
-        $apiName = $request->getApiMethodName();
-        $rootNodeName = str_replace(".", "_", $apiName) . $this->RESPONSE_SUFFIX;
-        $rootIndex = strpos($responseContent, $rootNodeName);
-        $errorIndex = strpos($responseContent, $this->ERROR_RESPONSE);
-        if ($rootIndex > 0) {
-            return $this->parserJSONSource($responseContent, $rootNodeName, $rootIndex);
-        } else if ($errorIndex > 0) {
-            return $this->parserJSONSource($responseContent, $this->ERROR_RESPONSE, $errorIndex);
-        } else {
-            return null;
-        }
-    }
-
-    function parserJSONSource($responseContent, $nodeName, $nodeIndex) {
-        $signDataStartIndex = $nodeIndex + strlen($nodeName) + 2;
-        if(strrpos($responseContent, $this->ALIPAY_CERT_SN)){
-            $signIndex = strrpos($responseContent, "\"" . $this->ALIPAY_CERT_SN . "\"");
-        }else{
-            $signIndex = strrpos($responseContent, "\"" . $this->SIGN_NODE_NAME . "\"");
-        }
-        // 签名前-逗号
-        $signDataEndIndex = $signIndex - 1;
-        $indexLen = $signDataEndIndex - $signDataStartIndex;
-        if ($indexLen < 0) {
-            return null;
-        }
-        return substr($responseContent, $signDataStartIndex, $indexLen);
-    }
-
-    /**
-     * XML格式签名内容
-     * @param $request
-     * @param $responseContent
-     * @return SignData
-     */
-    function parserXMLSignData($request, $responseContent) {
-        $signData = new SignData();
-        $signData->sign = $this->parserXMLSign($responseContent);
-        $signData->signSourceData = $this->parserXMLSignSource($request, $responseContent);
-        return $signData;
-    }
-
-    function parserXMLSign($responseContent) {
-        if(strrpos($responseContent, $this->ALIPAY_CERT_SN)){
-            $signNodeName = "<" . $this->ALIPAY_CERT_SN . ">";
-            $signEndNodeName = "</" . $this->ALIPAY_CERT_SN . ">";
-        }else{
-            $signNodeName = "<" . $this->SIGN_NODE_NAME . ">";
-            $signEndNodeName = "</" . $this->SIGN_NODE_NAME . ">";
-        }
-
-        $indexOfSignNode = strpos($responseContent, $signNodeName);
-        $indexOfSignEndNode = strpos($responseContent, $signEndNodeName);
-        if ($indexOfSignNode < 0 || $indexOfSignEndNode < 0) {
-            return null;
-        }
-        $nodeIndex = ($indexOfSignNode + strlen($signNodeName));
-        $indexLen = $indexOfSignEndNode - $nodeIndex;
-        if ($indexLen < 0) {
-            return null;
-        }
-        // 签名
-        return substr($responseContent, $nodeIndex, $indexLen);
-    }
-
-    function parserXMLSignSource($request, $responseContent) {
-        $apiName = $request->getApiMethodName();
-        $rootNodeName = str_replace(".", "_", $apiName) . $this->RESPONSE_SUFFIX;
-        $rootIndex = strpos($responseContent, $rootNodeName);
-        $errorIndex = strpos($responseContent, $this->ERROR_RESPONSE);
-        if ($rootIndex > 0) {
-            return $this->parserXMLSource($responseContent, $rootNodeName, $rootIndex);
-        } else if ($errorIndex > 0) {
-            return $this->parserXMLSource($responseContent, $this->ERROR_RESPONSE, $errorIndex);
-        } else {
-            return null;
-        }
-    }
-
-
-    function parserXMLSource($responseContent, $nodeName, $nodeIndex) {
-        $signDataStartIndex = $nodeIndex + strlen($nodeName) + 1;
-        if(strrpos($responseContent, $this->ALIPAY_CERT_SN)){
-            $signIndex = strrpos($responseContent, "<" . $this->ALIPAY_CERT_SN . ">");
-        }else{
-            $signIndex = strrpos($responseContent, "<" . $this->SIGN_NODE_NAME . ">");
-        }
-
-        // 签名前-逗号
-        $signDataEndIndex = $signIndex - 1;
-        $indexLen = $signDataEndIndex - $signDataStartIndex + 1;
-
-        if ($indexLen < 0) {
-            return null;
-        }
-        return substr($responseContent, $signDataStartIndex, $indexLen);
-    }
-
-
-    /**
-     * 验签
-     * @param $request
-     * @param $signData
-     * @param $resp
-     * @param $respObject
-     * @throws Exception
-     */
-    public function checkResponseSign($request, $signData, $resp, $respObject) {
-        if (!$this->checkEmpty($this->alipayPublicKey) || !$this->checkEmpty($this->alipayrsaPublicKey)) {
-            if ($signData == null || $this->checkEmpty($signData->sign) || $this->checkEmpty($signData->signSourceData)) {
-                throw new Exception(" check sign Fail! The reason : signData is Empty");
-            }
-            // 获取结果sub_code
-            $responseSubCode = $this->parserResponseSubCode($request, $resp, $respObject, $this->format);
-            if (!$this->checkEmpty($responseSubCode) || ($this->checkEmpty($responseSubCode) && !$this->checkEmpty($signData->sign))) {
-                $checkResult = $this->verify($signData->signSourceData, $signData->sign, $this->alipayPublicKey, $this->signType);
-
-                if (!$checkResult) {
-
-                    //请求网关下载新的支付宝公钥证书
-                    if(!$respObject->alipay_cert_sn && ($request->getApiMethodName()=="alipay.open.app.alipaycert.download")){
-                        throw new Exception(" check sign Fail! The reason : alipay_cert_sn is Empty");
-                    }
-                    //组装系统参数
-                    $sysParams["app_id"] = $this->appId;
-                    $sysParams["format"] = $this->format;
-                    $sysParams["sign_type"] = $this->signType;
-                    $sysParams["method"] = "alipay.open.app.alipaycert.download";
-                    $sysParams["timestamp"] = date("Y-m-d H:i:s");
-                    $sysParams["alipay_sdk"] = $this->alipaySdkVersion;
-                    $sysParams["terminal_type"] = $request->getTerminalType();
-                    $sysParams["terminal_info"] = $request->getTerminalInfo();
-                    $sysParams["prod_code"] = $request->getProdCode();
-                    $sysParams["notify_url"] = $request->getNotifyUrl();
-                    $sysParams["charset"] = $this->postCharset;
-                    $sysParams["app_cert_sn"] = $this->appCertSN;
-                    $sysParams["alipay_root_cert_sn"] = $this->alipayRootCertSN;
-                    //获取业务参数
-                    $apiParas = array();
-                    $apiParas["biz_content"] = "{\"alipay_cert_sn\":\"".$respObject->alipay_cert_sn."\"}";
-                    $apiParams = $apiParas;
-
-                    //签名
-                    $sysParams["sign"] = $this->generateSign(array_merge($apiParams, $sysParams), $this->signType);
-
-                    //系统参数放入GET请求串
-                    $requestUrl = $this->gatewayUrl . "?";
-                    foreach ($sysParams as $sysParamKey => $sysParamValue) {
-                        $requestUrl .= "$sysParamKey=" . urlencode($this->characet($sysParamValue, $this->postCharset)) . "&";
-                    }
-                    $requestUrl = substr($requestUrl, 0, -1);
-                    //发起HTTP请求
-                    try {
-                        $resp = $this->curl($requestUrl, $apiParams);
-                    } catch (Exception $e) {
-                        $this->logCommunicationError($sysParams["method"], $requestUrl, "HTTP_ERROR_" . $e->getCode(), $e->getMessage());
-                        return false;
-                    }
-
-                    // 将返回结果转换本地文件编码
-                    $r = iconv($this->postCharset, $this->fileCharset . "//IGNORE", $resp);
-
-                    $respObject = json_decode($r);
-                    $resultCode = $respObject->alipay_open_app_alipaycert_download_response->code;
-                    $certContent = $respObject->alipay_open_app_alipaycert_download_response->alipay_cert_content;
-
-                    if (!empty($resultCode) && $resultCode == 10000 && !empty($certContent)) {
-                        $cert = base64_decode($certContent);
-                        $certCheck = true;
-                        if(!empty($this->alipayRootCertContent) && $this->isCheckAlipayPublicCert){
-                            $certCheck = isTrusted($cert,$this->alipayRootCertContent);
-                        }
-                        if($certCheck){
-                            $pkey = openssl_pkey_get_public($cert);
-                            $keyData = openssl_pkey_get_details($pkey);
-                            $public_key = str_replace('-----BEGIN PUBLIC KEY-----', '', $keyData['key']);
-                            $public_key = trim(str_replace('-----END PUBLIC KEY-----', '', $public_key));
-                            $this->alipayrsaPublicKey = $public_key;
-                            $checkResult = $this->verify($signData->signSourceData, $signData->sign, $this->alipayrsaPublicKey, $this->signType);
-                        }else{
-                            //如果下载下来的支付宝公钥证书使用根证书检查失败直接抛异常
-                            throw new Exception("check sign Fail! [sign=" . $signData->sign . ", signSourceData=" . $signData->signSourceData . "]");
-                        }
-                    }
-
-                    if(!$checkResult){
-                        if (strpos($signData->signSourceData, "\\/") > 0) {
-                            $signData->signSourceData = str_replace("\\/", "/", $signData->signSourceData);
-                            $checkResult = $this->verify($signData->signSourceData, $signData->sign, $this->alipayPublicKey, $this->signType);
-                            if (!$checkResult) {
-                                throw new Exception("check sign Fail! [sign=" . $signData->sign . ", signSourceData=" . $signData->signSourceData . "]");
-                            }
-                        } else {
-                            throw new Exception("check sign Fail! [sign=" . $signData->sign . ", signSourceData=" . $signData->signSourceData . "]");
-                        }
-                    }
-
-                }
-            }
-        }
-    }
-
-
-    function parserResponseSubCode($request, $responseContent, $respObject, $format) {
-        if ("json" == $format) {
-            $apiName = $request->getApiMethodName();
-            $rootNodeName = str_replace(".", "_", $apiName) . $this->RESPONSE_SUFFIX;
-            $errorNodeName = $this->ERROR_RESPONSE;
-            $rootIndex = strpos($responseContent, $rootNodeName);
-            $errorIndex = strpos($responseContent, $errorNodeName);
-            if ($rootIndex > 0) {
-                // 内部节点对象
-                $rInnerObject = $respObject->$rootNodeName;
-            } elseif ($errorIndex > 0) {
-                $rInnerObject = $respObject->$errorNodeName;
-            } else {
-                return null;
-            }
-            // 存在属性则返回对应值
-            if (isset($rInnerObject->sub_code)) {
-                return $rInnerObject->sub_code;
-            } else {
-                return null;
-            }
-        } elseif ("xml" == $format) {
-            // xml格式sub_code在同一层级
-            return $respObject->sub_code;
-        }
-    }
-
-    function verify($data, $sign, $rsaPublicKeyFilePath, $signType = 'RSA') {
-        if($this->checkEmpty($this->alipayPublicKey)){
-            $pubKey= $this->alipayrsaPublicKey;
-            $res = "-----BEGIN PUBLIC KEY-----\n" .
-                wordwrap($pubKey, 64, "\n", true) .
-                "\n-----END PUBLIC KEY-----";
-        }else {
-            //读取公钥文件
-            $pubKey = file_get_contents($rsaPublicKeyFilePath);
-            //转换为openssl格式密钥
-            $res = openssl_get_publickey($pubKey);
-        }
-        ($res) or die('支付宝RSA公钥错误。请检查公钥文件格式是否正确');
-        //调用openssl内置方法验签,返回bool值
-        $result = FALSE;
-        if ("RSA2" == $signType) {
-            $result = (openssl_verify($data, base64_decode($sign), $res, OPENSSL_ALGO_SHA256)===1);
-        } else {
-            $result = (openssl_verify($data, base64_decode($sign), $res)===1);
-        }
-        if(!$this->checkEmpty($this->alipayPublicKey)) {
-            //释放资源
-            openssl_free_key($res);
-        }
-        return $result;
-    }
-
-
-    // 获取加密内容
-    private function encryptJSONSignSource($request, $responseContent) {
-        $parsetItem = $this->parserEncryptJSONSignSource($request, $responseContent);
-        $bodyIndexContent = substr($responseContent, 0, $parsetItem->startIndex);
-        $bodyEndContent = substr($responseContent, $parsetItem->endIndex, strlen($responseContent) + 1 - $parsetItem->endIndex);
-        $bizContent = decrypt($parsetItem->encryptContent, $this->encryptKey);
-        return $bodyIndexContent . $bizContent . $bodyEndContent;
-    }
-
-
-    private function parserEncryptJSONSignSource($request, $responseContent) {
-        $apiName = $request->getApiMethodName();
-        $rootNodeName = str_replace(".", "_", $apiName) . $this->RESPONSE_SUFFIX;
-        $rootIndex = strpos($responseContent, $rootNodeName);
-        $errorIndex = strpos($responseContent, $this->ERROR_RESPONSE);
-        if ($rootIndex > 0) {
-            return $this->parserEncryptJSONItem($responseContent, $rootNodeName, $rootIndex);
-        } else if ($errorIndex > 0) {
-            return $this->parserEncryptJSONItem($responseContent, $this->ERROR_RESPONSE, $errorIndex);
-        } else {
-            return null;
-        }
-    }
-
-    private function parserEncryptJSONItem($responseContent, $nodeName, $nodeIndex) {
-        $signDataStartIndex = $nodeIndex + strlen($nodeName) + 2;
-        if(strrpos($responseContent, $this->ALIPAY_CERT_SN)){
-            $signIndex = strpos($responseContent, "\"" . $this->ALIPAY_CERT_SN . "\"");
-        }else{
-            $signIndex = strpos($responseContent, "\"" . $this->SIGN_NODE_NAME . "\"");
-        }
-
-        // 签名前-逗号
-        $signDataEndIndex = $signIndex - 1;
-        if ($signDataEndIndex < 0) {
-            $signDataEndIndex = strlen($responseContent)-1 ;
-        }
-        $indexLen = $signDataEndIndex - $signDataStartIndex;
-        $encContent = substr($responseContent, $signDataStartIndex+1, $indexLen-2);
-        $encryptParseItem = new EncryptParseItem();
-        $encryptParseItem->encryptContent = $encContent;
-        $encryptParseItem->startIndex = $signDataStartIndex;
-        $encryptParseItem->endIndex = $signDataEndIndex;
-        return $encryptParseItem;
-    }
-
-    // 获取加密内容
-    private function encryptXMLSignSource($request, $responseContent) {
-        $parsetItem = $this->parserEncryptXMLSignSource($request, $responseContent);
-        $bodyIndexContent = substr($responseContent, 0, $parsetItem->startIndex);
-        $bodyEndContent = substr($responseContent, $parsetItem->endIndex, strlen($responseContent) + 1 - $parsetItem->endIndex);
-        $bizContent = decrypt($parsetItem->encryptContent, $this->encryptKey);
-        return $bodyIndexContent . $bizContent . $bodyEndContent;
-
-    }
-
-    private function parserEncryptXMLSignSource($request, $responseContent) {
-        $apiName = $request->getApiMethodName();
-        $rootNodeName = str_replace(".", "_", $apiName) . $this->RESPONSE_SUFFIX;
-        $rootIndex = strpos($responseContent, $rootNodeName);
-        $errorIndex = strpos($responseContent, $this->ERROR_RESPONSE);
-        if ($rootIndex > 0) {
-            return $this->parserEncryptXMLItem($responseContent, $rootNodeName, $rootIndex);
-        } else if ($errorIndex > 0) {
-            return $this->parserEncryptXMLItem($responseContent, $this->ERROR_RESPONSE, $errorIndex);
-        } else {
-            return null;
-        }
-    }
-
-    private function parserEncryptXMLItem($responseContent, $nodeName, $nodeIndex) {
-        $signDataStartIndex = $nodeIndex + strlen($nodeName) + 1;
-        $xmlStartNode="<".$this->ENCRYPT_XML_NODE_NAME.">";
-        $xmlEndNode="</".$this->ENCRYPT_XML_NODE_NAME.">";
-        $indexOfXmlNode=strpos($responseContent,$xmlEndNode);
-        if($indexOfXmlNode<0){
-            $item = new EncryptParseItem();
-            $item->encryptContent = null;
-            $item->startIndex = 0;
-            $item->endIndex = 0;
-            return $item;
-        }
-        $startIndex=$signDataStartIndex+strlen($xmlStartNode);
-        $bizContentLen=$indexOfXmlNode-$startIndex;
-        $bizContent=substr($responseContent,$startIndex,$bizContentLen);
-        $encryptParseItem = new EncryptParseItem();
-        $encryptParseItem->encryptContent = $bizContent;
-        $encryptParseItem->startIndex = $signDataStartIndex;
-        $encryptParseItem->endIndex = $indexOfXmlNode+strlen($xmlEndNode);
-        return $encryptParseItem;
-    }
-
-    function echoDebug($content) {
-        if ($this->debugInfo) {
-            echo "<br/>" . $content;
-        }
-    }
-}

+ 0 - 527
application/common/library/alipay/aop/AopCertification.php

@@ -1,527 +0,0 @@
-<?php
-
-/**
- * 验证支付宝公钥证书是否可信
- * @param $alipayCert 支付宝公钥证书
- * @param $rootCert 支付宝根证书
- */
-function isTrusted($alipayCert, $rootCert)
-{
-    $alipayCerts = readPemCertChain($alipayCert);
-    $rootCerts = readPemCertChain($rootCert);
-    if (verifyCertChain($alipayCerts, $rootCerts)) {
-        return verifySignature($alipayCert, $rootCert);
-    } else {
-        return false;
-    }
-
-}
-
-function verifySignature($alipayCert, $rootCert)
-{
-    $alipayCertArray = explode("-----END CERTIFICATE-----", $alipayCert);
-    $rootCertArray = explode("-----END CERTIFICATE-----", $rootCert);
-    $length = count($rootCertArray) - 1;
-    $checkSign = isCertSigner($alipayCertArray[0] . "-----END CERTIFICATE-----", $alipayCertArray[1] . "-----END CERTIFICATE-----");
-    if (!$checkSign) {
-        $checkSign = isCertSigner($alipayCertArray[1] . "-----END CERTIFICATE-----", $alipayCertArray[0] . "-----END CERTIFICATE-----");
-        if ($checkSign) {
-            $issuer = openssl_x509_parse($alipayCertArray[0] . "-----END CERTIFICATE-----")['issuer'];
-            for ($i = 0; $i < $length; $i++) {
-                $subject = openssl_x509_parse($rootCertArray[$i] . "-----END CERTIFICATE-----")['subject'];
-                if ($issuer == $subject) {
-                    isCertSigner($alipayCertArray[0] . "-----END CERTIFICATE-----", $rootCertArray[$i] . $rootCertArray);
-                    return $checkSign;
-                }
-            }
-        } else {
-            return $checkSign;
-        }
-    } else {
-        $issuer = openssl_x509_parse($alipayCertArray[1] . "-----END CERTIFICATE-----")['issuer'];
-        for ($i = 0; $i < $length; $i++) {
-            $subject = openssl_x509_parse($rootCertArray[$i] . "-----END CERTIFICATE-----")['subject'];
-            if ($issuer == $subject) {
-                $checkSign = isCertSigner($alipayCertArray[1] . "-----END CERTIFICATE-----", $rootCertArray[$i] . "-----END CERTIFICATE-----");
-                return $checkSign;
-            }
-        }
-        return $checkSign;
-    }
-}
-
-function readPemCertChain($cert)
-{
-    $array = explode("-----END CERTIFICATE-----", $cert);
-    $certs[] = null;
-    for ($i = 0; $i < count($array) - 1; $i++) {
-        $certs[$i] = openssl_x509_parse($array[$i] . "-----END CERTIFICATE-----");
-    }
-    return $certs;
-}
-
-function verifyCert($prev, $rootCerts)
-{
-    $nowTime = time();
-    if ($nowTime < $prev['validFrom_time_t']) {
-        echo "证书未激活";
-        return false;
-    }
-    if ($nowTime > $prev['validTo_time_t']) {
-        echo "证书已经过期";
-        return false;
-    }
-    $subjectMap = null;
-    for ($i = 0; $i < count($rootCerts); $i++) {
-        $subjectDN = array2string($rootCerts[$i]['subject']);
-        $subjectMap[$subjectDN] = $rootCerts[$i];
-    }
-    $issuerDN = array2string(($prev['issuer']));
-    if (!array_key_exists($issuerDN, $subjectMap)) {
-        echo "证书链验证失败";
-        return false;
-    }
-    return true;
-}
-
-/**
- * 验证证书链是否是信任证书库中证书签发的
- * @param $alipayCerts 目标验证证书列表
- * @param $rootCerts 可信根证书列表
- */
-function verifyCertChain($alipayCerts, $rootCerts)
-{
-    $sorted = sortByDn($alipayCerts);
-    if (!$sorted) {
-        echo "证书链验证失败:不是完整的证书链";
-        return false;
-    }
-    //先验证第一个证书是不是信任库中证书签发的
-    $prev = $alipayCerts[0];
-    $firstOK = verifyCert($prev, $rootCerts);
-    $length = count($alipayCerts);
-    if (!$firstOK || $length == 1) {
-        return $firstOK;
-    }
-
-    $nowTime = time();
-    //验证证书链
-    for ($i = 1; $i < $length; $i++) {
-        $cert = $alipayCerts[$i];
-        if ($nowTime < $cert['validFrom_time_t']) {
-            echo "证书未激活";
-            return false;
-        }
-        if ($nowTime > $cert['validTo_time_t']) {
-            echo "证书已经过期";
-            return false;
-        }
-    }
-    return true;
-}
-
-/**
- * 将证书链按照完整的签发顺序进行排序,排序后证书链为:[issuerA, subjectA]-[issuerA, subjectB]-[issuerB, subjectC]-[issuerC, subjectD]...
- * @param $certs 证书链
- */
-function sortByDn(&$certs)
-{
-    //是否包含自签名证书
-    $hasSelfSignedCert = false;
-    $subjectMap = null;
-    $issuerMap = null;
-    for ($i = 0; $i < count($certs); $i++) {
-        if (isSelfSigned($certs[$i])) {
-            if ($hasSelfSignedCert) {
-                return false;
-            }
-            $hasSelfSignedCert = true;
-        }
-        $subjectDN = array2string($certs[$i]['subject']);
-        $issuerDN = array2string(($certs[$i]['issuer']));
-        $subjectMap[$subjectDN] = $certs[$i];
-        $issuerMap[$issuerDN] = $certs[$i];
-    }
-    $certChain = null;
-    addressingUp($subjectMap, $certChain, $certs[0]);
-    addressingDown($issuerMap, $certChain, $certs[0]);
-
-    //说明证书链不完整
-    if (count($certs) != count($certChain)) {
-        return false;
-    }
-    //将证书链复制到原先的数据
-    for ($i = 0; $i < count($certs); $i++) {
-        $certs[$i] = $certChain[count($certs) - $i - 1];
-    }
-    return true;
-}
-
-/**
- * 验证证书是否是自签发的
- * @param $cert 目标证书
- */
-function isSelfSigned($cert)
-{
-    $subjectDN = array2string($cert['subject']);
-    $issuerDN = array2string($cert['issuer']);
-    return ($subjectDN == $issuerDN);
-}
-
-
-function array2string($array)
-{
-    $string = [];
-    if ($array && is_array($array)) {
-        foreach ($array as $key => $value) {
-            $string[] = $key . '=' . $value;
-        }
-    }
-    return implode(',', $string);
-}
-
-/**
- * 向上构造证书链
- * @param $subjectMap 主题和证书的映射
- * @param $certChain 证书链
- * @param $current 当前需要插入证书链的证书,include
- */
-function addressingUp($subjectMap, &$certChain, $current)
-{
-    $certChain[] = $current;
-    if (isSelfSigned($current)) {
-        return;
-    }
-    $issuerDN = array2string($current['issuer']);
-
-    if (!array_key_exists($issuerDN, $subjectMap)) {
-        return;
-    }
-    addressingUp($subjectMap, $certChain, $subjectMap[$issuerDN]);
-}
-
-/**
- * 向下构造证书链
- * @param $issuerMap 签发者和证书的映射
- * @param $certChain 证书链
- * @param $current 当前需要插入证书链的证书,exclude
- */
-function addressingDown($issuerMap, &$certChain, $current)
-{
-    $subjectDN = array2string($current['subject']);
-    if (!array_key_exists($subjectDN, $issuerMap)) {
-        return $certChain;
-    }
-    $certChain[] = $issuerMap[$subjectDN];
-    addressingDown($issuerMap, $certChain, $issuerMap[$subjectDN]);
-}
-
-
-/**
- * Extract signature from der encoded cert.
- * Expects x509 der encoded certificate consisting of a section container
- * containing 2 sections and a bitstream.  The bitstream contains the
- * original encrypted signature, encrypted by the public key of the issuing
- * signer.
- * @param string $der
- * @return string on success
- * @return bool false on failures
- */
-function extractSignature($der = false)
-{
-    if (strlen($der) < 5) {
-        return false;
-    }
-    // skip container sequence
-    $der = substr($der, 4);
-    // now burn through two sequences and the return the final bitstream
-    while (strlen($der) > 1) {
-        $class = ord($der[0]);
-        $classHex = dechex($class);
-        switch ($class) {
-            // BITSTREAM
-            case 0x03:
-                $len = ord($der[1]);
-                $bytes = 0;
-                if ($len & 0x80) {
-                    $bytes = $len & 0x0f;
-                    $len = 0;
-                    for ($i = 0; $i < $bytes; $i++) {
-                        $len = ($len << 8) | ord($der[$i + 2]);
-                    }
-                }
-                return substr($der, 3 + $bytes, $len);
-                break;
-            // SEQUENCE
-            case 0x30:
-                $len = ord($der[1]);
-                $bytes = 0;
-                if ($len & 0x80) {
-                    $bytes = $len & 0x0f;
-                    $len = 0;
-                    for ($i = 0; $i < $bytes; $i++) {
-                        $len = ($len << 8) | ord($der[$i + 2]);
-                    }
-                }
-                $contents = substr($der, 2 + $bytes, $len);
-                $der = substr($der, 2 + $bytes + $len);
-                break;
-            default:
-                return false;
-                break;
-        }
-    }
-    return false;
-}
-
-/**
- * Get signature algorithm oid from der encoded signature data.
- * Expects decrypted signature data from a certificate in der format.
- * This ASN1 data should contain the following structure:
- * SEQUENCE
- *    SEQUENCE
- *       OID    (signature algorithm)
- *       NULL
- * OCTET STRING (signature hash)
- * @return bool false on failures
- * @return string oid
- */
-function getSignatureAlgorithmOid($der = null)
-{
-    // Validate this is the der we need...
-    if (!is_string($der) or strlen($der) < 5) {
-        return false;
-    }
-    $bit_seq1 = 0;
-    $bit_seq2 = 2;
-    $bit_oid = 4;
-    if (ord($der[$bit_seq1]) !== 0x30) {
-        die('Invalid DER passed to getSignatureAlgorithmOid()');
-    }
-    if (ord($der[$bit_seq2]) !== 0x30) {
-        die('Invalid DER passed to getSignatureAlgorithmOid()');
-    }
-    if (ord($der[$bit_oid]) !== 0x06) {
-        die('Invalid DER passed to getSignatureAlgorithmOid');
-    }
-    // strip out what we don't need and get the oid
-    $der = substr($der, $bit_oid);
-    // Get the oid
-    $len = ord($der[1]);
-    $bytes = 0;
-    if ($len & 0x80) {
-        $bytes = $len & 0x0f;
-        $len = 0;
-        for ($i = 0; $i < $bytes; $i++) {
-            $len = ($len << 8) | ord($der[$i + 2]);
-        }
-    }
-    $oid_data = substr($der, 2 + $bytes, $len);
-    // Unpack the OID
-    $oid = floor(ord($oid_data[0]) / 40);
-    $oid .= '.' . ord($oid_data[0]) % 40;
-    $value = 0;
-    $i = 1;
-    while ($i < strlen($oid_data)) {
-        $value = $value << 7;
-        $value = $value | (ord($oid_data[$i]) & 0x7f);
-        if (!(ord($oid_data[$i]) & 0x80)) {
-            $oid .= '.' . $value;
-            $value = 0;
-        }
-        $i++;
-    }
-    return $oid;
-}
-
-/**
- * Get signature hash from der encoded signature data.
- * Expects decrypted signature data from a certificate in der format.
- * This ASN1 data should contain the following structure:
- * SEQUENCE
- *    SEQUENCE
- *       OID    (signature algorithm)
- *       NULL
- * OCTET STRING (signature hash)
- * @return bool false on failures
- * @return string hash
- */
-function getSignatureHash($der = null)
-{
-    // Validate this is the der we need...
-    if (!is_string($der) or strlen($der) < 5) {
-        return false;
-    }
-    if (ord($der[0]) !== 0x30) {
-        die('Invalid DER passed to getSignatureHash()');
-    }
-    // strip out the container sequence
-    $der = substr($der, 2);
-    if (ord($der[0]) !== 0x30) {
-        die('Invalid DER passed to getSignatureHash()');
-    }
-    // Get the length of the first sequence so we can strip it out.
-    $len = ord($der[1]);
-    $bytes = 0;
-    if ($len & 0x80) {
-        $bytes = $len & 0x0f;
-        $len = 0;
-        for ($i = 0; $i < $bytes; $i++) {
-            $len = ($len << 8) | ord($der[$i + 2]);
-        }
-    }
-    $der = substr($der, 2 + $bytes + $len);
-    // Now we should have an octet string
-    if (ord($der[0]) !== 0x04) {
-        die('Invalid DER passed to getSignatureHash()');
-    }
-    $len = ord($der[1]);
-    $bytes = 0;
-    if ($len & 0x80) {
-        $bytes = $len & 0x0f;
-        $len = 0;
-        for ($i = 0; $i < $bytes; $i++) {
-            $len = ($len << 8) | ord($der[$i + 2]);
-        }
-    }
-    return bin2hex(substr($der, 2 + $bytes, $len));
-}
-
-/**
- * Determine if one cert was used to sign another
- * Note that more than one CA cert can give a positive result, some certs
- * re-issue signing certs after having only changed the expiration dates.
- * @param string $cert - PEM encoded cert
- * @param string $caCert - PEM encoded cert that possibly signed $cert
- * @return bool
- */
-function isCertSigner($certPem = null, $caCertPem = null)
-{
-    if (!function_exists('openssl_pkey_get_public')) {
-        die('Need the openssl_pkey_get_public() function.');
-    }
-    if (!function_exists('openssl_public_decrypt')) {
-        die('Need the openssl_public_decrypt() function.');
-    }
-    if (!function_exists('hash')) {
-        die('Need the php hash() function.');
-    }
-    if (empty($certPem) or empty($caCertPem)) {
-        return false;
-    }
-    // Convert the cert to der for feeding to extractSignature.
-    $certDer = pemToDer($certPem);
-    if (!is_string($certDer)) {
-        die('invalid certPem');
-    }
-    // Grab the encrypted signature from the der encoded cert.
-    $encryptedSig = extractSignature($certDer);
-    if (!is_string($encryptedSig)) {
-        die('Failed to extract encrypted signature from certPem.');
-    }
-    // Extract the public key from the ca cert, which is what has
-    // been used to encrypt the signature in the cert.
-    $pubKey = openssl_pkey_get_public($caCertPem);
-    if ($pubKey === false) {
-        die('Failed to extract the public key from the ca cert.');
-    }
-    // Attempt to decrypt the encrypted signature using the CA's public
-    // key, returning the decrypted signature in $decryptedSig.  If
-    // it can't be decrypted, this ca was not used to sign it for sure...
-    $rc = openssl_public_decrypt($encryptedSig, $decryptedSig, $pubKey);
-    if ($rc === false) {
-        return false;
-    }
-    // We now have the decrypted signature, which is der encoded
-    // asn1 data containing the signature algorithm and signature hash.
-    // Now we need what was originally hashed by the issuer, which is
-    // the original DER encoded certificate without the issuer and
-    // signature information.
-    $origCert = stripSignerAsn($certDer);
-    if ($origCert === false) {
-        die('Failed to extract unsigned cert.');
-    }
-    // Get the oid of the signature hash algorithm, which is required
-    // to generate our own hash of the original cert.  This hash is
-    // what will be compared to the issuers hash.
-    $oid = getSignatureAlgorithmOid($decryptedSig);
-    if ($oid === false) {
-        die('Failed to determine the signature algorithm.');
-    }
-    switch ($oid) {
-        case '1.2.840.113549.2.2':
-            $algo = 'md2';
-            break;
-        case '1.2.840.113549.2.4':
-            $algo = 'md4';
-            break;
-        case '1.2.840.113549.2.5':
-            $algo = 'md5';
-            break;
-        case '1.3.14.3.2.18':
-            $algo = 'sha';
-            break;
-        case '1.3.14.3.2.26':
-            $algo = 'sha1';
-            break;
-        case '2.16.840.1.101.3.4.2.1':
-            $algo = 'sha256';
-            break;
-        case '2.16.840.1.101.3.4.2.2':
-            $algo = 'sha384';
-            break;
-        case '2.16.840.1.101.3.4.2.3':
-            $algo = 'sha512';
-            break;
-        default:
-            die('Unknown signature hash algorithm oid: ' . $oid);
-            break;
-    }
-    // Get the issuer generated hash from the decrypted signature.
-    $decryptedHash = getSignatureHash($decryptedSig);
-    // Ok, hash the original unsigned cert with the same algorithm
-    // and if it matches $decryptedHash we have a winner.
-    $certHash = hash($algo, $origCert);
-    return ($decryptedHash === $certHash);
-}
-
-/**
- * Convert pem encoded certificate to DER encoding
- * @return string $derEncoded on success
- * @return bool false on failures
- */
-function pemToDer($pem = null)
-{
-    if (!is_string($pem)) {
-        return false;
-    }
-    $cert_split = preg_split('/(-----((BEGIN)|(END)) CERTIFICATE-----)/', $pem);
-    if (!isset($cert_split[1])) {
-        return false;
-    }
-    return base64_decode($cert_split[1]);
-}
-
-/**
- * Obtain der cert with issuer and signature sections stripped.
- * @param string $der - der encoded certificate
- * @return string $der on success
- * @return bool false on failures.
- */
-function stripSignerAsn($der = null)
-{
-    if (!is_string($der) or strlen($der) < 8) {
-        return false;
-    }
-    $bit = 4;
-    $len = ord($der[($bit + 1)]);
-    $bytes = 0;
-    if ($len & 0x80) {
-        $bytes = $len & 0x0f;
-        $len = 0;
-        for ($i = 0; $i < $bytes; $i++) {
-            $len = ($len << 8) | ord($der[$bit + $i + 2]);
-        }
-    }
-    return substr($der, 4, $len + 4);
-}

+ 0 - 1299
application/common/library/alipay/aop/AopClient.php

@@ -1,1299 +0,0 @@
-<?php
-namespace app\common\library;
-use think\Controller;
-require_once 'AopEncrypt.php';
-require_once 'EncryptParseItem.php';
-require_once 'EncryptResponseData.php';
-require_once 'SignData.php';
-
-class AopClient
-{
-    //应用ID
-    public $appId;
-
-    //私钥文件路径
-    public $rsaPrivateKeyFilePath;
-
-    //私钥值
-    public $rsaPrivateKey;
-
-    //网关
-    public $gatewayUrl = "https://openapi.alipay.com/gateway.do";
-    //返回数据格式
-    public $format = "json";
-    //api版本
-    public $apiVersion = "1.0";
-
-    // 表单提交字符集编码
-    public $postCharset = "UTF-8";
-
-    //使用文件读取文件格式,请只传递该值
-    public $alipayPublicKey = null;
-
-    //使用读取字符串格式,请只传递该值
-    public $alipayrsaPublicKey;
-
-
-    public $debugInfo = false;
-
-    private $fileCharset = "UTF-8";
-
-    private $RESPONSE_SUFFIX = "_response";
-
-    private $ERROR_RESPONSE = "error_response";
-
-    private $SIGN_NODE_NAME = "sign";
-
-
-    //加密XML节点名称
-    private $ENCRYPT_XML_NODE_NAME = "response_encrypted";
-
-    private $needEncrypt = false;
-
-
-    //签名类型
-    public $signType = "RSA";
-
-
-    //加密密钥和类型
-
-    public $encryptKey;
-
-    public $encryptType = "AES";
-
-    private $targetServiceUrl = "";
-
-    protected $alipaySdkVersion = "alipay-sdk-php-20200415";
-
-    public function generateSign($params, $signType = "RSA")
-    {
-        return $this->sign($this->getSignContent($params), $signType);
-    }
-
-    public function rsaSign($params, $signType = "RSA")
-    {
-        return $this->sign($this->getSignContent($params), $signType);
-    }
-
-    public function getSignContent($params)
-    {
-        ksort($params);
-
-        $stringToBeSigned = "";
-        $i = 0;
-        foreach ($params as $k => $v) {
-            if (false === $this->checkEmpty($v) && "@" != substr($v, 0, 1)) {
-                // 转换成目标字符集
-                $v = $this->characet($v, $this->postCharset);
-
-                if ($i == 0) {
-                    $stringToBeSigned .= "$k" . "=" . "$v";
-                } else {
-                    $stringToBeSigned .= "&" . "$k" . "=" . "$v";
-                }
-                $i++;
-            }
-        }
-
-        unset ($k, $v);
-        return $stringToBeSigned;
-    }
-
-
-    //此方法对value做urlencode
-    public function getSignContentUrlencode($params)
-    {
-        ksort($params);
-
-        $stringToBeSigned = "";
-        $i = 0;
-        foreach ($params as $k => $v) {
-            if (false === $this->checkEmpty($v) && "@" != substr($v, 0, 1)) {
-
-                // 转换成目标字符集
-                $v = $this->characet($v, $this->postCharset);
-
-                if ($i == 0) {
-                    $stringToBeSigned .= "$k" . "=" . urlencode($v);
-                } else {
-                    $stringToBeSigned .= "&" . "$k" . "=" . urlencode($v);
-                }
-                $i++;
-            }
-        }
-
-        unset ($k, $v);
-        return $stringToBeSigned;
-    }
-
-    protected function sign($data, $signType = "RSA")
-    {
-        if ($this->checkEmpty($this->rsaPrivateKeyFilePath)) {
-            $priKey = $this->rsaPrivateKey;
-            $res = "-----BEGIN RSA PRIVATE KEY-----\n" .
-                wordwrap($priKey, 64, "\n", true) .
-                "\n-----END RSA PRIVATE KEY-----";
-        } else {
-            $priKey = file_get_contents($this->rsaPrivateKeyFilePath);
-            $res = openssl_get_privatekey($priKey);
-        }
-
-        ($res) or die('您使用的私钥格式错误,请检查RSA私钥配置');
-
-        if ("RSA2" == $signType) {
-            openssl_sign($data, $sign, $res, OPENSSL_ALGO_SHA256);
-        } else {
-            openssl_sign($data, $sign, $res);
-        }
-
-        if (!$this->checkEmpty($this->rsaPrivateKeyFilePath)) {
-            openssl_free_key($res);
-        }
-        $sign = base64_encode($sign);
-        return $sign;
-    }
-
-    /**
-     * RSA单独签名方法,未做字符串处理,字符串处理见getSignContent()
-     * @param $data 待签名字符串
-     * @param $privatekey 商户私钥,根据keyfromfile来判断是读取字符串还是读取文件,false:填写私钥字符串去回车和空格 true:填写私钥文件路径
-     * @param $signType 签名方式,RSA:SHA1     RSA2:SHA256
-     * @param $keyfromfile 私钥获取方式,读取字符串还是读文件
-     * @return string
-     */
-    public function alonersaSign($data, $privatekey, $signType = "RSA", $keyfromfile = false)
-    {
-
-        if (!$keyfromfile) {
-            $priKey = $privatekey;
-            $res = "-----BEGIN RSA PRIVATE KEY-----\n" .
-                wordwrap($priKey, 64, "\n", true) .
-                "\n-----END RSA PRIVATE KEY-----";
-        } else {
-            $priKey = file_get_contents($privatekey);
-            $res = openssl_get_privatekey($priKey);
-        }
-
-        ($res) or die('您使用的私钥格式错误,请检查RSA私钥配置');
-
-        if ("RSA2" == $signType) {
-            openssl_sign($data, $sign, $res, OPENSSL_ALGO_SHA256);
-        } else {
-            openssl_sign($data, $sign, $res);
-        }
-
-        if ($keyfromfile) {
-            openssl_free_key($res);
-        }
-        $sign = base64_encode($sign);
-        return $sign;
-    }
-
-
-    protected function curl($url, $postFields = null)
-    {
-        $ch = curl_init();
-        curl_setopt($ch, CURLOPT_URL, $url);
-        curl_setopt($ch, CURLOPT_FAILONERROR, false);
-        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
-        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
-
-        $postBodyString = "";
-        $encodeArray = Array();
-        $postMultipart = false;
-
-
-        if (is_array($postFields) && 0 < count($postFields)) {
-
-            foreach ($postFields as $k => $v) {
-                if ("@" != substr($v, 0, 1)) //判断是不是文件上传
-                {
-
-                    $postBodyString .= "$k=" . urlencode($this->characet($v, $this->postCharset)) . "&";
-                    $encodeArray[$k] = $this->characet($v, $this->postCharset);
-                } else //文件上传用multipart/form-data,否则用www-form-urlencoded
-                {
-                    $postMultipart = true;
-                    $encodeArray[$k] = new \CURLFile(substr($v, 1));
-                }
-
-            }
-            unset ($k, $v);
-            curl_setopt($ch, CURLOPT_POST, true);
-            if ($postMultipart) {
-                curl_setopt($ch, CURLOPT_POSTFIELDS, $encodeArray);
-            } else {
-                curl_setopt($ch, CURLOPT_POSTFIELDS, substr($postBodyString, 0, -1));
-            }
-        }
-
-        if (!$postMultipart) {
-            $headers = array('content-type: application/x-www-form-urlencoded;charset=' . $this->postCharset);
-            curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
-        }
-
-        $reponse = curl_exec($ch);
-
-        if (curl_errno($ch)) {
-
-            throw new Exception(curl_error($ch), 0);
-        } else {
-            $httpStatusCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
-            if (200 !== $httpStatusCode) {
-                throw new Exception($reponse, $httpStatusCode);
-            }
-        }
-
-        curl_close($ch);
-        return $reponse;
-    }
-
-    protected function getMillisecond()
-    {
-        list($s1, $s2) = explode(' ', microtime());
-        return (float)sprintf('%.0f', (floatval($s1) + floatval($s2)) * 1000);
-    }
-
-
-    protected function logCommunicationError($apiName, $requestUrl, $errorCode, $responseTxt)
-    {
-        $logData = array(
-            date("Y-m-d H:i:s"),
-            $apiName,
-            $this->appId,
-            PHP_OS,
-            $this->alipaySdkVersion,
-            $requestUrl,
-            $errorCode,
-            str_replace("\n", "", $responseTxt)
-        );
-
-        echo json_encode($logData);
-    }
-
-    /**
-     * 生成用于调用收银台SDK的字符串
-     * @param $request SDK接口的请求参数对象
-     * @param $appAuthToken 三方应用授权token
-     * @return string
-     */
-    public function sdkExecute($request, $appAuthToken = null)
-    {
-
-        $this->setupCharsets($request);
-
-        $params['app_id'] = $this->appId;
-        $params['method'] = $request->getApiMethodName();
-        $params['format'] = $this->format;
-        $params['sign_type'] = $this->signType;
-        $params['timestamp'] = date("Y-m-d H:i:s");
-        $params['alipay_sdk'] = $this->alipaySdkVersion;
-        $params['charset'] = $this->postCharset;
-
-        $version = $request->getApiVersion();
-        $params['version'] = $this->checkEmpty($version) ? $this->apiVersion : $version;
-
-        if ($notify_url = $request->getNotifyUrl()) {
-            $params['notify_url'] = $notify_url;
-        }
-
-        $params['app_auth_token'] = $appAuthToken;
-
-        $dict = $request->getApiParas();
-        $params['biz_content'] = $dict['biz_content'];
-
-        ksort($params);
-
-        $params['sign'] = $this->generateSign($params, $this->signType);
-
-        foreach ($params as &$value) {
-            $value = $this->characet($value, $params['charset']);
-        }
-
-        return http_build_query($params);
-    }
-
-    /**
-     * 页面提交执行方法
-     * @param $request 跳转类接口的request
-     * @param string $httpmethod 提交方式,两个值可选:post、get;
-     * @param null $appAuthToken 三方应用授权token
-     * @return 构建好的、签名后的最终跳转URL(GET)或String形式的form(POST)
-     * @throws Exception
-     */
-    public function pageExecute($request, $httpmethod = "POST", $appAuthToken = null)
-    {
-
-        $this->setupCharsets($request);
-
-        if (strcasecmp($this->fileCharset, $this->postCharset)) {
-
-            // writeLog("本地文件字符集编码与表单提交编码不一致,请务必设置成一样,属性名分别为postCharset!");
-            throw new Exception("文件编码:[" . $this->fileCharset . "] 与表单提交编码:[" . $this->postCharset . "]两者不一致!");
-        }
-
-        $iv = null;
-
-        if (!$this->checkEmpty($request->getApiVersion())) {
-            $iv = $request->getApiVersion();
-        } else {
-            $iv = $this->apiVersion;
-        }
-
-        //组装系统参数
-        $sysParams["app_id"] = $this->appId;
-        $sysParams["version"] = $iv;
-        $sysParams["format"] = $this->format;
-        $sysParams["sign_type"] = $this->signType;
-        $sysParams["method"] = $request->getApiMethodName();
-        $sysParams["timestamp"] = date("Y-m-d H:i:s");
-        $sysParams["alipay_sdk"] = $this->alipaySdkVersion;
-        $sysParams["terminal_type"] = $request->getTerminalType();
-        $sysParams["terminal_info"] = $request->getTerminalInfo();
-        $sysParams["prod_code"] = $request->getProdCode();
-        $sysParams["notify_url"] = $request->getNotifyUrl();
-        $sysParams["return_url"] = $request->getReturnUrl();
-        $sysParams["charset"] = $this->postCharset;
-        $sysParams["app_auth_token"] = $appAuthToken;
-
-        //获取业务参数
-        $apiParams = $request->getApiParas();
-
-        if (method_exists($request, "getNeedEncrypt") && $request->getNeedEncrypt()) {
-
-            $sysParams["encrypt_type"] = $this->encryptType;
-
-            if ($this->checkEmpty($apiParams['biz_content'])) {
-
-                throw new Exception(" api request Fail! The reason : encrypt request is not supperted!");
-            }
-
-            if ($this->checkEmpty($this->encryptKey) || $this->checkEmpty($this->encryptType)) {
-
-                throw new Exception(" encryptType and encryptKey must not null! ");
-            }
-
-            if ("AES" != $this->encryptType) {
-
-                throw new Exception("加密类型只支持AES");
-            }
-
-            // 执行加密
-            $enCryptContent = encrypt($apiParams['biz_content'], $this->encryptKey);
-            $apiParams['biz_content'] = $enCryptContent;
-
-        }
-
-        //print_r($apiParams);
-        $totalParams = array_merge($apiParams, $sysParams);
-
-        //待签名字符串
-        $preSignStr = $this->getSignContent($totalParams);
-
-        //签名
-        $totalParams["sign"] = $this->generateSign($totalParams, $this->signType);
-
-        if ("GET" == strtoupper($httpmethod)) {
-
-            //value做urlencode
-            $preString = $this->getSignContentUrlencode($totalParams);
-            //拼接GET请求串
-            $requestUrl = $this->gatewayUrl . "?" . $preString;
-
-            return $requestUrl;
-        } else {
-            //拼接表单字符串
-            return $this->buildRequestForm($totalParams);
-        }
-
-
-    }
-
-
-    /**
-     * 建立请求,以表单HTML形式构造(默认)
-     * @param $para_temp 请求参数数组
-     * @return 提交表单HTML文本
-     */
-    protected function buildRequestForm($para_temp)
-    {
-
-        $sHtml = "<form id='alipaysubmit' name='alipaysubmit' action='" . $this->gatewayUrl . "?charset=" . trim($this->postCharset) . "' method='POST'>";
-        while (list ($key, $val) = $this->fun_adm_each($para_temp)) {
-            if (false === $this->checkEmpty($val)) {
-                //$val = $this->characet($val, $this->postCharset);
-                $val = str_replace("'", "&apos;", $val);
-                //$val = str_replace("\"","&quot;",$val);
-                $sHtml .= "<input type='hidden' name='" . $key . "' value='" . $val . "'/>";
-            }
-        }
-
-        //submit按钮控件请不要含有name属性
-        $sHtml = $sHtml . "<input type='submit' value='ok' style='display:none;''></form>";
-
-        $sHtml = $sHtml . "<script>document.forms['alipaysubmit'].submit();</script>";
-
-        return $sHtml;
-    }
-
-    protected function fun_adm_each(&$array)
-    {
-        $res = array();
-        $key = key($array);
-        if ($key !== null) {
-            next($array);
-            $res[1] = $res['value'] = $array[$key];
-            $res[0] = $res['key'] = $key;
-        } else {
-            $res = false;
-        }
-        return $res;
-    }
-
-
-    public function execute($request, $authToken = null, $appInfoAuthtoken = null, $targetAppId = null)
-    {
-
-        $this->setupCharsets($request);
-
-        //如果两者编码不一致,会出现签名验签或者乱码
-        if (strcasecmp($this->fileCharset, $this->postCharset)) {
-
-            // writeLog("本地文件字符集编码与表单提交编码不一致,请务必设置成一样,属性名分别为postCharset!");
-            throw new Exception("文件编码:[" . $this->fileCharset . "] 与表单提交编码:[" . $this->postCharset . "]两者不一致!");
-        }
-
-        $iv = null;
-
-        if (!$this->checkEmpty($request->getApiVersion())) {
-            $iv = $request->getApiVersion();
-        } else {
-            $iv = $this->apiVersion;
-        }
-
-
-        //组装系统参数
-        $sysParams["app_id"] = $this->appId;
-        $sysParams["version"] = $iv;
-        $sysParams["format"] = $this->format;
-        $sysParams["sign_type"] = $this->signType;
-        $sysParams["method"] = $request->getApiMethodName();
-        $sysParams["timestamp"] = date("Y-m-d H:i:s");
-        $sysParams["auth_token"] = $authToken;
-        $sysParams["alipay_sdk"] = $this->alipaySdkVersion;
-        $sysParams["terminal_type"] = $request->getTerminalType();
-        $sysParams["terminal_info"] = $request->getTerminalInfo();
-        $sysParams["prod_code"] = $request->getProdCode();
-        $sysParams["notify_url"] = $request->getNotifyUrl();
-        $sysParams["charset"] = $this->postCharset;
-        $sysParams["app_auth_token"] = $appInfoAuthtoken;
-        $sysParams["target_app_id"] = $targetAppId;
-        if (!$this->checkEmpty($this->targetServiceUrl)) {
-            $sysParams["ws_service_url"] = $this->targetServiceUrl;
-        }
-
-
-        //获取业务参数
-        $apiParams = $request->getApiParas();
-
-        if (method_exists($request, "getNeedEncrypt") && $request->getNeedEncrypt()) {
-
-            $sysParams["encrypt_type"] = $this->encryptType;
-
-            if ($this->checkEmpty($apiParams['biz_content'])) {
-
-                throw new Exception(" api request Fail! The reason : encrypt request is not supperted!");
-            }
-
-            if ($this->checkEmpty($this->encryptKey) || $this->checkEmpty($this->encryptType)) {
-
-                throw new Exception(" encryptType and encryptKey must not null! ");
-            }
-
-            if ("AES" != $this->encryptType) {
-
-                throw new Exception("加密类型只支持AES");
-            }
-
-            // 执行加密
-            $enCryptContent = encrypt($apiParams['biz_content'], $this->encryptKey);
-            $apiParams['biz_content'] = $enCryptContent;
-
-        }
-
-
-        //签名
-        $sysParams["sign"] = $this->generateSign(array_merge($apiParams, $sysParams), $this->signType);
-
-
-        //系统参数放入GET请求串
-        $requestUrl = $this->gatewayUrl . "?";
-        foreach ($sysParams as $sysParamKey => $sysParamValue) {
-            $requestUrl .= "$sysParamKey=" . urlencode($this->characet($sysParamValue, $this->postCharset)) . "&";
-        }
-        $requestUrl = substr($requestUrl, 0, -1);
-
-
-        //发起HTTP请求
-        try {
-            $resp = $this->curl($requestUrl, $apiParams);
-        } catch (Exception $e) {
-
-            $this->logCommunicationError($sysParams["method"], $requestUrl, "HTTP_ERROR_" . $e->getCode(), $e->getMessage());
-            return false;
-        }
-
-        //解析AOP返回结果
-        $respWellFormed = false;
-
-
-        // 将返回结果转换本地文件编码
-        $r = iconv($this->postCharset, $this->fileCharset . "//IGNORE", $resp);
-
-
-        $signData = null;
-
-        if ("json" == $this->format) {
-
-            $respObject = json_decode($r);
-            if (null !== $respObject) {
-                $respWellFormed = true;
-                $signData = $this->parserJSONSignData($request, $resp, $respObject);
-            }
-        } else if ("xml" == $this->format) {
-            $disableLibxmlEntityLoader = libxml_disable_entity_loader(true);
-            $respObject = @ simplexml_load_string($resp);
-            if (false !== $respObject) {
-                $respWellFormed = true;
-
-                $signData = $this->parserXMLSignData($request, $resp);
-            }
-            libxml_disable_entity_loader($disableLibxmlEntityLoader);
-        }
-
-
-        //返回的HTTP文本不是标准JSON或者XML,记下错误日志
-        if (false === $respWellFormed) {
-            $this->logCommunicationError($sysParams["method"], $requestUrl, "HTTP_RESPONSE_NOT_WELL_FORMED", $resp);
-            return false;
-        }
-
-        // 验签
-        $this->checkResponseSign($request, $signData, $resp, $respObject);
-
-        // 解密
-        if (method_exists($request, "getNeedEncrypt") && $request->getNeedEncrypt()) {
-
-            if ("json" == $this->format) {
-
-
-                $resp = $this->encryptJSONSignSource($request, $resp);
-
-                // 将返回结果转换本地文件编码
-                $r = iconv($this->postCharset, $this->fileCharset . "//IGNORE", $resp);
-                $respObject = json_decode($r);
-            } else {
-
-                $resp = $this->encryptXMLSignSource($request, $resp);
-
-                $r = iconv($this->postCharset, $this->fileCharset . "//IGNORE", $resp);
-                $disableLibxmlEntityLoader = libxml_disable_entity_loader(true);
-                $respObject = @ simplexml_load_string($r);
-                libxml_disable_entity_loader($disableLibxmlEntityLoader);
-
-            }
-        }
-
-        return $respObject;
-    }
-
-    /**
-     * 转换字符集编码
-     * @param $data
-     * @param $targetCharset
-     * @return string
-     */
-    function characet($data, $targetCharset)
-    {
-
-        if (!empty($data)) {
-            $fileType = $this->fileCharset;
-            if (strcasecmp($fileType, $targetCharset) != 0) {
-                $data = mb_convert_encoding($data, $targetCharset, $fileType);
-                //				$data = iconv($fileType, $targetCharset.'//IGNORE', $data);
-            }
-        }
-
-
-        return $data;
-    }
-
-    public function exec($paramsArray)
-    {
-        if (!isset ($paramsArray["method"])) {
-            trigger_error("No api name passed");
-        }
-        $inflector = new LtInflector;
-        $inflector->conf["separator"] = ".";
-        $requestClassName = ucfirst($inflector->camelize(substr($paramsArray["method"], 7))) . "Request";
-        if (!class_exists($requestClassName)) {
-            trigger_error("No such api: " . $paramsArray["method"]);
-        }
-
-        $session = isset ($paramsArray["session"]) ? $paramsArray["session"] : null;
-
-        $req = new $requestClassName;
-        foreach ($paramsArray as $paraKey => $paraValue) {
-            $inflector->conf["separator"] = "_";
-            $setterMethodName = $inflector->camelize($paraKey);
-            $inflector->conf["separator"] = ".";
-            $setterMethodName = "set" . $inflector->camelize($setterMethodName);
-            if (method_exists($req, $setterMethodName)) {
-                $req->$setterMethodName ($paraValue);
-            }
-        }
-        return $this->execute($req, $session);
-    }
-
-    /**
-     * 校验$value是否非空
-     *  if not set ,return true;
-     *    if is null , return true;
-     **/
-    protected function checkEmpty($value)
-    {
-        if (!isset($value))
-            return true;
-        if ($value === null)
-            return true;
-        if (trim($value) === "")
-            return true;
-
-        return false;
-    }
-
-    /** rsaCheckV1 & rsaCheckV2
-     *  验证签名
-     *  在使用本方法前,必须初始化AopClient且传入公钥参数。
-     *  公钥是否是读取字符串还是读取文件,是根据初始化传入的值判断的。
-     **/
-    public function rsaCheckV1($params, $rsaPublicKeyFilePath, $signType = 'RSA')
-    {
-        $sign = $params['sign'];
-
-        unset($params['sign']);
-        unset($params['sign_type']);
-        return $this->verify($this->getCheckSignContent($params), $sign, $rsaPublicKeyFilePath, $signType);
-    }
-
-    public function rsaCheckV2($params, $rsaPublicKeyFilePath, $signType = 'RSA')
-    {
-        $sign = $params['sign'];
-
-        unset($params['sign']);
-        unset($params['sign_type']);
-        return $this->verify($this->getCheckSignContent($params), $sign, $rsaPublicKeyFilePath, $signType);
-    }
-
-    function getCheckSignContent($params)
-    {
-        ksort($params);
-
-        $stringToBeSigned = "";
-        $i = 0;
-        foreach ($params as $k => $v) {
-            // 转换成目标字符集
-            $v = $this->characet($v, $this->postCharset);
-
-            if ($i == 0) {
-                $stringToBeSigned .= "$k" . "=" . "$v";
-            } else {
-                $stringToBeSigned .= "&" . "$k" . "=" . "$v";
-            }
-            $i++;
-        }
-
-        unset ($k, $v);
-        return $stringToBeSigned;
-    }
-
-    function verify($data, $sign, $rsaPublicKeyFilePath, $signType = 'RSA')
-    {
-
-        if ($this->checkEmpty($this->alipayPublicKey)) {
-
-            $pubKey = $this->alipayrsaPublicKey;
-            $res = "-----BEGIN PUBLIC KEY-----\n" .
-                wordwrap($pubKey, 64, "\n", true) .
-                "\n-----END PUBLIC KEY-----";
-        } else {
-            //读取公钥文件
-            $pubKey = file_get_contents($rsaPublicKeyFilePath);
-            //转换为openssl格式密钥
-            $res = openssl_get_publickey($pubKey);
-        }
-
-        ($res) or die('支付宝RSA公钥错误。请检查公钥文件格式是否正确');
-
-        //调用openssl内置方法验签,返回bool值
-
-        $result = FALSE;
-        if ("RSA2" == $signType) {
-            $result = (openssl_verify($data, base64_decode($sign), $res, OPENSSL_ALGO_SHA256) === 1);
-        } else {
-            $result = (openssl_verify($data, base64_decode($sign), $res) === 1);
-        }
-
-        if (!$this->checkEmpty($this->alipayPublicKey)) {
-            //释放资源
-            openssl_free_key($res);
-        }
-
-        return $result;
-    }
-
-    /**
-     *  在使用本方法前,必须初始化AopClient且传入公私钥参数。
-     *  公钥是否是读取字符串还是读取文件,是根据初始化传入的值判断的。
-     **/
-    public function checkSignAndDecrypt($params, $rsaPublicKeyPem, $rsaPrivateKeyPem, $isCheckSign, $isDecrypt, $signType = 'RSA')
-    {
-        $charset = $params['charset'];
-        $bizContent = $params['biz_content'];
-        if ($isCheckSign) {
-            if (!$this->rsaCheckV2($params, $rsaPublicKeyPem, $signType)) {
-                echo "<br/>checkSign failure<br/>";
-                exit;
-            }
-        }
-        if ($isDecrypt) {
-            return $this->rsaDecrypt($bizContent, $rsaPrivateKeyPem, $charset);
-        }
-
-        return $bizContent;
-    }
-
-    /**
-     *  在使用本方法前,必须初始化AopClient且传入公私钥参数。
-     *  公钥是否是读取字符串还是读取文件,是根据初始化传入的值判断的。
-     **/
-    public function encryptAndSign($bizContent, $rsaPublicKeyPem, $rsaPrivateKeyPem, $charset, $isEncrypt, $isSign, $signType = 'RSA')
-    {
-        // 加密,并签名
-        if ($isEncrypt && $isSign) {
-            $encrypted = $this->rsaEncrypt($bizContent, $rsaPublicKeyPem, $charset);
-            $sign = $this->sign($encrypted, $signType);
-            $response = "<?xml version=\"1.0\" encoding=\"$charset\"?><alipay><response>$encrypted</response><encryption_type>RSA</encryption_type><sign>$sign</sign><sign_type>$signType</sign_type></alipay>";
-            return $response;
-        }
-        // 加密,不签名
-        if ($isEncrypt && (!$isSign)) {
-            $encrypted = $this->rsaEncrypt($bizContent, $rsaPublicKeyPem, $charset);
-            $response = "<?xml version=\"1.0\" encoding=\"$charset\"?><alipay><response>$encrypted</response><encryption_type>$signType</encryption_type></alipay>";
-            return $response;
-        }
-        // 不加密,但签名
-        if ((!$isEncrypt) && $isSign) {
-            $sign = $this->sign($bizContent, $signType);
-            $response = "<?xml version=\"1.0\" encoding=\"$charset\"?><alipay><response>$bizContent</response><sign>$sign</sign><sign_type>$signType</sign_type></alipay>";
-            return $response;
-        }
-        // 不加密,不签名
-        $response = "<?xml version=\"1.0\" encoding=\"$charset\"?>$bizContent";
-        return $response;
-    }
-
-    /**
-     *  在使用本方法前,必须初始化AopClient且传入公私钥参数。
-     *  公钥是否是读取字符串还是读取文件,是根据初始化传入的值判断的。
-     **/
-    public function rsaEncrypt($data, $rsaPublicKeyFilePath, $charset)
-    {
-        if ($this->checkEmpty($this->alipayPublicKey)) {
-            //读取字符串
-            $pubKey = $this->alipayrsaPublicKey;
-            $res = "-----BEGIN PUBLIC KEY-----\n" .
-                wordwrap($pubKey, 64, "\n", true) .
-                "\n-----END PUBLIC KEY-----";
-        } else {
-            //读取公钥文件
-            $pubKey = file_get_contents($rsaPublicKeyFilePath);
-            //转换为openssl格式密钥
-            $res = openssl_get_publickey($pubKey);
-        }
-
-        ($res) or die('支付宝RSA公钥错误。请检查公钥文件格式是否正确');
-        $blocks = $this->splitCN($data, 0, 30, $charset);
-        $chrtext  = null;
-        $encodes  = array();
-        foreach ($blocks as $n => $block) {
-            if (!openssl_public_encrypt($block, $chrtext , $res)) {
-                echo "<br/>" . openssl_error_string() . "<br/>";
-            }
-            $encodes[] = $chrtext ;
-        }
-        $chrtext = implode(",", $encodes);
-
-        return base64_encode($chrtext);
-    }
-
-    /**
-     *  在使用本方法前,必须初始化AopClient且传入公私钥参数。
-     *  公钥是否是读取字符串还是读取文件,是根据初始化传入的值判断的。
-     **/
-    public function rsaDecrypt($data, $rsaPrivateKeyPem, $charset)
-    {
-
-        if ($this->checkEmpty($this->rsaPrivateKeyFilePath)) {
-            //读字符串
-            $priKey = $this->rsaPrivateKey;
-            $res = "-----BEGIN RSA PRIVATE KEY-----\n" .
-                wordwrap($priKey, 64, "\n", true) .
-                "\n-----END RSA PRIVATE KEY-----";
-        } else {
-            $priKey = file_get_contents($this->rsaPrivateKeyFilePath);
-            $res = openssl_get_privatekey($priKey);
-        }
-        ($res) or die('您使用的私钥格式错误,请检查RSA私钥配置');
-        //转换为openssl格式密钥
-        $decodes = explode(',', $data);
-        $strnull = "";
-        $dcyCont = "";
-        foreach ($decodes as $n => $decode) {
-            if (!openssl_private_decrypt($decode, $dcyCont, $res)) {
-                echo "<br/>" . openssl_error_string() . "<br/>";
-            }
-            $strnull .= $dcyCont;
-        }
-        return $strnull;
-    }
-
-    function splitCN($cont, $n = 0, $subnum, $charset)
-    {
-        //$len = strlen($cont) / 3;
-        $arrr = array();
-        for ($i = $n; $i < strlen($cont); $i += $subnum) {
-            $res = $this->subCNchar($cont, $i, $subnum, $charset);
-            if (!empty ($res)) {
-                $arrr[] = $res;
-            }
-        }
-
-        return $arrr;
-    }
-
-    function subCNchar($str, $start = 0, $length, $charset = "gbk")
-    {
-        if (strlen($str) <= $length) {
-            return $str;
-        }
-        $re['utf-8'] = "/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|[\xe0-\xef][\x80-\xbf]{2}|[\xf0-\xff][\x80-\xbf]{3}/";
-        $re['gb2312'] = "/[\x01-\x7f]|[\xb0-\xf7][\xa0-\xfe]/";
-        $re['gbk'] = "/[\x01-\x7f]|[\x81-\xfe][\x40-\xfe]/";
-        $re['big5'] = "/[\x01-\x7f]|[\x81-\xfe]([\x40-\x7e]|\xa1-\xfe])/";
-        preg_match_all($re[$charset], $str, $match);
-        $slice = join("", array_slice($match[0], $start, $length));
-        return $slice;
-    }
-
-    function parserResponseSubCode($request, $responseContent, $respObject, $format)
-    {
-
-        if ("json" == $format) {
-
-            $apiName = $request->getApiMethodName();
-            $rootNodeName = str_replace(".", "_", $apiName) . $this->RESPONSE_SUFFIX;
-            $errorNodeName = $this->ERROR_RESPONSE;
-
-            $rootIndex = strpos($responseContent, $rootNodeName);
-            $errorIndex = strpos($responseContent, $errorNodeName);
-
-            if ($rootIndex > 0) {
-                // 内部节点对象
-                $rInnerObject = $respObject->$rootNodeName;
-            } elseif ($errorIndex > 0) {
-
-                $rInnerObject = $respObject->$errorNodeName;
-            } else {
-                return null;
-            }
-
-            // 存在属性则返回对应值
-            if (isset($rInnerObject->sub_code)) {
-
-                return $rInnerObject->sub_code;
-            } else {
-
-                return null;
-            }
-
-
-        } elseif ("xml" == $format) {
-
-            // xml格式sub_code在同一层级
-            return $respObject->sub_code;
-
-        }
-
-
-    }
-
-    function parserJSONSignData($request, $responseContent, $responseJSON)
-    {
-
-        $signData = new \SignData();
-
-        $signData->sign = $this->parserJSONSign($responseJSON);
-        $signData->signSourceData = $this->parserJSONSignSource($request, $responseContent);
-
-
-        return $signData;
-
-    }
-
-    function parserJSONSignSource($request, $responseContent)
-    {
-
-        $apiName = $request->getApiMethodName();
-        $rootNodeName = str_replace(".", "_", $apiName) . $this->RESPONSE_SUFFIX;
-
-        $rootIndex = strpos($responseContent, $rootNodeName);
-        $errorIndex = strpos($responseContent, $this->ERROR_RESPONSE);
-
-
-        if ($rootIndex > 0) {
-
-            return $this->parserJSONSource($responseContent, $rootNodeName, $rootIndex);
-        } else if ($errorIndex > 0) {
-
-            return $this->parserJSONSource($responseContent, $this->ERROR_RESPONSE, $errorIndex);
-        } else {
-
-            return null;
-        }
-
-
-    }
-
-    function parserJSONSource($responseContent, $nodeName, $nodeIndex)
-    {
-        $signDataStartIndex = $nodeIndex + strlen($nodeName) + 2;
-        $signIndex = strrpos($responseContent, "\"" . $this->SIGN_NODE_NAME . "\"");
-        // 签名前-逗号
-        $signDataEndIndex = $signIndex - 1;
-        $indexLen = $signDataEndIndex - $signDataStartIndex;
-        if ($indexLen < 0) {
-
-            return null;
-        }
-
-        return substr($responseContent, $signDataStartIndex, $indexLen);
-
-    }
-
-    function parserJSONSign($responseJSon)
-    {
-
-        return $responseJSon->sign;
-    }
-
-    function parserXMLSignData($request, $responseContent)
-    {
-
-
-        $signData = new SignData();
-
-        $signData->sign = $this->parserXMLSign($responseContent);
-        $signData->signSourceData = $this->parserXMLSignSource($request, $responseContent);
-
-
-        return $signData;
-
-
-    }
-
-    function parserXMLSignSource($request, $responseContent)
-    {
-
-
-        $apiName = $request->getApiMethodName();
-        $rootNodeName = str_replace(".", "_", $apiName) . $this->RESPONSE_SUFFIX;
-
-
-        $rootIndex = strpos($responseContent, $rootNodeName);
-        $errorIndex = strpos($responseContent, $this->ERROR_RESPONSE);
-        //		$this->echoDebug("<br/>rootNodeName:" . $rootNodeName);
-        //		$this->echoDebug("<br/> responseContent:<xmp>" . $responseContent . "</xmp>");
-
-
-        if ($rootIndex > 0) {
-
-            return $this->parserXMLSource($responseContent, $rootNodeName, $rootIndex);
-        } else if ($errorIndex > 0) {
-
-            return $this->parserXMLSource($responseContent, $this->ERROR_RESPONSE, $errorIndex);
-        } else {
-
-            return null;
-        }
-
-
-    }
-
-    function parserXMLSource($responseContent, $nodeName, $nodeIndex)
-    {
-        $signDataStartIndex = $nodeIndex + strlen($nodeName) + 1;
-        $signIndex = strrpos($responseContent, "<" . $this->SIGN_NODE_NAME . ">");
-        // 签名前-逗号
-        $signDataEndIndex = $signIndex - 1;
-        $indexLen = $signDataEndIndex - $signDataStartIndex + 1;
-
-        if ($indexLen < 0) {
-            return null;
-        }
-
-
-        return substr($responseContent, $signDataStartIndex, $indexLen);
-
-
-    }
-
-    function parserXMLSign($responseContent)
-    {
-        $signNodeName = "<" . $this->SIGN_NODE_NAME . ">";
-        $signEndNodeName = "</" . $this->SIGN_NODE_NAME . ">";
-
-        $indexOfSignNode = strpos($responseContent, $signNodeName);
-        $indexOfSignEndNode = strpos($responseContent, $signEndNodeName);
-
-
-        if ($indexOfSignNode < 0 || $indexOfSignEndNode < 0) {
-            return null;
-        }
-
-        $nodeIndex = ($indexOfSignNode + strlen($signNodeName));
-
-        $indexLen = $indexOfSignEndNode - $nodeIndex;
-
-        if ($indexLen < 0) {
-            return null;
-        }
-
-        // 签名
-        return substr($responseContent, $nodeIndex, $indexLen);
-
-    }
-
-    /**
-     * 验签
-     * @param $request
-     * @param $signData
-     * @param $resp
-     * @param $respObject
-     * @throws Exception
-     */
-    public function checkResponseSign($request, $signData, $resp, $respObject)
-    {
-
-        if (!$this->checkEmpty($this->alipayPublicKey) || !$this->checkEmpty($this->alipayrsaPublicKey)) {
-
-
-            if ($signData == null || $this->checkEmpty($signData->sign) || $this->checkEmpty($signData->signSourceData)) {
-
-                throw new Exception(" check sign Fail! The reason : signData is Empty");
-            }
-
-
-            // 获取结果sub_code
-            $responseSubCode = $this->parserResponseSubCode($request, $resp, $respObject, $this->format);
-
-
-            if (!$this->checkEmpty($responseSubCode) || ($this->checkEmpty($responseSubCode) && !$this->checkEmpty($signData->sign))) {
-
-                $checkResult = $this->verify($signData->signSourceData, $signData->sign, $this->alipayPublicKey, $this->signType);
-
-                if (!$checkResult) {
-
-                    if (strpos($signData->signSourceData, "\\/") > 0) {
-
-                        $signData->signSourceData = str_replace("\\/", "/", $signData->signSourceData);
-
-                        $checkResult = $this->verify($signData->signSourceData, $signData->sign, $this->alipayPublicKey, $this->signType);
-
-                        if (!$checkResult) {
-                            throw new Exception("check sign Fail! [sign=" . $signData->sign . ", signSourceData=" . $signData->signSourceData . "]");
-                        }
-                    } else {
-                        throw new \Exception("check sign Fail! [sign=" . $signData->sign . ", signSourceData=" . $signData->signSourceData . "]");
-                    }
-
-                }
-            }
-
-
-        }
-    }
-
-    private function setupCharsets($request)
-    {
-        if ($this->checkEmpty($this->postCharset)) {
-            $this->postCharset = 'UTF-8';
-        }
-        $str = preg_match('/[\x80-\xff]/', $this->appId) ? $this->appId : print_r($request, true);
-        $this->fileCharset = mb_detect_encoding($str, "UTF-8, GBK") == 'UTF-8' ? 'UTF-8' : 'GBK';
-    }
-
-    // 获取加密内容
-
-    private function encryptJSONSignSource($request, $responseContent)
-    {
-
-        $parsetItem = $this->parserEncryptJSONSignSource($request, $responseContent);
-
-        $bodyIndexContent = substr($responseContent, 0, $parsetItem->startIndex);
-        $bodyEndContent = substr($responseContent, $parsetItem->endIndex, strlen($responseContent) + 1 - $parsetItem->endIndex);
-
-        $bizContent = decrypt($parsetItem->encryptContent, $this->encryptKey);
-        return $bodyIndexContent . $bizContent . $bodyEndContent;
-
-    }
-
-
-    private function parserEncryptJSONSignSource($request, $responseContent)
-    {
-
-        $apiName = $request->getApiMethodName();
-        $rootNodeName = str_replace(".", "_", $apiName) . $this->RESPONSE_SUFFIX;
-
-        $rootIndex = strpos($responseContent, $rootNodeName);
-        $errorIndex = strpos($responseContent, $this->ERROR_RESPONSE);
-
-
-        if ($rootIndex > 0) {
-
-            return $this->parserEncryptJSONItem($responseContent, $rootNodeName, $rootIndex);
-        } else if ($errorIndex > 0) {
-
-            return $this->parserEncryptJSONItem($responseContent, $this->ERROR_RESPONSE, $errorIndex);
-        } else {
-
-            return null;
-        }
-
-
-    }
-
-
-    private function parserEncryptJSONItem($responseContent, $nodeName, $nodeIndex)
-    {
-        $signDataStartIndex = $nodeIndex + strlen($nodeName) + 2;
-        $signIndex = strpos($responseContent, "\"" . $this->SIGN_NODE_NAME . "\"");
-        // 签名前-逗号
-        $signDataEndIndex = $signIndex - 1;
-
-        if ($signDataEndIndex < 0) {
-
-            $signDataEndIndex = strlen($responseContent) - 1;
-        }
-
-        $indexLen = $signDataEndIndex - $signDataStartIndex;
-
-        $encContent = substr($responseContent, $signDataStartIndex + 1, $indexLen - 2);
-
-
-        $encryptParseItem = new EncryptParseItem();
-
-        $encryptParseItem->encryptContent = $encContent;
-        $encryptParseItem->startIndex = $signDataStartIndex;
-        $encryptParseItem->endIndex = $signDataEndIndex;
-
-        return $encryptParseItem;
-
-    }
-
-    // 获取加密内容
-
-    private function encryptXMLSignSource($request, $responseContent)
-    {
-
-        $parsetItem = $this->parserEncryptXMLSignSource($request, $responseContent);
-
-        $bodyIndexContent = substr($responseContent, 0, $parsetItem->startIndex);
-        $bodyEndContent = substr($responseContent, $parsetItem->endIndex, strlen($responseContent) + 1 - $parsetItem->endIndex);
-        $bizContent = decrypt($parsetItem->encryptContent, $this->encryptKey);
-
-        return $bodyIndexContent . $bizContent . $bodyEndContent;
-
-    }
-
-    private function parserEncryptXMLSignSource($request, $responseContent)
-    {
-
-
-        $apiName = $request->getApiMethodName();
-        $rootNodeName = str_replace(".", "_", $apiName) . $this->RESPONSE_SUFFIX;
-
-
-        $rootIndex = strpos($responseContent, $rootNodeName);
-        $errorIndex = strpos($responseContent, $this->ERROR_RESPONSE);
-        //		$this->echoDebug("<br/>rootNodeName:" . $rootNodeName);
-        //		$this->echoDebug("<br/> responseContent:<xmp>" . $responseContent . "</xmp>");
-
-
-        if ($rootIndex > 0) {
-
-            return $this->parserEncryptXMLItem($responseContent, $rootNodeName, $rootIndex);
-        } else if ($errorIndex > 0) {
-
-            return $this->parserEncryptXMLItem($responseContent, $this->ERROR_RESPONSE, $errorIndex);
-        } else {
-
-            return null;
-        }
-
-
-    }
-
-    private function parserEncryptXMLItem($responseContent, $nodeName, $nodeIndex)
-    {
-
-        $signDataStartIndex = $nodeIndex + strlen($nodeName) + 1;
-
-        $xmlStartNode = "<" . $this->ENCRYPT_XML_NODE_NAME . ">";
-        $xmlEndNode = "</" . $this->ENCRYPT_XML_NODE_NAME . ">";
-
-        $indexOfXmlNode = strpos($responseContent, $xmlEndNode);
-        if ($indexOfXmlNode < 0) {
-
-            $item = new EncryptParseItem();
-            $item->encryptContent = null;
-            $item->startIndex = 0;
-            $item->endIndex = 0;
-            return $item;
-        }
-
-        $startIndex = $signDataStartIndex + strlen($xmlStartNode);
-        $bizContentLen = $indexOfXmlNode - $startIndex;
-        $bizContent = substr($responseContent, $startIndex, $bizContentLen);
-
-        $encryptParseItem = new EncryptParseItem();
-        $encryptParseItem->encryptContent = $bizContent;
-        $encryptParseItem->startIndex = $signDataStartIndex;
-        $encryptParseItem->endIndex = $indexOfXmlNode + strlen($xmlEndNode);
-
-        return $encryptParseItem;
-
-    }
-
-
-    function echoDebug($content)
-    {
-
-        if ($this->debugInfo) {
-            echo "<br/>" . $content;
-        }
-
-    }
-
-
-}

+ 0 - 81
application/common/library/alipay/aop/AopEncrypt.php

@@ -1,81 +0,0 @@
-<?php
-/**
- *   加密工具类
- *
- * User: jiehua
- * Date: 16/3/30
- * Time: 下午3:25
- */
-
-
-/**
- * 加密方法
- * @param string $str
- * @return string
- */
-function encrypt($str, $screct_key)
-{
-    //AES, 128 模式加密数据 CBC
-    $screct_key = base64_decode($screct_key);
-    $str = trim($str);
-    $str = addPKCS7Padding($str);
-
-    //设置全0的IV
-    $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
-    $iv = str_repeat("\0", $iv_size);
-
-    $encrypt_str = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $screct_key, $str, MCRYPT_MODE_CBC, $iv);
-    return base64_encode($encrypt_str);
-}
-
-/**
- * 解密方法
- * @param string $str
- * @return string
- */
-function decrypt($str, $screct_key)
-{
-    //AES, 128 模式加密数据 CBC
-    $str = base64_decode($str);
-    $screct_key = base64_decode($screct_key);
-
-    //设置全0的IV
-    $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
-    $iv = str_repeat("\0", $iv_size);
-
-    $decrypt_str = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $screct_key, $str, MCRYPT_MODE_CBC, $iv);
-    $decrypt_str = stripPKSC7Padding($decrypt_str);
-    return $decrypt_str;
-}
-
-/**
- * 填充算法
- * @param string $source
- * @return string
- */
-function addPKCS7Padding($source)
-{
-    $source = trim($source);
-    $block = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
-
-    $pad = $block - (strlen($source) % $block);
-    if ($pad <= $block) {
-        $char = chr($pad);
-        $source .= str_repeat($char, $pad);
-    }
-    return $source;
-}
-
-/**
- * 移去填充算法
- * @param string $source
- * @return string
- */
-function stripPKSC7Padding($source)
-{
-    $char = substr($source, -1);
-    $num = ord($char);
-    if ($num == 62) return $source;
-    $source = substr($source, 0, -$num);
-    return $source;
-}

+ 0 - 18
application/common/library/alipay/aop/EncryptParseItem.php

@@ -1,18 +0,0 @@
-<?php
-/**
- *  TODO 补充说明
- *
- * User: jiehua
- * Date: 16/3/30
- * Time: 下午8:55
- */
-
-class EncryptParseItem
-{
-    public $startIndex;
-
-    public $endIndex;
-
-    public $encryptContent;
-
-} 

+ 0 - 16
application/common/library/alipay/aop/EncryptResponseData.php

@@ -1,16 +0,0 @@
-<?php
-/**
- *  TODO 补充说明
- *
- * User: jiehua
- * Date: 16/3/30
- * Time: 下午8:51
- */
-
-class EncryptResponseData
-{
-    public $realContent;
-
-    public $returnContent;
-
-} 

+ 0 - 15
application/common/library/alipay/aop/SignData.php

@@ -1,15 +0,0 @@
-<?php
-/**
- * Created by PhpStorm.
- * User: jiehua
- * Date: 15/5/2
- * Time: 下午6:21
- */
-
-class SignData
-{
-    public $signSourceData = null;
-
-    public $sign = null;
-
-} 

+ 0 - 14
application/common/library/alipay/aop/readme

@@ -1,14 +0,0 @@
-SDK版本升级说明
-1、去除已经放弃维护的lotusphp框架
-2、公私钥模式开发者请直接初始化AopClient,使用方法详见:aop/test/AopClientTest.php
-3、证书模式开发者请直接初始化AopCertClient,使用方法详见:aop/test/AopCertClientTest.php
-4、兼容PHP7.2以上版本
-
-使用过程中有任何问题,请加入钉钉群咨询:23311489
-
-更新时间:2020-04-15
-
-备注:
-使用证书模式本地必须开始SSL
-如果出现SSL certificate: unable to get local issuer certificate错误信息
-解决办法:到http://curl.haxx.se/ca/cacert.pem下载pem文件,并将文件拷贝到D:\phpStudy\PHPTutorial\cacert.pem 在php.ini 增加curl.cainfo = "D:\phpStudy\PHPTutorial\cacert.pem"

+ 0 - 118
application/common/library/alipay/aop/request/AftAifinFireeyeOcrImageQueryRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: aft.aifin.fireeye.ocr.image.query request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AftAifinFireeyeOcrImageQueryRequest
-{
-	/** 
-	 * OCR火眼识别
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "aft.aifin.fireeye.ocr.image.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AftFinsecureRiskplusSecurityPolicyQueryRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: aft.finsecure.riskplus.security.policy.query request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AftFinsecureRiskplusSecurityPolicyQueryRequest
-{
-	/** 
-	 * 策略咨询服务输出
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "aft.finsecure.riskplus.security.policy.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AliosOpenAutoInfoQueryRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alios.open.auto.info.query request
- *
- * @author auto create
- * @since 1.0, 2020-05-06 14:05:09
- */
-class AliosOpenAutoInfoQueryRequest
-{
-	/** 
-	 * 查询阿里车的车辆信息
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alios.open.auto.info.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayAccountExrateAdviceAcceptRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.account.exrate.advice.accept request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayAccountExrateAdviceAcceptRequest
-{
-	/** 
-	 * 标准的兑换交易受理接口
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.account.exrate.advice.accept";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayAccountExrateAllclientrateQueryRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.account.exrate.allclientrate.query request
- *
- * @author auto create
- * @since 1.0, 2019-09-27 17:03:52
- */
-class AlipayAccountExrateAllclientrateQueryRequest
-{
-	/** 
-	 * 查询客户的所有币种对最新有效汇率
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.account.exrate.allclientrate.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayAccountExrateRatequeryRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.account.exrate.ratequery request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayAccountExrateRatequeryRequest
-{
-	/** 
-	 * 对于部分签约境内当面付的商家,为了能够在境外进行推广,因此需要汇率进行币种之间的转换,本接口提供此业务场景下的汇率查询服务
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.account.exrate.ratequery";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayAccountExrateTraderequestCreateRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.account.exrate.traderequest.create request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayAccountExrateTraderequestCreateRequest
-{
-	/** 
-	 * 受理外汇交易请求
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.account.exrate.traderequest.create";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 171
application/common/library/alipay/aop/request/AlipayAcquireCancelRequest.php

@@ -1,171 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.acquire.cancel request
- *
- * @author auto create
- * @since 1.0, 2019-03-08 15:29:11
- */
-class AlipayAcquireCancelRequest
-{
-	/** 
-	 * 操作员ID。
-	 **/
-	private $operatorId;
-	
-	/** 
-	 * 操作员的类型:
-0:支付宝操作员
-1:商户的操作员
-如果传入其它值或者为空,则默认设置为1
-	 **/
-	private $operatorType;
-	
-	/** 
-	 * 支付宝合作商户网站唯一订单号。
-	 **/
-	private $outTradeNo;
-	
-	/** 
-	 * 该交易在支付宝系统中的交易流水号。
-最短16位,最长64位。
-如果同时传了out_trade_no和trade_no,则以trade_no为准。
-	 **/
-	private $tradeNo;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setOperatorId($operatorId)
-	{
-		$this->operatorId = $operatorId;
-		$this->apiParas["operator_id"] = $operatorId;
-	}
-
-	public function getOperatorId()
-	{
-		return $this->operatorId;
-	}
-
-	public function setOperatorType($operatorType)
-	{
-		$this->operatorType = $operatorType;
-		$this->apiParas["operator_type"] = $operatorType;
-	}
-
-	public function getOperatorType()
-	{
-		return $this->operatorType;
-	}
-
-	public function setOutTradeNo($outTradeNo)
-	{
-		$this->outTradeNo = $outTradeNo;
-		$this->apiParas["out_trade_no"] = $outTradeNo;
-	}
-
-	public function getOutTradeNo()
-	{
-		return $this->outTradeNo;
-	}
-
-	public function setTradeNo($tradeNo)
-	{
-		$this->tradeNo = $tradeNo;
-		$this->apiParas["trade_no"] = $tradeNo;
-	}
-
-	public function getTradeNo()
-	{
-		return $this->tradeNo;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.acquire.cancel";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 152
application/common/library/alipay/aop/request/AlipayAcquireCloseRequest.php

@@ -1,152 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.acquire.close request
- *
- * @author auto create
- * @since 1.0, 2019-03-08 15:29:11
- */
-class AlipayAcquireCloseRequest
-{
-	/** 
-	 * 卖家的操作员ID
-	 **/
-	private $operatorId;
-	
-	/** 
-	 * 支付宝合作商户网站唯一订单号
-	 **/
-	private $outTradeNo;
-	
-	/** 
-	 * 该交易在支付宝系统中的交易流水号。
-最短16位,最长64位。
-如果同时传了out_trade_no和trade_no,则以trade_no为准
-	 **/
-	private $tradeNo;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setOperatorId($operatorId)
-	{
-		$this->operatorId = $operatorId;
-		$this->apiParas["operator_id"] = $operatorId;
-	}
-
-	public function getOperatorId()
-	{
-		return $this->operatorId;
-	}
-
-	public function setOutTradeNo($outTradeNo)
-	{
-		$this->outTradeNo = $outTradeNo;
-		$this->apiParas["out_trade_no"] = $outTradeNo;
-	}
-
-	public function getOutTradeNo()
-	{
-		return $this->outTradeNo;
-	}
-
-	public function setTradeNo($tradeNo)
-	{
-		$this->tradeNo = $tradeNo;
-		$this->apiParas["trade_no"] = $tradeNo;
-	}
-
-	public function getTradeNo()
-	{
-		return $this->tradeNo;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.acquire.close";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 550
application/common/library/alipay/aop/request/AlipayAcquireCreateandpayRequest.php

@@ -1,550 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.acquire.createandpay request
- *
- * @author auto create
- * @since 1.0, 2019-07-18 14:08:22
- */
-class AlipayAcquireCreateandpayRequest
-{
-	/** 
-	 * 证书签名
-	 **/
-	private $alipayCaRequest;
-	
-	/** 
-	 * 对一笔交易的具体描述信息。如果是多种商品,请将商品描述字符串累加传给body。
-	 **/
-	private $body;
-	
-	/** 
-	 * 买家支付宝账号,可以为email或者手机号。
-	 **/
-	private $buyerEmail;
-	
-	/** 
-	 * 买家支付宝账号对应的支付宝唯一用户号。
-以2088开头的纯16位数字。
-	 **/
-	private $buyerId;
-	
-	/** 
-	 * 描述多渠道收单的渠道明细信息,json格式,具体请参见“4.5 渠道明细说明”。
-	 **/
-	private $channelParameters;
-	
-	/** 
-	 * 订单金额币种。
-目前只支持传入156(人民币)。
-如果为空,则默认设置为156。
-	 **/
-	private $currency;
-	
-	/** 
-	 * 动态ID。
-	 **/
-	private $dynamicId;
-	
-	/** 
-	 * 动态ID类型:
-&#1048698;
-soundwave:声波
-&#1048698;
-qrcode:二维码
-&#1048698;
-barcode:条码
-&#1048698;
-wave_code:声波,等同soundwave
-&#1048698;
-qr_code:二维码,等同qrcode
-&#1048698;
-bar_code:条码,等同barcode
-建议取值wave_code、qr_code、bar_code。
-	 **/
-	private $dynamicIdType;
-	
-	/** 
-	 * 用于商户的特定业务信息的传递,只有商户与支付宝约定了传递此参数且约定了参数含义,此参数才有效。
-比如可传递声波支付场景下的门店ID等信息,以json格式传输,具体请参见“4.7 业务扩展参数说明”。
-	 **/
-	private $extendParams;
-	
-	/** 
-	 * xml或json
-	 **/
-	private $formatType;
-	
-	/** 
-	 * 描述商品明细信息,json格式,具体请参见“4.3 商品明细说明”。
-	 **/
-	private $goodsDetail;
-	
-	/** 
-	 * 设置未付款交易的超时时间,一旦超时,该笔交易就会自动被关闭。
-取值范围:1m~15d。
-m-分钟,h-小时,d-天,1c-当天(无论交易何时创建,都在0点关闭)。
-该参数数值不接受小数点,如1.5h,可转换为90m。
-该功能需要联系支付宝配置关闭时间。
-	 **/
-	private $itBPay;
-	
-	/** 
-	 * 描述预付卡相关的明细信息,json格式,具体请参见“4.8 预付卡明细参数说明”。
-	 **/
-	private $mcardParameters;
-	
-	/** 
-	 * 卖家的操作员ID。
-	 **/
-	private $operatorId;
-	
-	/** 
-	 * 操作员的类型:
-&#1048698;
-0:支付宝操作员
-&#1048698;
-1:商户的操作员
-如果传入其它值或者为空,则默认设置为1。
-	 **/
-	private $operatorType;
-	
-	/** 
-	 * 支付宝合作商户网站唯一订单号。
-	 **/
-	private $outTradeNo;
-	
-	/** 
-	 * 订单中商品的单价。
-如果请求时传入本参数,则必须满足total_fee=price×quantity的条件。
-	 **/
-	private $price;
-	
-	/** 
-	 * 订单中商品的数量。
-如果请求时传入本参数,则必须满足total_fee=price×quantity的条件。
-	 **/
-	private $quantity;
-	
-	/** 
-	 * 业务关联ID集合,用于放置商户的订单号、支付流水号等信息,json格式,具体请参见“4.6 业务关联ID集合说明”。
-	 **/
-	private $refIds;
-	
-	/** 
-	 * 描述分账明细信息,json格式,具体请参见“4.4 分账明细说明”。
-	 **/
-	private $royaltyParameters;
-	
-	/** 
-	 * 卖家的分账类型,目前只支持传入ROYALTY(普通分账类型)。
-	 **/
-	private $royaltyType;
-	
-	/** 
-	 * 卖家支付宝账号,可以为email或者手机号。
-如果seller_id不为空,则以seller_id的值作为卖家账号,忽略本参数。
-	 **/
-	private $sellerEmail;
-	
-	/** 
-	 * 卖家支付宝账号对应的支付宝唯一用户号。
-以2088开头的纯16位数字。
-如果和seller_email同时为空,则本参数默认填充partner的值。
-	 **/
-	private $sellerId;
-	
-	/** 
-	 * 收银台页面上,商品展示的超链接。
-	 **/
-	private $showUrl;
-	
-	/** 
-	 * 商品的标题/交易标题/订单标题/订单关键字等。
-该参数最长为128个汉字。
-	 **/
-	private $subject;
-	
-	/** 
-	 * 该笔订单的资金总额,取值范围[0.01,100000000],精确到小数点后2位。
-	 **/
-	private $totalFee;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setAlipayCaRequest($alipayCaRequest)
-	{
-		$this->alipayCaRequest = $alipayCaRequest;
-		$this->apiParas["alipay_ca_request"] = $alipayCaRequest;
-	}
-
-	public function getAlipayCaRequest()
-	{
-		return $this->alipayCaRequest;
-	}
-
-	public function setBody($body)
-	{
-		$this->body = $body;
-		$this->apiParas["body"] = $body;
-	}
-
-	public function getBody()
-	{
-		return $this->body;
-	}
-
-	public function setBuyerEmail($buyerEmail)
-	{
-		$this->buyerEmail = $buyerEmail;
-		$this->apiParas["buyer_email"] = $buyerEmail;
-	}
-
-	public function getBuyerEmail()
-	{
-		return $this->buyerEmail;
-	}
-
-	public function setBuyerId($buyerId)
-	{
-		$this->buyerId = $buyerId;
-		$this->apiParas["buyer_id"] = $buyerId;
-	}
-
-	public function getBuyerId()
-	{
-		return $this->buyerId;
-	}
-
-	public function setChannelParameters($channelParameters)
-	{
-		$this->channelParameters = $channelParameters;
-		$this->apiParas["channel_parameters"] = $channelParameters;
-	}
-
-	public function getChannelParameters()
-	{
-		return $this->channelParameters;
-	}
-
-	public function setCurrency($currency)
-	{
-		$this->currency = $currency;
-		$this->apiParas["currency"] = $currency;
-	}
-
-	public function getCurrency()
-	{
-		return $this->currency;
-	}
-
-	public function setDynamicId($dynamicId)
-	{
-		$this->dynamicId = $dynamicId;
-		$this->apiParas["dynamic_id"] = $dynamicId;
-	}
-
-	public function getDynamicId()
-	{
-		return $this->dynamicId;
-	}
-
-	public function setDynamicIdType($dynamicIdType)
-	{
-		$this->dynamicIdType = $dynamicIdType;
-		$this->apiParas["dynamic_id_type"] = $dynamicIdType;
-	}
-
-	public function getDynamicIdType()
-	{
-		return $this->dynamicIdType;
-	}
-
-	public function setExtendParams($extendParams)
-	{
-		$this->extendParams = $extendParams;
-		$this->apiParas["extend_params"] = $extendParams;
-	}
-
-	public function getExtendParams()
-	{
-		return $this->extendParams;
-	}
-
-	public function setFormatType($formatType)
-	{
-		$this->formatType = $formatType;
-		$this->apiParas["format_type"] = $formatType;
-	}
-
-	public function getFormatType()
-	{
-		return $this->formatType;
-	}
-
-	public function setGoodsDetail($goodsDetail)
-	{
-		$this->goodsDetail = $goodsDetail;
-		$this->apiParas["goods_detail"] = $goodsDetail;
-	}
-
-	public function getGoodsDetail()
-	{
-		return $this->goodsDetail;
-	}
-
-	public function setItBPay($itBPay)
-	{
-		$this->itBPay = $itBPay;
-		$this->apiParas["it_b_pay"] = $itBPay;
-	}
-
-	public function getItBPay()
-	{
-		return $this->itBPay;
-	}
-
-	public function setMcardParameters($mcardParameters)
-	{
-		$this->mcardParameters = $mcardParameters;
-		$this->apiParas["mcard_parameters"] = $mcardParameters;
-	}
-
-	public function getMcardParameters()
-	{
-		return $this->mcardParameters;
-	}
-
-	public function setOperatorId($operatorId)
-	{
-		$this->operatorId = $operatorId;
-		$this->apiParas["operator_id"] = $operatorId;
-	}
-
-	public function getOperatorId()
-	{
-		return $this->operatorId;
-	}
-
-	public function setOperatorType($operatorType)
-	{
-		$this->operatorType = $operatorType;
-		$this->apiParas["operator_type"] = $operatorType;
-	}
-
-	public function getOperatorType()
-	{
-		return $this->operatorType;
-	}
-
-	public function setOutTradeNo($outTradeNo)
-	{
-		$this->outTradeNo = $outTradeNo;
-		$this->apiParas["out_trade_no"] = $outTradeNo;
-	}
-
-	public function getOutTradeNo()
-	{
-		return $this->outTradeNo;
-	}
-
-	public function setPrice($price)
-	{
-		$this->price = $price;
-		$this->apiParas["price"] = $price;
-	}
-
-	public function getPrice()
-	{
-		return $this->price;
-	}
-
-	public function setQuantity($quantity)
-	{
-		$this->quantity = $quantity;
-		$this->apiParas["quantity"] = $quantity;
-	}
-
-	public function getQuantity()
-	{
-		return $this->quantity;
-	}
-
-	public function setRefIds($refIds)
-	{
-		$this->refIds = $refIds;
-		$this->apiParas["ref_ids"] = $refIds;
-	}
-
-	public function getRefIds()
-	{
-		return $this->refIds;
-	}
-
-	public function setRoyaltyParameters($royaltyParameters)
-	{
-		$this->royaltyParameters = $royaltyParameters;
-		$this->apiParas["royalty_parameters"] = $royaltyParameters;
-	}
-
-	public function getRoyaltyParameters()
-	{
-		return $this->royaltyParameters;
-	}
-
-	public function setRoyaltyType($royaltyType)
-	{
-		$this->royaltyType = $royaltyType;
-		$this->apiParas["royalty_type"] = $royaltyType;
-	}
-
-	public function getRoyaltyType()
-	{
-		return $this->royaltyType;
-	}
-
-	public function setSellerEmail($sellerEmail)
-	{
-		$this->sellerEmail = $sellerEmail;
-		$this->apiParas["seller_email"] = $sellerEmail;
-	}
-
-	public function getSellerEmail()
-	{
-		return $this->sellerEmail;
-	}
-
-	public function setSellerId($sellerId)
-	{
-		$this->sellerId = $sellerId;
-		$this->apiParas["seller_id"] = $sellerId;
-	}
-
-	public function getSellerId()
-	{
-		return $this->sellerId;
-	}
-
-	public function setShowUrl($showUrl)
-	{
-		$this->showUrl = $showUrl;
-		$this->apiParas["show_url"] = $showUrl;
-	}
-
-	public function getShowUrl()
-	{
-		return $this->showUrl;
-	}
-
-	public function setSubject($subject)
-	{
-		$this->subject = $subject;
-		$this->apiParas["subject"] = $subject;
-	}
-
-	public function getSubject()
-	{
-		return $this->subject;
-	}
-
-	public function setTotalFee($totalFee)
-	{
-		$this->totalFee = $totalFee;
-		$this->apiParas["total_fee"] = $totalFee;
-	}
-
-	public function getTotalFee()
-	{
-		return $this->totalFee;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.acquire.createandpay";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 402
application/common/library/alipay/aop/request/AlipayAcquirePrecreateRequest.php

@@ -1,402 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.acquire.precreate request
- *
- * @author auto create
- * @since 1.0, 2019-03-08 15:29:11
- */
-class AlipayAcquirePrecreateRequest
-{
-	/** 
-	 * 对一笔交易的具体描述信息。如果是多种商品,请将商品描述字符串累加传给body
-	 **/
-	private $body;
-	
-	/** 
-	 * 描述多渠道收单的渠道明细信息,json格式
-	 **/
-	private $channelParameters;
-	
-	/** 
-	 * 订单金额币种。目前只支持传入156(人民币)。
-如果为空,则默认设置为156
-	 **/
-	private $currency;
-	
-	/** 
-	 * 公用业务扩展信息。用于商户的特定业务信息的传递,只有商户与支付宝约定了传递此参数且约定了参数含义,此参数才有效。
-比如可传递二维码支付场景下的门店ID等信息,以json格式传输。
-	 **/
-	private $extendParams;
-	
-	/** 
-	 * 描述商品明细信息,json格式。
-	 **/
-	private $goodsDetail;
-	
-	/** 
-	 * 订单支付超时时间。设置未付款交易的超时时间,一旦超时,该笔交易就会自动被关闭。
-取值范围:1m~15d。
-m-分钟,h-小时,d-天,1c-当天(无论交易何时创建,都在0点关闭)。
-该参数数值不接受小数点,如1.5h,可转换为90m。
-该功能需要联系支付宝配置关闭时间。
-	 **/
-	private $itBPay;
-	
-	/** 
-	 * 操作员的类型:
-0:支付宝操作员
-1:商户的操作员
-如果传入其它值或者为空,则默认设置为1
-	 **/
-	private $operatorCode;
-	
-	/** 
-	 * 卖家的操作员ID
-	 **/
-	private $operatorId;
-	
-	/** 
-	 * 支付宝合作商户网站唯一订单号
-	 **/
-	private $outTradeNo;
-	
-	/** 
-	 * 订单中商品的单价。
-如果请求时传入本参数,则必须满足total_fee=price×quantity的条件
-	 **/
-	private $price;
-	
-	/** 
-	 * 订单中商品的数量。
-如果请求时传入本参数,则必须满足total_fee=price×quantity的条件
-	 **/
-	private $quantity;
-	
-	/** 
-	 * 分账信息。
-描述分账明细信息,json格式
-	 **/
-	private $royaltyParameters;
-	
-	/** 
-	 * 分账类型。卖家的分账类型,目前只支持传入ROYALTY(普通分账类型)
-	 **/
-	private $royaltyType;
-	
-	/** 
-	 * 卖家支付宝账号,可以为email或者手机号。如果seller_id不为空,则以seller_id的值作为卖家账号,忽略本参数
-	 **/
-	private $sellerEmail;
-	
-	/** 
-	 * 卖家支付宝账号对应的支付宝唯一用户号,以2088开头的纯16位数字。如果和seller_email同时为空,则本参数默认填充partner的值
-	 **/
-	private $sellerId;
-	
-	/** 
-	 * 收银台页面上,商品展示的超链接
-	 **/
-	private $showUrl;
-	
-	/** 
-	 * 商品购买
-	 **/
-	private $subject;
-	
-	/** 
-	 * 订单金额。该笔订单的资金总额,取值范围[0.01,100000000],精确到小数点后2位。
-	 **/
-	private $totalFee;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBody($body)
-	{
-		$this->body = $body;
-		$this->apiParas["body"] = $body;
-	}
-
-	public function getBody()
-	{
-		return $this->body;
-	}
-
-	public function setChannelParameters($channelParameters)
-	{
-		$this->channelParameters = $channelParameters;
-		$this->apiParas["channel_parameters"] = $channelParameters;
-	}
-
-	public function getChannelParameters()
-	{
-		return $this->channelParameters;
-	}
-
-	public function setCurrency($currency)
-	{
-		$this->currency = $currency;
-		$this->apiParas["currency"] = $currency;
-	}
-
-	public function getCurrency()
-	{
-		return $this->currency;
-	}
-
-	public function setExtendParams($extendParams)
-	{
-		$this->extendParams = $extendParams;
-		$this->apiParas["extend_params"] = $extendParams;
-	}
-
-	public function getExtendParams()
-	{
-		return $this->extendParams;
-	}
-
-	public function setGoodsDetail($goodsDetail)
-	{
-		$this->goodsDetail = $goodsDetail;
-		$this->apiParas["goods_detail"] = $goodsDetail;
-	}
-
-	public function getGoodsDetail()
-	{
-		return $this->goodsDetail;
-	}
-
-	public function setItBPay($itBPay)
-	{
-		$this->itBPay = $itBPay;
-		$this->apiParas["it_b_pay"] = $itBPay;
-	}
-
-	public function getItBPay()
-	{
-		return $this->itBPay;
-	}
-
-	public function setOperatorCode($operatorCode)
-	{
-		$this->operatorCode = $operatorCode;
-		$this->apiParas["operator_code"] = $operatorCode;
-	}
-
-	public function getOperatorCode()
-	{
-		return $this->operatorCode;
-	}
-
-	public function setOperatorId($operatorId)
-	{
-		$this->operatorId = $operatorId;
-		$this->apiParas["operator_id"] = $operatorId;
-	}
-
-	public function getOperatorId()
-	{
-		return $this->operatorId;
-	}
-
-	public function setOutTradeNo($outTradeNo)
-	{
-		$this->outTradeNo = $outTradeNo;
-		$this->apiParas["out_trade_no"] = $outTradeNo;
-	}
-
-	public function getOutTradeNo()
-	{
-		return $this->outTradeNo;
-	}
-
-	public function setPrice($price)
-	{
-		$this->price = $price;
-		$this->apiParas["price"] = $price;
-	}
-
-	public function getPrice()
-	{
-		return $this->price;
-	}
-
-	public function setQuantity($quantity)
-	{
-		$this->quantity = $quantity;
-		$this->apiParas["quantity"] = $quantity;
-	}
-
-	public function getQuantity()
-	{
-		return $this->quantity;
-	}
-
-	public function setRoyaltyParameters($royaltyParameters)
-	{
-		$this->royaltyParameters = $royaltyParameters;
-		$this->apiParas["royalty_parameters"] = $royaltyParameters;
-	}
-
-	public function getRoyaltyParameters()
-	{
-		return $this->royaltyParameters;
-	}
-
-	public function setRoyaltyType($royaltyType)
-	{
-		$this->royaltyType = $royaltyType;
-		$this->apiParas["royalty_type"] = $royaltyType;
-	}
-
-	public function getRoyaltyType()
-	{
-		return $this->royaltyType;
-	}
-
-	public function setSellerEmail($sellerEmail)
-	{
-		$this->sellerEmail = $sellerEmail;
-		$this->apiParas["seller_email"] = $sellerEmail;
-	}
-
-	public function getSellerEmail()
-	{
-		return $this->sellerEmail;
-	}
-
-	public function setSellerId($sellerId)
-	{
-		$this->sellerId = $sellerId;
-		$this->apiParas["seller_id"] = $sellerId;
-	}
-
-	public function getSellerId()
-	{
-		return $this->sellerId;
-	}
-
-	public function setShowUrl($showUrl)
-	{
-		$this->showUrl = $showUrl;
-		$this->apiParas["show_url"] = $showUrl;
-	}
-
-	public function getShowUrl()
-	{
-		return $this->showUrl;
-	}
-
-	public function setSubject($subject)
-	{
-		$this->subject = $subject;
-		$this->apiParas["subject"] = $subject;
-	}
-
-	public function getSubject()
-	{
-		return $this->subject;
-	}
-
-	public function setTotalFee($totalFee)
-	{
-		$this->totalFee = $totalFee;
-		$this->apiParas["total_fee"] = $totalFee;
-	}
-
-	public function getTotalFee()
-	{
-		return $this->totalFee;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.acquire.precreate";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 136
application/common/library/alipay/aop/request/AlipayAcquireQueryRequest.php

@@ -1,136 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.acquire.query request
- *
- * @author auto create
- * @since 1.0, 2019-03-08 15:29:11
- */
-class AlipayAcquireQueryRequest
-{
-	/** 
-	 * 支付宝合作商户网站唯一订单号
-	 **/
-	private $outTradeNo;
-	
-	/** 
-	 * 该交易在支付宝系统中的交易流水号。
-最短16位,最长64位。
-如果同时传了out_trade_no和trade_no,则以trade_no为准。
-	 **/
-	private $tradeNo;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setOutTradeNo($outTradeNo)
-	{
-		$this->outTradeNo = $outTradeNo;
-		$this->apiParas["out_trade_no"] = $outTradeNo;
-	}
-
-	public function getOutTradeNo()
-	{
-		return $this->outTradeNo;
-	}
-
-	public function setTradeNo($tradeNo)
-	{
-		$this->tradeNo = $tradeNo;
-		$this->apiParas["trade_no"] = $tradeNo;
-	}
-
-	public function getTradeNo()
-	{
-		return $this->tradeNo;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.acquire.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 236
application/common/library/alipay/aop/request/AlipayAcquireRefundRequest.php

@@ -1,236 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.acquire.refund request
- *
- * @author auto create
- * @since 1.0, 2019-03-08 15:29:11
- */
-class AlipayAcquireRefundRequest
-{
-	/** 
-	 * 卖家的操作员ID。
-	 **/
-	private $operatorId;
-	
-	/** 
-	 * 操作员的类型:
-0:支付宝操作员
-1:商户的操作员
-如果传入其它值或者为空,则默认设置为1。
-	 **/
-	private $operatorType;
-	
-	/** 
-	 * 商户退款请求单号,用以标识本次交易的退款请求。
-如果不传入本参数,则以out_trade_no填充本参数的值。同时,认为本次请求为全额退款,要求退款金额和交易支付金额一致。
-	 **/
-	private $outRequestNo;
-	
-	/** 
-	 * 商户网站唯一订单号
-	 **/
-	private $outTradeNo;
-	
-	/** 
-	 * 业务关联ID集合,用于放置商户的退款单号、退款流水号等信息,json格式
-	 **/
-	private $refIds;
-	
-	/** 
-	 * 退款金额;退款金额不能大于订单金额,全额退款必须与订单金额一致。
-	 **/
-	private $refundAmount;
-	
-	/** 
-	 * 退款原因说明。
-	 **/
-	private $refundReason;
-	
-	/** 
-	 * 该交易在支付宝系统中的交易流水号。
-最短16位,最长64位。
-如果同时传了out_trade_no和trade_no,则以trade_no为准
-	 **/
-	private $tradeNo;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setOperatorId($operatorId)
-	{
-		$this->operatorId = $operatorId;
-		$this->apiParas["operator_id"] = $operatorId;
-	}
-
-	public function getOperatorId()
-	{
-		return $this->operatorId;
-	}
-
-	public function setOperatorType($operatorType)
-	{
-		$this->operatorType = $operatorType;
-		$this->apiParas["operator_type"] = $operatorType;
-	}
-
-	public function getOperatorType()
-	{
-		return $this->operatorType;
-	}
-
-	public function setOutRequestNo($outRequestNo)
-	{
-		$this->outRequestNo = $outRequestNo;
-		$this->apiParas["out_request_no"] = $outRequestNo;
-	}
-
-	public function getOutRequestNo()
-	{
-		return $this->outRequestNo;
-	}
-
-	public function setOutTradeNo($outTradeNo)
-	{
-		$this->outTradeNo = $outTradeNo;
-		$this->apiParas["out_trade_no"] = $outTradeNo;
-	}
-
-	public function getOutTradeNo()
-	{
-		return $this->outTradeNo;
-	}
-
-	public function setRefIds($refIds)
-	{
-		$this->refIds = $refIds;
-		$this->apiParas["ref_ids"] = $refIds;
-	}
-
-	public function getRefIds()
-	{
-		return $this->refIds;
-	}
-
-	public function setRefundAmount($refundAmount)
-	{
-		$this->refundAmount = $refundAmount;
-		$this->apiParas["refund_amount"] = $refundAmount;
-	}
-
-	public function getRefundAmount()
-	{
-		return $this->refundAmount;
-	}
-
-	public function setRefundReason($refundReason)
-	{
-		$this->refundReason = $refundReason;
-		$this->apiParas["refund_reason"] = $refundReason;
-	}
-
-	public function getRefundReason()
-	{
-		return $this->refundReason;
-	}
-
-	public function setTradeNo($tradeNo)
-	{
-		$this->tradeNo = $tradeNo;
-		$this->apiParas["trade_no"] = $tradeNo;
-	}
-
-	public function getTradeNo()
-	{
-		return $this->tradeNo;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.acquire.refund";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayAppTokenGetRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.app.token.get request
- *
- * @author auto create
- * @since 1.0, 2019-03-26 17:00:00
- */
-class AlipayAppTokenGetRequest
-{
-	/** 
-	 * 应用安全码
-	 **/
-	private $secret;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setSecret($secret)
-	{
-		$this->secret = $secret;
-		$this->apiParas["secret"] = $secret;
-	}
-
-	public function getSecret()
-	{
-		return $this->secret;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.app.token.get";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 103
application/common/library/alipay/aop/request/AlipayAssetPointBalanceQueryRequest.php

@@ -1,103 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.asset.point.balance.query request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayAssetPointBalanceQueryRequest
-{
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function getApiMethodName()
-	{
-		return "alipay.asset.point.balance.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 103
application/common/library/alipay/aop/request/AlipayAssetPointBudgetQueryRequest.php

@@ -1,103 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.asset.point.budget.query request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayAssetPointBudgetQueryRequest
-{
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function getApiMethodName()
-	{
-		return "alipay.asset.point.budget.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayAssetPointOrderCreateRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.asset.point.order.create request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayAssetPointOrderCreateRequest
-{
-	/** 
-	 * 商户在采购完集分宝后可以通过此接口发放集分宝
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.asset.point.order.create";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayAssetPointOrderQueryRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.asset.point.order.query request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayAssetPointOrderQueryRequest
-{
-	/** 
-	 * 商户在调用集分宝发放接口后可以通过此接口查询发放情况
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.asset.point.order.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayBossCsChannelQueryRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.boss.cs.channel.query request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayBossCsChannelQueryRequest
-{
-	/** 
-	 * 云客服热线数据查询,云客服会有很多外部客服,他们需要查询落地在站内的自己公司的服务数据。
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.boss.cs.channel.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 103
application/common/library/alipay/aop/request/AlipayBossFncXwbtestRetModifyRequest.php

@@ -1,103 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.boss.fnc.xwbtest.ret.modify request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayBossFncXwbtestRetModifyRequest
-{
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function getApiMethodName()
-	{
-		return "alipay.boss.fnc.xwbtest.ret.modify";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayBossProdArrangementOfflineQueryRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.boss.prod.arrangement.offline.query request
- *
- * @author auto create
- * @since 1.0, 2019-03-08 15:29:11
- */
-class AlipayBossProdArrangementOfflineQueryRequest
-{
-	/** 
-	 * 签约销售方案的主站产品码,目前只支持ONLINE_TRADE_PAY(在线购买签约)和FACE_TO_FACE_PAYMENT(当面付)两个常量值,不允许传入其他值,否则报SYSTEM_ERROR异常。不传值时,默认查询FACE_TO_FACE_PAYM(当面付产品)。
-	 **/
-	private $productCode;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setProductCode($productCode)
-	{
-		$this->productCode = $productCode;
-		$this->apiParas["product_code"] = $productCode;
-	}
-
-	public function getProductCode()
-	{
-		return $this->productCode;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.boss.prod.arrangement.offline.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayBossProdMyTestQueryRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.boss.prod.my.test.query request
- *
- * @author auto create
- * @since 1.0, 2020-02-11 17:00:00
- */
-class AlipayBossProdMyTestQueryRequest
-{
-	/** 
-	 * 明焕open测试
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.boss.prod.my.test.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 103
application/common/library/alipay/aop/request/AlipayCommerceAdContractSignRequest.php

@@ -1,103 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.ad.contract.sign request
- *
- * @author auto create
- * @since 1.0, 2019-02-21 15:05:00
- */
-class AlipayCommerceAdContractSignRequest
-{
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.ad.contract.sign";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceAirCallcenterTradeApplyRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.air.callcenter.trade.apply request
- *
- * @author auto create
- * @since 1.0, 2020-03-03 12:10:07
- */
-class AlipayCommerceAirCallcenterTradeApplyRequest
-{
-	/** 
-	 * 航司电话订票待申请接口
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.air.callcenter.trade.apply";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceAirXfgDsgModifyRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.air.xfg.dsg.modify request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayCommerceAirXfgDsgModifyRequest
-{
-	/** 
-	 * 吃饭更好
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.air.xfg.dsg.modify";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 103
application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorCityQueryRequest.php

@@ -1,103 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.cityfacilitator.city.query request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayCommerceCityfacilitatorCityQueryRequest
-{
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.cityfacilitator.city.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorDepositCancelRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.cityfacilitator.deposit.cancel request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayCommerceCityfacilitatorDepositCancelRequest
-{
-	/** 
-	 * 合作渠道可通过该接口补登扣款取消请求,以帮助支付宝将用户的资金退给用户
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.cityfacilitator.deposit.cancel";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorDepositConfirmRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.cityfacilitator.deposit.confirm request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayCommerceCityfacilitatorDepositConfirmRequest
-{
-	/** 
-	 * 合作渠道可通过该接口补登单笔圈存确认扣款请求,以帮助支付宝将用户的资金结算给指定的渠道,不支持单笔拆分
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.cityfacilitator.deposit.confirm";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorDepositQueryRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.cityfacilitator.deposit.query request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayCommerceCityfacilitatorDepositQueryRequest
-{
-	/** 
-	 * 商户查询用户的充值转账记录
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.cityfacilitator.deposit.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorFunctionQueryRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.cityfacilitator.function.query request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayCommerceCityfacilitatorFunctionQueryRequest
-{
-	/** 
-	 * 基于设备和城市查询当前支持的功能
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.cityfacilitator.function.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorScriptQueryRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.cityfacilitator.script.query request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayCommerceCityfacilitatorScriptQueryRequest
-{
-	/** 
-	 * 查询城市一卡通的判卡、读卡脚本
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.cityfacilitator.script.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorStationQueryRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.cityfacilitator.station.query request
- *
- * @author auto create
- * @since 1.0, 2019-10-10 16:31:07
- */
-class AlipayCommerceCityfacilitatorStationQueryRequest
-{
-	/** 
-	 * 地铁购票站点查询
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.cityfacilitator.station.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorVoucherBatchqueryRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.cityfacilitator.voucher.batchquery request
- *
- * @author auto create
- * @since 1.0, 2019-10-10 16:31:37
- */
-class AlipayCommerceCityfacilitatorVoucherBatchqueryRequest
-{
-	/** 
-	 * 地铁购票订单批量查询
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.cityfacilitator.voucher.batchquery";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorVoucherCancelRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.cityfacilitator.voucher.cancel request
- *
- * @author auto create
- * @since 1.0, 2019-10-10 16:31:52
- */
-class AlipayCommerceCityfacilitatorVoucherCancelRequest
-{
-	/** 
-	 * 钱包中地铁票购票,获得核销码,线下渠道商凭核销码撤销该笔交易
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.cityfacilitator.voucher.cancel";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorVoucherConfirmRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.cityfacilitator.voucher.confirm request
- *
- * @author auto create
- * @since 1.0, 2019-10-10 16:30:39
- */
-class AlipayCommerceCityfacilitatorVoucherConfirmRequest
-{
-	/** 
-	 * 钱包中地铁票购票,获得核销码,线下地铁自助购票机上凭核销码取票,购票确认
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.cityfacilitator.voucher.confirm";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorVoucherGenerateRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.cityfacilitator.voucher.generate request
- *
- * @author auto create
- * @since 1.0, 2019-10-10 16:30:53
- */
-class AlipayCommerceCityfacilitatorVoucherGenerateRequest
-{
-	/** 
-	 * 地铁购票核销码发码
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.cityfacilitator.voucher.generate";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorVoucherQueryRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.cityfacilitator.voucher.query request
- *
- * @author auto create
- * @since 1.0, 2019-01-07 20:51:15
- */
-class AlipayCommerceCityfacilitatorVoucherQueryRequest
-{
-	/** 
-	 * 钱包中地铁票购票,获得核销码,线下地铁自助购票机上凭核销码取票,渠道商凭用户输入的核销码调接口查询核销码的有效性。
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.cityfacilitator.voucher.query";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorVoucherRefundRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.cityfacilitator.voucher.refund request
- *
- * @author auto create
- * @since 1.0, 2019-10-10 16:32:08
- */
-class AlipayCommerceCityfacilitatorVoucherRefundRequest
-{
-	/** 
-	 * 地铁购票发码退款
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.cityfacilitator.voucher.refund";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceCityfacilitatorVoucherUploadRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.cityfacilitator.voucher.upload request
- *
- * @author auto create
- * @since 1.0, 2019-10-10 16:30:13
- */
-class AlipayCommerceCityfacilitatorVoucherUploadRequest
-{
-	/** 
-	 * 钱包中地铁票购票,获得核销码,线下地铁自助购票机上凭核销码取票,票号上传接口
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.cityfacilitator.voucher.upload";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceDataCampaignCreateRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.data.campaign.create request
- *
- * @author auto create
- * @since 1.0, 2020-04-13 14:06:53
- */
-class AlipayCommerceDataCampaignCreateRequest
-{
-	/** 
-	 * 集点活动配置接口
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.data.campaign.create";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceDataCampaignSendRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.data.campaign.send request
- *
- * @author auto create
- * @since 1.0, 2020-04-23 13:06:14
- */
-class AlipayCommerceDataCampaignSendRequest
-{
-	/** 
-	 * 集点数据回流接口
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.data.campaign.send";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

+ 0 - 118
application/common/library/alipay/aop/request/AlipayCommerceDataCustommetricSyncRequest.php

@@ -1,118 +0,0 @@
-<?php
-/**
- * ALIPAY API: alipay.commerce.data.custommetric.sync request
- *
- * @author auto create
- * @since 1.0, 2019-03-22 18:10:00
- */
-class AlipayCommerceDataCustommetricSyncRequest
-{
-	/** 
-	 * 商户自主监控自定义指标数据上报接口
-	 **/
-	private $bizContent;
-
-	private $apiParas = array();
-	private $terminalType;
-	private $terminalInfo;
-	private $prodCode;
-	private $apiVersion="1.0";
-	private $notifyUrl;
-	private $returnUrl;
-    private $needEncrypt=false;
-
-	
-	public function setBizContent($bizContent)
-	{
-		$this->bizContent = $bizContent;
-		$this->apiParas["biz_content"] = $bizContent;
-	}
-
-	public function getBizContent()
-	{
-		return $this->bizContent;
-	}
-
-	public function getApiMethodName()
-	{
-		return "alipay.commerce.data.custommetric.sync";
-	}
-
-	public function setNotifyUrl($notifyUrl)
-	{
-		$this->notifyUrl=$notifyUrl;
-	}
-
-	public function getNotifyUrl()
-	{
-		return $this->notifyUrl;
-	}
-
-	public function setReturnUrl($returnUrl)
-	{
-		$this->returnUrl=$returnUrl;
-	}
-
-	public function getReturnUrl()
-	{
-		return $this->returnUrl;
-	}
-
-	public function getApiParas()
-	{
-		return $this->apiParas;
-	}
-
-	public function getTerminalType()
-	{
-		return $this->terminalType;
-	}
-
-	public function setTerminalType($terminalType)
-	{
-		$this->terminalType = $terminalType;
-	}
-
-	public function getTerminalInfo()
-	{
-		return $this->terminalInfo;
-	}
-
-	public function setTerminalInfo($terminalInfo)
-	{
-		$this->terminalInfo = $terminalInfo;
-	}
-
-	public function getProdCode()
-	{
-		return $this->prodCode;
-	}
-
-	public function setProdCode($prodCode)
-	{
-		$this->prodCode = $prodCode;
-	}
-
-	public function setApiVersion($apiVersion)
-	{
-		$this->apiVersion=$apiVersion;
-	}
-
-	public function getApiVersion()
-	{
-		return $this->apiVersion;
-	}
-
-  public function setNeedEncrypt($needEncrypt)
-  {
-
-     $this->needEncrypt=$needEncrypt;
-
-  }
-
-  public function getNeedEncrypt()
-  {
-    return $this->needEncrypt;
-  }
-
-}

Някои файлове не бяха показани, защото твърде много файлове са промени