From 78e79175a3aa0fd1d46aa101da5d40773b7a1e26 Mon Sep 17 00:00:00 2001 From: liaofei <136327134@qq.com> Date: Fri, 22 Nov 2019 12:07:28 +0800 Subject: [PATCH] =?UTF-8?q?=E6=96=B0=E5=A2=9E=E6=B5=B7=E6=8A=A5=E7=94=9F?= =?UTF-8?q?=E6=88=90=E7=B1=BB?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../controller/user/UserBillController.php | 309 +++++++++--------- .../controller/wechat/WechatController.php | 26 +- crmeb/crmeb/services/CanvasService.php | 301 +++++++++++++++++ crmeb/crmeb/services/UploadService.php | 9 +- crmeb/route/api/route.php | 3 +- 5 files changed, 488 insertions(+), 160 deletions(-) create mode 100644 crmeb/crmeb/services/CanvasService.php diff --git a/crmeb/app/api/controller/user/UserBillController.php b/crmeb/app/api/controller/user/UserBillController.php index 94015c20..17401108 100644 --- a/crmeb/app/api/controller/user/UserBillController.php +++ b/crmeb/app/api/controller/user/UserBillController.php @@ -1,4 +1,5 @@ uid(); - $lastDayCount = UserBill::yesterdayCommissionSum($uid);//昨天的佣金 - $extractCount = UserExtract::extractSum($uid);//累计提现金额 - $commissionCount = UserBill::getBrokerage($uid);//获取总佣金 - if($commissionCount > 0){ - $rechargeCount = UserBill::getRecharge($uid);//累计充值 - $orderYuePrice = StoreOrder::getOrderStatusYueSum($uid);//余额累计消费 - $systemAdd = UserBill::getSystemAdd($uid);//后台添加余额 - $yueCount = bcadd($rechargeCount,$systemAdd,2);// 后台添加余额 + 累计充值 = 非佣金的总金额 - $orderYuePrice = $yueCount > $orderYuePrice ? 0 : bcsub($orderYuePrice,$yueCount,2);// 余额累计消费(使用佣金消费的金额) - $commissionCount = bcsub($commissionCount, $extractCount,2);//减去已提现金额 - $extractPriceCount = UserExtract::userExtractTotalPrice($uid,0); - $commissionCount = $extractPriceCount < $commissionCount ? bcsub($commissionCount, $extractPriceCount,2) : 0;//减去审核中的提现金额 - $commissionCount = $commissionCount > $orderYuePrice ? bcsub($commissionCount, $orderYuePrice,2) : 0;//减掉余额支付 - } - $data['lastDayCount'] = $lastDayCount; - $data['extractCount'] = $extractCount; - $data['commissionCount'] = $commissionCount; - return app('json')->successful($data); - } + public function commission(Request $request) + { + $uid = $request->uid(); + $lastDayCount = UserBill::yesterdayCommissionSum($uid);//昨天的佣金 + $extractCount = UserExtract::extractSum($uid);//累计提现金额 + $commissionCount = UserBill::getBrokerage($uid);//获取总佣金 + if ($commissionCount > 0) { + $rechargeCount = UserBill::getRecharge($uid);//累计充值 + $orderYuePrice = StoreOrder::getOrderStatusYueSum($uid);//余额累计消费 + $systemAdd = UserBill::getSystemAdd($uid);//后台添加余额 + $yueCount = bcadd($rechargeCount, $systemAdd, 2);// 后台添加余额 + 累计充值 = 非佣金的总金额 + $orderYuePrice = $yueCount > $orderYuePrice ? 0 : bcsub($orderYuePrice, $yueCount, 2);// 余额累计消费(使用佣金消费的金额) + $commissionCount = bcsub($commissionCount, $extractCount, 2);//减去已提现金额 + $extractPriceCount = UserExtract::userExtractTotalPrice($uid, 0); + $commissionCount = $extractPriceCount < $commissionCount ? bcsub($commissionCount, $extractPriceCount, 2) : 0;//减去审核中的提现金额 + $commissionCount = $commissionCount > $orderYuePrice ? bcsub($commissionCount, $orderYuePrice, 2) : 0;//减掉余额支付 + } + $data['lastDayCount'] = $lastDayCount; + $data['extractCount'] = $extractCount; + $data['commissionCount'] = $commissionCount; + return app('json')->successful($data); + } /** @@ -65,12 +66,12 @@ class UserBillController public function spread_people(Request $request) { $spreadInfo = UtilService::postMore([ - ['page',1], - ['limit',20], - ['grade',0], - ['keyword',''], - ['sort',''], - ],$request); + ['page', 1], + ['limit', 20], + ['grade', 0], + ['keyword', ''], + ['sort', ''], + ], $request); $uid = $request->uid(); $data['list'] = User::getUserSpreadGrade($uid, $spreadInfo['grade'], $spreadInfo['sort'], $spreadInfo['keyword'], $spreadInfo['page'], $spreadInfo['limit']); $data['total'] = User::getSpreadCount($uid); @@ -86,19 +87,19 @@ class UserBillController public function spread_order(Request $request) { $orderInfo = UtilService::postMore([ - ['page',1], - ['limit',20], - ['category','now_money'], - ['type','brokerage'], - ],$request); + ['page', 1], + ['limit', 20], + ['category', 'now_money'], + ['type', 'brokerage'], + ], $request); $data['list'] = []; $data['count'] = 0; $uid = $request->uid(); $data['list'] = UserBill::getRecordList($uid, $orderInfo['page'], $orderInfo['limit'], $orderInfo['category'], $orderInfo['type']); $count = UserBill::getRecordOrderCount($uid, $orderInfo['category'], $orderInfo['type']); $data['count'] = $count ? $count : 0; - if(!count($data['list'])) return app('json')->successful($data); - foreach ($data['list'] as $key=>&$value){ + if (!count($data['list'])) return app('json')->successful($data); + foreach ($data['list'] as $key => &$value) { $value['child'] = UserBill::getRecordOrderListDraw($uid, $value['time'], $orderInfo['category'], $orderInfo['type']); $value['count'] = count($value['child']); } @@ -108,31 +109,31 @@ class UserBillController /** * 推广佣金明细 * @param Request $request - * @param $type 0 全部 1 消费 2 充值 3 返佣 4 提现 + * @param $type 0 全部 1 消费 2 充值 3 返佣 4 提现 * @return mixed */ public function spread_commission(Request $request, $type) { list($page, $limit) = UtilService::getMore([ - ['page',0], - ['limit',0], - ],$request, true); - return app('json')->successful(UserBill::getUserBillList($request->uid(),$page,$limit,$type)); + ['page', 0], + ['limit', 0], + ], $request, true); + return app('json')->successful(UserBill::getUserBillList($request->uid(), $page, $limit, $type)); } /** * 推广 佣金/提现 总和 * @param Request $request - * @param $type 3 佣金 4 提现 + * @param $type 3 佣金 4 提现 * @return mixed */ public function spread_count(Request $request, $type) { $count = 0; - if($type == 3) $count = UserBill::getRecordCount($request->uid(), 'now_money', 'brokerage'); - else if($type == 4) $count = UserExtract::userExtractTotalPrice($request->uid());//累计提现 + if ($type == 3) $count = UserBill::getRecordCount($request->uid(), 'now_money', 'brokerage'); + else if ($type == 4) $count = UserExtract::userExtractTotalPrice($request->uid());//累计提现 $count = $count ? $count : 0; - return app('json')->successful(['count'=>$count]); + return app('json')->successful(['count' => $count]); } @@ -144,168 +145,168 @@ class UserBillController public function spread_banner(Request $request) { list($type) = UtilService::getMore([ - ['type',2], - ],$request, true); + ['type', 2], + ], $request, true); $user = $request->user(); $rootPath = app()->getRootPath(); - try{ + try { $resRoutine = true;//小程序 $resWap = true;//公众号 $siteUrl = sysConfig('site_url'); $routineSpreadBanner = GroupDataService::getData('routine_spread_banner'); - if(!count($routineSpreadBanner)) return app('json')->fail('暂无海报'); - if($type == 1){ + if (!count($routineSpreadBanner)) return app('json')->fail('暂无海报'); + if ($type == 1) { //小程序 - $name = $user['uid'].'_'.$user['is_promoter'].'_user_routine.jpg'; - $imageInfo = SystemAttachment::getInfo($name,'name'); + $name = $user['uid'] . '_' . $user['is_promoter'] . '_user_routine.jpg'; + $imageInfo = SystemAttachment::getInfo($name, 'name'); //检测远程文件是否存在 - if(isset($imageInfo['att_dir']) && strstr($imageInfo['att_dir'],'http')!==false && UtilService::CurlFileExist($imageInfo['att_dir']) === false){ + if (isset($imageInfo['att_dir']) && strstr($imageInfo['att_dir'], 'http') !== false && UtilService::CurlFileExist($imageInfo['att_dir']) === false) { $imageInfo = null; - SystemAttachment::where(['name'=>$name])->delete(); + SystemAttachment::where(['name' => $name])->delete(); } - if(!$imageInfo){ + if (!$imageInfo) { $res = RoutineCode::getShareCode($user['uid'], 'spread', '', ''); - if(!$res) return app('json')->fail('二维码生成失败'); - $imageInfo = UploadService::instance()->setUploadPath('routine/spread/code')->imageStream($name,$res['res']); - if(!is_array($imageInfo)) return app('json')->fail($imageInfo); - SystemAttachment::attachmentAdd($imageInfo['name'],$imageInfo['size'],$imageInfo['type'],$imageInfo['dir'],$imageInfo['thumb_path'],1,$imageInfo['image_type'],$imageInfo['time'],2); - RoutineQrcode::setRoutineQrcodeFind($res['id'],['status'=>1,'time'=>time(),'qrcode_url'=>$imageInfo['dir']]); + if (!$res) return app('json')->fail('二维码生成失败'); + $imageInfo = UploadService::instance()->setUploadPath('routine/spread/code')->imageStream($name, $res['res']); + if (!is_array($imageInfo)) return app('json')->fail($imageInfo); + SystemAttachment::attachmentAdd($imageInfo['name'], $imageInfo['size'], $imageInfo['type'], $imageInfo['dir'], $imageInfo['thumb_path'], 1, $imageInfo['image_type'], $imageInfo['time'], 2); + RoutineQrcode::setRoutineQrcodeFind($res['id'], ['status' => 1, 'time' => time(), 'qrcode_url' => $imageInfo['dir']]); $urlCode = $imageInfo['dir']; - }else $urlCode = $imageInfo['att_dir']; - if($imageInfo['image_type'] == 1) $urlCode = $siteUrl.$urlCode; + } else $urlCode = $imageInfo['att_dir']; + if ($imageInfo['image_type'] == 1) $urlCode = $siteUrl . $urlCode; $siteUrlHttps = UtilService::setHttpType($siteUrl, 0); - $filelink=[ - 'Bold'=>'static'. DS .'font'. DS .'Alibaba-PuHuiTi-Regular.otf', - 'Normal'=>'static'. DS .'font'. DS .'Alibaba-PuHuiTi-Regular.otf', + $filelink = [ + 'Bold' => 'static' . DS . 'font' . DS . 'Alibaba-PuHuiTi-Regular.otf', + 'Normal' => 'static' . DS . 'font' . DS . 'Alibaba-PuHuiTi-Regular.otf', ]; - if(!file_exists($filelink['Bold'])) return app('json')->fail('缺少字体文件Bold'); - if(!file_exists($filelink['Normal'])) return app('json')->fail('缺少字体文件Normal'); - foreach ($routineSpreadBanner as $key=>&$item){ + if (!file_exists($filelink['Bold'])) return app('json')->fail('缺少字体文件Bold'); + if (!file_exists($filelink['Normal'])) return app('json')->fail('缺少字体文件Normal'); + foreach ($routineSpreadBanner as $key => &$item) { $posterInfo = '海报生成失败:('; $config = array( - 'image'=>array( + 'image' => array( array( - 'url'=>$urlCode, //二维码资源 - 'stream'=>0, - 'left'=>114, - 'top'=>790, - 'right'=>0, - 'bottom'=>0, - 'width'=>120, - 'height'=>120, - 'opacity'=>100 + 'url' => $urlCode, //二维码资源 + 'stream' => 0, + 'left' => 114, + 'top' => 790, + 'right' => 0, + 'bottom' => 0, + 'width' => 120, + 'height' => 120, + 'opacity' => 100 ) ), - 'text'=>array( + 'text' => array( array( - 'text'=>$user['nickname'], - 'left'=>250, - 'top'=>840, - 'fontPath'=>$rootPath.'public'. DS .$filelink['Bold'], //字体文件 - 'fontSize'=>16, //字号 - 'fontColor'=>'40,40,40', //字体颜色 - 'angle'=>0, + 'text' => $user['nickname'], + 'left' => 250, + 'top' => 840, + 'fontPath' => $rootPath . 'public' . DS . $filelink['Bold'], //字体文件 + 'fontSize' => 16, //字号 + 'fontColor' => '40,40,40', //字体颜色 + 'angle' => 0, ), array( - 'text'=>'邀请您加入'.sysConfig('site_name'), - 'left'=>250, - 'top'=>880, - 'fontPath'=>$rootPath.'public'. DS .$filelink['Normal'], //字体文件 - 'fontSize'=>16, //字号 - 'fontColor'=>'40,40,40', //字体颜色 - 'angle'=>0, + 'text' => '邀请您加入' . sysConfig('site_name'), + 'left' => 250, + 'top' => 880, + 'fontPath' => $rootPath . 'public' . DS . $filelink['Normal'], //字体文件 + 'fontSize' => 16, //字号 + 'fontColor' => '40,40,40', //字体颜色 + 'angle' => 0, ) ), - 'background'=>$item['pic'] + 'background' => $item['pic'] ); - $resRoutine = $resRoutine && $posterInfo = UtilService::setSharePoster($config,'routine/spread/poster'); - if(!is_array($posterInfo)) return app('json')->fail($posterInfo); - SystemAttachment::attachmentAdd($posterInfo['name'],$posterInfo['size'],$posterInfo['type'],$posterInfo['dir'],$posterInfo['thumb_path'],1,$posterInfo['image_type'],$posterInfo['time'],2); - if($resRoutine){ - if($posterInfo['image_type'] == 1) - $item['poster'] = $siteUrlHttps.$posterInfo['dir']; + $resRoutine = $resRoutine && $posterInfo = UtilService::setSharePoster($config, 'routine/spread/poster'); + if (!is_array($posterInfo)) return app('json')->fail($posterInfo); + SystemAttachment::attachmentAdd($posterInfo['name'], $posterInfo['size'], $posterInfo['type'], $posterInfo['dir'], $posterInfo['thumb_path'], 1, $posterInfo['image_type'], $posterInfo['time'], 2); + if ($resRoutine) { + if ($posterInfo['image_type'] == 1) + $item['poster'] = $siteUrlHttps . $posterInfo['dir']; else $item['poster'] = UtilService::setHttpType($posterInfo['dir'], 0); - $item['poster'] = str_replace('\\','/',$item['poster']); + $item['poster'] = str_replace('\\', '/', $item['poster']); } } - }else if($type == 2){ + } else if ($type == 2) { //公众号 - $name = $user['uid'].'_'.$user['is_promoter'].'_user_wap.jpg'; - $imageInfo = SystemAttachment::getInfo($name,'name'); + $name = $user['uid'] . '_' . $user['is_promoter'] . '_user_wap.jpg'; + $imageInfo = SystemAttachment::getInfo($name, 'name'); //检测远程文件是否存在 - if(isset($imageInfo['att_dir']) && strstr($imageInfo['att_dir'],'http')!==false && UtilService::CurlFileExist($imageInfo['att_dir']) === false){ + if (isset($imageInfo['att_dir']) && strstr($imageInfo['att_dir'], 'http') !== false && UtilService::CurlFileExist($imageInfo['att_dir']) === false) { $imageInfo = null; - SystemAttachment::where(['name'=>$name])->delete(); + SystemAttachment::where(['name' => $name])->delete(); } - if(!$imageInfo){ - $codeUrl = UtilService::setHttpType($siteUrl.'?spread='.$user['uid'], 1);//二维码链接 + if (!$imageInfo) { + $codeUrl = UtilService::setHttpType($siteUrl . '?spread=' . $user['uid'], 1);//二维码链接 $imageInfo = UtilService::getQRCodePath($codeUrl, $name); - if(!$imageInfo) return app('json')->fail('二维码生成失败'); - SystemAttachment::attachmentAdd($imageInfo['name'],$imageInfo['size'],$imageInfo['type'],$imageInfo['dir'],$imageInfo['thumb_path'],1,$imageInfo['image_type'],$imageInfo['time'],2); + if (!$imageInfo) return app('json')->fail('二维码生成失败'); + SystemAttachment::attachmentAdd($imageInfo['name'], $imageInfo['size'], $imageInfo['type'], $imageInfo['dir'], $imageInfo['thumb_path'], 1, $imageInfo['image_type'], $imageInfo['time'], 2); $urlCode = $imageInfo['dir']; - }else $urlCode = $imageInfo['att_dir']; - if($imageInfo['image_type'] == 1) $urlCode = $siteUrl.$urlCode; + } else $urlCode = $imageInfo['att_dir']; + if ($imageInfo['image_type'] == 1) $urlCode = $siteUrl . $urlCode; $siteUrl = UtilService::setHttpType($siteUrl, 1); - $filelink=[ - 'Bold'=>'static'. DS .'font'. DS .'Alibaba-PuHuiTi-Regular.otf', - 'Normal'=>'static'. DS .'font'. DS .'Alibaba-PuHuiTi-Regular.otf', + $filelink = [ + 'Bold' => 'static' . DS . 'font' . DS . 'Alibaba-PuHuiTi-Regular.otf', + 'Normal' => 'static' . DS . 'font' . DS . 'Alibaba-PuHuiTi-Regular.otf', ]; - if(!file_exists($filelink['Bold'])) return app('json')->fail('缺少字体文件Bold'); - if(!file_exists($filelink['Normal'])) return app('json')->fail('缺少字体文件Normal'); - foreach ($routineSpreadBanner as $key=>&$item){ + if (!file_exists($filelink['Bold'])) return app('json')->fail('缺少字体文件Bold'); + if (!file_exists($filelink['Normal'])) return app('json')->fail('缺少字体文件Normal'); + foreach ($routineSpreadBanner as $key => &$item) { $posterInfo = '海报生成失败:('; $config = array( - 'image'=>array( + 'image' => array( array( - 'url'=>$urlCode, //二维码资源 - 'stream'=>0, - 'left'=>114, - 'top'=>790, - 'right'=>0, - 'bottom'=>0, - 'width'=>120, - 'height'=>120, - 'opacity'=>100 + 'url' => $urlCode, //二维码资源 + 'stream' => 0, + 'left' => 114, + 'top' => 790, + 'right' => 0, + 'bottom' => 0, + 'width' => 120, + 'height' => 120, + 'opacity' => 100 ) ), - 'text'=>array( + 'text' => array( array( - 'text'=>$user['nickname'], - 'left'=>250, - 'top'=>840, - 'fontPath'=>$rootPath.'public'. DS .$filelink['Bold'], //字体文件 - 'fontSize'=>16, //字号 - 'fontColor'=>'40,40,40', //字体颜色 - 'angle'=>0, + 'text' => $user['nickname'], + 'left' => 250, + 'top' => 840, + 'fontPath' => $rootPath . 'public' . DS . $filelink['Bold'], //字体文件 + 'fontSize' => 16, //字号 + 'fontColor' => '40,40,40', //字体颜色 + 'angle' => 0, ), array( - 'text'=>'邀请您加入'.sysConfig('site_name'), - 'left'=>250, - 'top'=>880, - 'fontPath'=>$rootPath.'public'. DS .$filelink['Normal'], //字体文件 - 'fontSize'=>16, //字号 - 'fontColor'=>'40,40,40', //字体颜色 - 'angle'=>0, + 'text' => '邀请您加入' . sysConfig('site_name'), + 'left' => 250, + 'top' => 880, + 'fontPath' => $rootPath . 'public' . DS . $filelink['Normal'], //字体文件 + 'fontSize' => 16, //字号 + 'fontColor' => '40,40,40', //字体颜色 + 'angle' => 0, ) ), - 'background'=>$item['pic'] + 'background' => $item['pic'] ); - $resWap = $resWap && $posterInfo = UtilService::setSharePoster($config,'wap/spread/poster'); - if(!is_array($posterInfo)) return app('json')->fail($posterInfo); - SystemAttachment::attachmentAdd($posterInfo['name'],$posterInfo['size'],$posterInfo['type'],$posterInfo['dir'],$posterInfo['thumb_path'],1,$posterInfo['image_type'],$posterInfo['time'],2); - if($resWap){ - if($posterInfo['image_type'] == 1) - $item['wap_poster'] = $siteUrl.$posterInfo['dir']; + $resWap = $resWap && $posterInfo = UtilService::setSharePoster($config, 'wap/spread/poster'); + if (!is_array($posterInfo)) return app('json')->fail($posterInfo); + SystemAttachment::attachmentAdd($posterInfo['name'], $posterInfo['size'], $posterInfo['type'], $posterInfo['dir'], $posterInfo['thumb_path'], 1, $posterInfo['image_type'], $posterInfo['time'], 2); + if ($resWap) { + if ($posterInfo['image_type'] == 1) + $item['wap_poster'] = $siteUrl . $posterInfo['dir']; else $item['wap_poster'] = UtilService::setHttpType($posterInfo['dir'], 1); } } } - if($resRoutine && $resWap) return app('json')->successful($routineSpreadBanner); + if ($resRoutine && $resWap) return app('json')->successful($routineSpreadBanner); else return app('json')->fail('生成图片失败'); - }catch (\Exception $e){ - return app('json')->fail('生成图片时,系统错误',['line'=>$e->getLine(),'message'=>$e->getMessage()]); + } catch (\Exception $e) { + return app('json')->fail('生成图片时,系统错误', ['line' => $e->getLine(), 'message' => $e->getMessage()]); } } @@ -321,9 +322,9 @@ class UserBillController public function integral_list(Request $request) { list($page, $limit) = UtilService::getMore([ - ['page',0],['limit',0] + ['page', 0], ['limit', 0] ], $request, true); - return app('json')->successful(UserBill::userBillList($request->uid(),$page,$limit)); + return app('json')->successful(UserBill::userBillList($request->uid(), $page, $limit)); } } \ No newline at end of file diff --git a/crmeb/app/api/controller/wechat/WechatController.php b/crmeb/app/api/controller/wechat/WechatController.php index 566f3410..862dc954 100644 --- a/crmeb/app/api/controller/wechat/WechatController.php +++ b/crmeb/app/api/controller/wechat/WechatController.php @@ -8,6 +8,7 @@ use app\models\user\User; use app\models\user\UserToken; use app\models\user\WechatUser; use app\Request; +use crmeb\services\CanvasService; use crmeb\services\WechatService; use think\facade\Cookie; @@ -56,7 +57,7 @@ class WechatController public function auth(Request $request) { $spreadId = intval($request->param('spread')); - $login_type = $request->param('login_type',''); + $login_type = $request->param('login_type', ''); try { $wechatInfo = WechatService::oauthService()->user()->getOriginal(); } catch (\Exception $e) { @@ -79,7 +80,7 @@ class WechatController $user = User::where('uid', WechatUser::openidToUid($openid, 'openid'))->find(); if (!$user) return app('json')->fail('获取用户信息失败'); - if($user->login_type == 'h5' && ($h5UserInfo = User::where(['account'=>$user->phone,'phone'=>$user->phone,'user_type'=>'h5'])->find())) + if ($user->login_type == 'h5' && ($h5UserInfo = User::where(['account' => $user->phone, 'phone' => $user->phone, 'user_type' => 'h5'])->find())) $token = UserToken::createToken($h5UserInfo, 'wechat'); else $token = UserToken::createToken($user, 'wechat'); @@ -91,4 +92,25 @@ class WechatController } else return app('json')->fail('登录失败'); } + + public function follow() + { + $canvas = CanvasService::instance(); + $path = 'uploads/follow/'; + $imageType = 'jpg'; + $name = 'follow'; + $siteUrl = sysConfig('site_url'); + if (file_exists($path . $name . '.' . $imageType)) { + return app('json')->success('ok', ['path' => $siteUrl . '/' . $path . $name . '.' . $imageType]); + } + $canvas->setImageUrl('static/qrcode/follow.png')->setImageHeight(720)->setImageWidth(500)->pushImageValue(); + $wechatQrcode = sysConfig('wechat_qrcode'); + if (($strlen = stripos($wechatQrcode, 'uploads')) !== false) { + $wechatQrcode = substr($wechatQrcode, $strlen); + } + $canvas->setImageUrl($wechatQrcode)->setImageHeight(344)->setImageWidth(344)->setImageLeft(76)->setImageTop(76)->pushImageValue(); + $image = $canvas->setFileName($name)->setImageType($imageType)->setPath($path)->setBackgroundWidth(500)->setBackgroundHeight(720)->starDrawChart(); + return app('json')->success('ok', ['path' => $image ? $siteUrl . '/' . $image : '']); + } + } \ No newline at end of file diff --git a/crmeb/crmeb/services/CanvasService.php b/crmeb/crmeb/services/CanvasService.php new file mode 100644 index 00000000..65718448 --- /dev/null +++ b/crmeb/crmeb/services/CanvasService.php @@ -0,0 +1,301 @@ + 0, + 'fontColor' => '231,180,52', + 'fontLeft' => 0, + 'fontTop' => 0, + 'fontText' => '', + 'fontPath' => self::FONT, + 'fontAngle' => 0, + ]; + + protected $defaultFont; + /** + * 图片数据集 + * @var array + */ + protected $imageValue = []; + + /** + * 图片可设置属性 + * @var array + */ + protected $defaultImageValue = [ + 'imageUrl' => '', + 'imageLeft' => 0, + 'imageTop' => 0, + 'imageRight' => 0, + 'imageBottom' => 0, + 'imageWidth' => 0, + 'imageHeight' => 0, + 'imageOpacity' => 0, + 'imageStream' => false, + ]; + + protected $defaultImage; + + protected function __construct() + { + $this->defaultImage = $this->defaultImageValue; + $this->defaultFont = $this->defaultFontValue; + } + + /** + * 创建一个新图象 + * @param string $file + * @return array + */ + public function createFrom(string $file): array + { + $imagesize = getimagesize($file); + $type = image_type_to_extension($imagesize[2], true); + switch ($type) { + case '.png': + $canvas = imagecreatefrompng($file); + break; + case '.jpeg': + $canvas = imagecreatefromjpeg($file); + break; + case '.jpg': + $canvas = imagecreatefromjpeg($file); + break; + case '.gif': + $canvas = imagecreatefromgif($file); + break; + } + return [$canvas, $imagesize]; + + } + + /** + * 放入字体 + * @return $this + */ + public function pushFontValue() + { + array_push($this->fontValue, $this->defaultFontValue); + $this->defaultFontValue = $this->defaultFont; + return $this; + } + + /** + * 放入图片 + * @return $this + */ + public function pushImageValue() + { + array_push($this->imageValue, $this->defaultImageValue); + $this->defaultImageValue = $this->defaultImage; + return $this; + } + + /** + * 创建背景 + * @param int $w + * @param int $h + * @return false|resource + */ + public function createTrueColor(int $w = 0, int $h = 0) + { + return imagecreatetruecolor($w ? $w : $this->backgroundWidth, $h ? $h : $this->backgroundHeight); + } + + + /** + * 开始画图 + * @param bool $force 生成错误时是否抛出异常 + * @return string + * @throws \Exception + */ + public function starDrawChart(bool $force = false): string + { + try { + $image = $this->createTrueColor(); + + foreach ($this->imageValue as $item) { + if ($item['imageUrl']) { + if ($item['imageStream']) { + $res = getimagesizefromstring($item['imageUrl']); + $mer = imagecreatefromstring($item['imageUrl']); + } else { + [$mer, $res] = $this->createFrom($item['imageUrl']); + } + if ($mer && $res) { + $scrW = $res[0] ?? 0; + $scrH = $res[1] ?? 0; + $imageWidth = $item['imageWidth'] ?: $scrW; + $imageHeight = $item['imageHeight'] ?: $scrH; + imagecopyresampled($image, $mer, $item['imageLeft'], $item['imageTop'], $item['imageRight'], $item['imageBottom'], $imageWidth, $imageHeight, $scrW, $scrH); + unset($scrW, $scrH, $imageWidth, $imageHeight, $res, $mer); + } + + } + } + + foreach ($this->fontValue as $val) { + if (!is_array($val['fontColor'])) + $fontColor = explode(',', $val['fontColor']); + else + $fontColor = $val['fontColor']; + if (count($fontColor) < 3) + throw new RuntimeException('fontColor 必须为三原色'); + [$r, $g, $b] = $fontColor; + $fontColor = imagecolorallocate($image, $r, $g, $b); + $val['fontLeft'] = $val['fontLeft'] < 0 ? $this->backgroundWidth - abs($val['fontLeft']) : $val['fontLeft']; + $val['fontTop'] = $val['fontTop'] < 0 ? $this->backgroundHeight - abs($val['fontTop']) : $val['fontTop']; + imagettftext($image, $val['fontSize'], $val['fontAngle'], $val['fontLeft'], $val['fontTop'], $fontColor, $val['fontPath'], $val['fontText']); + unset($r, $g, $b, $fontColor); + } + if (is_null($this->fileName)) { + $this->fileName = md5(time()); + } + + $strlen = stripos($this->path, 'uploads'); + $path = $this->path; + if ($strlen !== false) { + $path = substr($this->path, 8); + } + make_path($path, 4, true); + + $save_file = $this->path . $this->fileName . '.' . $this->imageType; + switch ($this->imageType) { + case 'jpeg': + case 'jpg': + imagejpeg($image, $save_file, 70); + break; + case 'png': + imagepng($image, $save_file, 70); + break; + case 'gif': + imagegif($image, $save_file, 70); + break; + default: + throw new \RuntimeException('Incorrect type set:' . $this->imageType); + } + imagedestroy($image); + + return $save_file; + } catch (\Throwable $e) { + if ($force || $e instanceof \RuntimeException) + throw new \Exception($e->getMessage()); + return ''; + } + } + + /** + * Magic access.. + * + * @param $method + * @param $args + * @return $this + */ + public function __call($method, $args): self + { + + if (0 === stripos($method, 'set') && strlen($method) > 3) { + $method = lcfirst(substr($method, 3)); + } + + $imageValueKes = array_keys($this->defaultImageValue); + $fontValueKes = array_keys($this->defaultFontValue); + + if (in_array($method, $imageValueKes)) { + $this->defaultImageValue[$method] = array_shift($args); + } + + if (in_array($method, $fontValueKes)) { + $this->defaultFontValue[$method] = array_shift($args); + } + + if (in_array($method, $this->propsRule)) { + $this->{$method} = array_shift($args); + } + + return $this; + } + + +} diff --git a/crmeb/crmeb/services/UploadService.php b/crmeb/crmeb/services/UploadService.php index af6cb70d..326ef068 100644 --- a/crmeb/crmeb/services/UploadService.php +++ b/crmeb/crmeb/services/UploadService.php @@ -154,7 +154,10 @@ class UploadService try { $uploadType = $this->uploadType ?: sysConfig('upload_type'); //TODO 没有选择默认使用本地上传 - if (!$uploadType) $uploadType = 1; + if (!$uploadType) + $uploadType = 1; + if (!is_int($uploadType)) + $uploadType = (int)$uploadType; switch ($uploadType) { case 1 : $info = $this->uploadLocaFile($fileName); @@ -186,8 +189,6 @@ class UploadService if (is_string($info)) return $info; break; } - $this->uploadPath = ''; - $this->autoValidate = true; } catch (\Exception $e) { return $e->getMessage(); } @@ -244,6 +245,8 @@ class UploadService $filePath = Filesystem::path($fileName); $fileInfo = new File($filePath); $url = '/uploads/' . $fileName; + $this->uploadPath = ''; + $this->autoValidate = false; return $this->setUploadInfo($url, 1, $fileInfo->getFilename(), self::thumb('.' . $url), [ 'Content-Length' => $fileInfo->getSize(), 'Content-Type' => $fileInfo->getMime() diff --git a/crmeb/route/api/route.php b/crmeb/route/api/route.php index 8e874d29..99beefdb 100644 --- a/crmeb/route/api/route.php +++ b/crmeb/route/api/route.php @@ -206,7 +206,8 @@ Route::group(function () { //短信购买异步通知 Route::post('sms/pay/notify', 'PublicController/sms_pay_notify')->name('smsPayNotify'); //短信购买异步通知 - + //获取关注微信公众号海报 + Route::get('wechat/follow','wechat.WechatController/follow')->name('Follow'); })->middleware(\app\http\middleware\AllowOriginMiddleware::class)->middleware(\app\http\middleware\AuthTokenMiddleware::class, false);