12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298 |
- <?php
- /**
- * 易优CMS
- * ============================================================================
- * 版权所有 2016-2028 海口快推科技有限公司,并保留所有权利。
- * 网站地址: http://www.eyoucms.com
- * ----------------------------------------------------------------------------
- * 如果商业用途务必到官方购买正版授权, 以免引起不必要的法律纠纷.
- * ============================================================================
- * Author: 小虎哥 <1105415366@qq.com>
- * Date: 2018-4-3
- */
-
- namespace app\api\model\v1;
-
- use think\Db;
- use think\Cache;
-
- /**
- * 微信小程序个人中心模型
- */
- load_trait('controller/Jump');
-
- class User extends UserBase
- {
- use \traits\controller\Jump;
- private $token;
-
- //初始化
- protected function initialize()
- {
- // 需要调用`Model`的`initialize`方法
- parent::initialize();
- }
-
- /**
- * 获取用户信息
- * @return null|static
- * @throws \think\exception\DbException
- */
- public function getUser()
- {
- if (empty($this->session)) return false;
- $where = [
- 'openid' => $this->session['openid'],
- 'users_id' => intval($this->session['users_id'])
- ];
- $users_id = Db::name('wx_users')->where($where)->getField('users_id');
- if (empty($users_id)) {
- return false;
- } else {
- $result = GetUsersLatestData($users_id);
- $result['head_pic'] = handle_subdir_pic($result['head_pic'], 'img', true);
- $address_default = []; // 默认收货地址
- $address = Db::name('shop_address')->where(['users_id' => $users_id])->order('is_default desc')->select(); // 收货地址列表
- if (!empty($address)) {
- foreach ($address as $key => $val) {
- if ($val['is_default'] == 1) {
- $address_default = $val;
- continue;
- }
- }
- }
- $result['address_1588820149'] = !empty($address) ? $address : [];
- $result['address_default_1588820149'] = $address_default;
- }
- return $result;
- }
-
- /**
- * 用户登录
- * @param array $post
- * @return string
- * @throws BaseException
- * @throws \think\Exception
- * @throws \think\exception\DbException
- */
- public function login($post)
- {
- if (self::$provider == 'baidu') {
- // 百度登录 获取session_key
- $session = $this->bdlogin($post['code']);
- // 自动注册用户
- $userInfo = [
- 'avatarUrl' => !empty($post['avatar_url']) ? $post['avatar_url'] : '',
- 'gender' => !empty($post['gender']) ? $post['gender'] : '',
- 'nickName' => !empty($post['nick_name']) ? $post['nick_name'] : '',
- ];
- // 自动注册用户
- $users_id = $this->register($session['openid'], $userInfo);
- $session['unionid'] = '';
- } elseif (self::$provider == 'toutiao') {
- $session = $this->ttlogin($post['code']);
- $userInfo = !empty($post['user_info']) ? json_decode($post['user_info'], true) : [];
- $users_id = $this->register($session['openid'], $userInfo);
- $session['unionid'] = '';
- } else {
- // 微信登录 获取session_key
- $session = $this->wxlogin($post['code']);
- $userInfo = !empty($post['user_info']) ? json_decode($post['user_info'], true) : [];
- $session['unionid'] = !empty($session['unionid']) ? $session['unionid'] : '';
- // 自动注册用户
- $users_id = $this->register($session['openid'], $userInfo, $session['unionid']);
- }
-
- if (!empty($users_id)) {
- // 更新会员信息
- $update = [
- 'last_ip' => clientIP(),
- 'last_login' => getTime(),
- 'login_count' => Db::raw('login_count+1'),
- 'update_time' => getTime(),
- ];
- // 查询用户信息
- $usersData = Db::name('users')->where(['users_id' => $users_id])->find();
- // 登录信息中有 unionid 且用户未记录 unionid 则执行
- if (!empty($session['unionid']) && empty($usersData['union_id'])) {
- $update['union_id'] = $session['unionid'];
- }
-
- // 如果有推荐注册的分销商ID信息则查询并绑定
- $parentUsersID = !empty($post['parent_users_id']) ? intval($post['parent_users_id']) : 0;
- $parentDealerID = !empty($post['parent_dealer_id']) ? intval($post['parent_dealer_id']) : 0;
- $parentDealer = [];
- if (!empty($parentUsersID) && !empty($parentDealerID)) {
- $where = [
- 'a.dealer_status' => 1,
- 'a.users_id' => $parentUsersID,
- 'a.dealer_id' => $parentDealerID,
- ];
- $field = 'a.*, b.is_dealer, b.parent_users_id, b.parent_dealer_id';
- $parentDealer = Db::name('weapp_dealer')->alias('a')->field($field)->where($where)->join('__USERS__ b', 'a.users_id = b.users_id', 'LEFT')->find();
- $dealerOpen = getUsersConfigData('dealer.dealer_open');
- if ((isset($dealerOpen) && 0 === intval($dealerOpen)) || $usersData['users_id'] == $parentDealer['users_id']) {
- $parentDealer = [];
- }
- }
- if (!empty($parentDealer) && empty($usersData['is_dealer'])) {
- // 如果当前登录用户没有上级分销商则绑定分销商
- if (empty($usersData['parent_users_id']) && empty($usersData['parent_dealer_id'])) {
- $update['parent_users_id'] = intval($parentDealer['users_id']);
- $update['parent_dealer_id'] = intval($parentDealer['dealer_id']);
- $update['bind_dealer_time'] = getTime();
- }
- // 如果当前用户绑定的上级分销商有上级分销商,有则绑定为顶级分销商
- if (!empty($parentDealer['parent_users_id']) && !empty($parentDealer['parent_dealer_id'])) {
- $update['top_users_id'] = intval($parentDealer['parent_users_id']);
- $update['top_dealer_id'] = intval($parentDealer['parent_dealer_id']);
- if (empty($update['bind_dealer_time'])) $update['bind_dealer_time'] = getTime();
- }
- }
- Db::name('users')->where(['users_id' => $users_id])->update($update);
- }
-
- // 生成token (session3rd)
- $this->token = $this->token($session['unionid'], $session['session_key'], $users_id, $session['openid']);
-
- return $users_id;
- }
-
- //头条登录
- private function ttlogin($code)
- {
- $inc = tpSetting("OpenMinicode.conf_toutiao");
- $inc = !empty($inc) ? json_decode($inc, true) : [];
- $inc = [
- 'appid' => !empty($inc['appid']) ? $inc['appid'] : '',
- 'secret' => !empty($inc['secret']) ? $inc['secret'] : '',
- ];
- if (empty($inc['appid']) || empty($inc['secret'])) $this->error('未填写抖音小程序配置');
-
- // 头条登录登录 (获取session_key)
- $session = $this->ttUserSessionKey($code, $inc);
- if (isset($session['errcode'])) $this->error($session['errmsg']);
-
- return $session;
- }
-
- /**
- * 获取抖音登录的session_key
- * @param $code
- * @return array|mixed
- */
- private function ttUserSessionKey($code, $inc)
- {
- $url = "https://developer.toutiao.com/api/apps/v2/jscode2session";
- $postData = [
- 'appid' => !empty($inc['appid']) ? $inc['appid'] : '',
- 'secret' => !empty($inc['secret']) ? $inc['secret'] : '',
- 'anonymous_code' => "",
- 'code' => $code,
- ];
- $headers = array("content-type: application/json");
- $response = httpRequest($url, 'POST', json_encode($postData), $headers);
- $params = json_decode($response, true);
- if (!empty($params['err_no']) && 'success' != $params['err_tips']) {
- $params = [
- 'errcode' => "-1",
- 'errmsg' => $params['err_no'] . ':' . $params['err_tips'],
- ];
- return $params;
- } else {
- return $params['data'];
- }
- }
-
- /**
- * 百度登录
- * @param $code
- * @return array|mixed
- * @throws BaseException
- * @throws \think\exception\DbException
- */
- private function bdlogin($code)
- {
- $inc = tpSetting("OpenMinicode.conf_baidu", [], self::$lang);
- $inc = json_decode($inc, true);
- if (empty($inc['appkey'])) {
- $this->error('该开源插件未填写百度小程序配置');
- }
- $inc = [
- 'appkey' => !empty($inc['appkey']) ? $inc['appkey'] : '',
- 'appsecret' => !empty($inc['appsecret']) ? $inc['appsecret'] : '',
- ];
- // 百度登录 (获取session_key)
- $session = $this->bdUserSessionKey($code, $inc);
- if (isset($session['errcode'])) {
- $this->error($session['errmsg']);
- }
- return $session;
- }
-
- /**
- * 获取百度登录的session_key
- * @param $code
- * @return array|mixed
- */
- private function bdUserSessionKey($code, $inc)
- {
- /**
- * code 换取 session_key
- * 这是一个 HTTPS 接口,开发者服务器使用登录凭证 code 获取 session_key 和 openid。
- * 其中 session_key 是对用户数据进行加密签名的密钥。为了自身应用安全,session_key 不应该在网络上传输。
- */
-
- $url = "https://spapi.baidu.com/oauth/jscode2sessionkey";
- $post_data = [
- 'code' => $code,
- 'client_id' => !empty($inc['appkey']) ? $inc['appkey'] : '',
- 'sk' => !empty($inc['appsecret']) ? $inc['appsecret'] : '',
- ];
- $response = httpRequest($url, 'POST', $post_data);
- $params = json_decode($response, true);
- if (!empty($params['errno'])) {
- $params = [
- 'errcode' => "-1",
- 'errmsg' => $params['error'],
- ];
- }
- return $params;
- }
-
- /**
- * 获取token
- * @return mixed
- */
- public function getToken()
- {
- return $this->token;
- }
-
- /**
- * 微信登录
- * @param $code
- * @return array|mixed
- * @throws BaseException
- * @throws \think\exception\DbException
- */
- private function wxlogin($code)
- {
- $inc = tpSetting("OpenMinicode.conf_weixin", [], self::$lang);
- $inc = json_decode($inc, true);
- if (empty($inc['appid'])) {
- $this->error('该开源插件未填写微信小程序配置');
- }
- // 微信登录 (获取session_key)
- $session = $this->wxUserSessionKey($code, $inc);
- if (isset($session['errcode'])) {
- $this->error($session['errmsg']);
- }
- return $session;
- }
-
- /**
- * 获取微信登录的session_key
- * @param $code
- * @return array|mixed
- */
- private function wxUserSessionKey($code, $inc)
- {
- /**
- * code 换取 session_key
- * 这是一个 HTTPS 接口,开发者服务器使用登录凭证 code 获取 session_key 和 openid。
- * 其中 session_key 是对用户数据进行加密签名的密钥。为了自身应用安全,session_key 不应该在网络上传输。
- */
- $url = "https://api.weixin.qq.com/sns/jscode2session?appid={$inc['appid']}&secret={$inc['appsecret']}&js_code={$code}&grant_type=authorization_code";
- $response = httpRequest($url);
- $params = json_decode($response, true);
- if (empty($params)) {
- $params = [
- 'errcode' => "-1",
- 'errmsg' => '系统繁忙',
- ];
- }
- return $params;
- }
-
- /**
- * 生成用户认证的token
- * @param $openid
- * @return string
- */
- private function token($unionid = '', $session_key = '', $users_id = '', $openid = 'openid')
- {
- // 随机串
- $randstr1 = get_rand_str(8, 0, 1);
- // 随机串
- $randstr2 = get_rand_str(8, 0, 0);
- // 自定义一个盐
- $salt = '_token_salt';
- $openid = !empty($openid) ? $openid : 'openid';//为手机号注册登录写的
- $session_key = !empty($session_key) ? $session_key : 'session_key';//为手机号注册登录写的
- // 用户认证的token
- $token = "{$randstr1}eyoucms{$users_id}eyoucms{$openid}eyoucms{$randstr2}eyoucms{$session_key}eyoucms{$salt}";
-
- return mchStrCode($token, 'ENCODE', '#!@diyminipro#!$');
- }
-
- /**
- * 自动注册用户
- * @param $openid
- * @param $userInfo
- * @return mixed
- * @throws \Exception
- * @throws \think\exception\DbException
- */
- private function register($openid = '', $userInfo = '', $unionid = '')
- {
- if (!empty($unionid)){
- $u_where['union_id'] = $w_where['unionid'] = $unionid;
- $users_id = Db::name('users')->where($u_where)->value('users_id');
- if (!empty($users_id)) return $users_id;
- }else{
- $w_where['openid'] = $openid;
- }
-
- // 查询用户是否已存在
- $we_user = Db::name('wx_users')->field('users_id')->where($w_where)->find();
- $userInfo['unionid'] = $unionid;
- $userInfo['openid'] = $openid;
- if (empty($we_user)) {
- $users_id = $this->setReg($userInfo);
- if (!empty($users_id)) {
- //微信用户信息存在表里
- $wxuser_id = Db::name('wx_users')->insertGetId([
- 'users_id' => $users_id,
- 'openid' => $openid,
- 'unionid' => $unionid,
- 'nickname' => !empty($userInfo['nickName']) ? filterNickname($userInfo['nickName']) : '',
- 'headimgurl' => !empty($userInfo['avatarUrl']) ? filterNickname($userInfo['avatarUrl']) : '',
- 'add_time' => getTime(),
- ]);
- if (!empty($wxuser_id)) {
- return $users_id;
- } else {
- Db::name('users')->where(['users_id' => $users_id])->delete();
- }
- }
- $this->error('用户注册失败!');
- } else {
- $users = Db::name('users')->field('users_id')->where([
- 'users_id' => $we_user['users_id'],
- ])->find();
- if (empty($users)) {
- $users_id = $this->setReg($userInfo);
- if (!empty($users_id)) {
- Db::name('wx_users')->where($w_where)->update([
- 'users_id' => $users_id,
- 'update_time' => getTime(),
- ]);
- return $users_id;
- } else {
- $this->error('用户注册失败!');
- }
- } else {
- return $we_user['users_id'];
- }
- }
- }
-
- /**
- * 自动注册users表用户
- */
- private function setReg($userInfo)
- {
- // 生成用户名
- $username = rand_username('', 'U', 3);
- // 用户昵称
- $nickname = !empty($userInfo['nickName']) ? filterNickname($userInfo['nickName']) : '';
- // 创建用户账号
- $addData = [
- 'username' => $username,//用户名-生成
- 'nickname' => !empty($nickname) ? trim($nickname) : $username,//昵称,同微信用户名
- 'level' => 1,
- 'thirdparty' => 3,
- 'union_id' => !empty($userInfo['unionid']) ? $userInfo['unionid'] : '',
- 'register_place' => 2,
- 'open_level_time' => getTime(),
- 'level_maturity_days' => 0,
- 'reg_time' => getTime(),
- 'head_pic' => !empty($userInfo['avatarUrl']) ? $userInfo['avatarUrl'] : ROOT_DIR . '/public/static/common/images/dfboy.png',
- 'mobile' => !empty($userInfo['mobile']) ? $userInfo['mobile'] : '',
- 'is_mobile' => !empty($userInfo['mobile']) ? 1 : 0,
- 'lang' => self::$lang,
- ];
- if (self::$provider == 'baidu') {
- $addData['source'] = 5;//1-PC端 2-H5 3-微信公众号/微站点 4-微信小程序 5-百度小程序 6-抖音小程序
- } elseif (self::$provider == 'toutiao') {
- $addData['source'] = 6;//1-PC端 2-H5 3-微信公众号/微站点 4-微信小程序 5-百度小程序 6-抖音小程序
- } else {
- $addData['source'] = 4;//1-PC端 2-H5 3-微信公众号/微站点 4-微信小程序 5-百度小程序 6-抖音小程序
- }
- if (0 == config('global.opencodetype') && !empty($userInfo['password'])) {
- $addData['password'] = func_encrypt($userInfo['password'], false, pwd_encry_type('bcrypt'));
- }
- $users_id = Db::name('users')->insertGetId($addData);
-
- return $users_id;
- }
-
- /**
- * 自动注册users表用户
- */
- private function setAccountReg($userInfo)
- {
- // 生成用户名
- $username = $userInfo["username"];
-
- // 创建用户账号
- $addData = [
- "username" => $username, // 用户名
- "nickname" => $username, //昵称,同用户名
- "level" => 1,
- "thirdparty" => 0,
- "union_id" => "",
- "register_place" => 2,
- "open_level_time" => getTime(),
- "level_maturity_days" => 0,
- "reg_time" => getTime(),
- "head_pic" => !empty($userInfo["avatarUrl"]) ? $userInfo["avatarUrl"] : ROOT_DIR . "/public/static/common/images/dfboy.png",
- "mobile" => !empty($userInfo["mobile"]) ? $userInfo["mobile"] : "",
- "is_mobile" => !empty($userInfo["mobile"]) ? 1 : 0,
- "lang" => self::$lang,
- ];
-
- if (0 == config("global.opencodetype")) {
- $addData["password"] = func_encrypt($userInfo["password"], false, pwd_encry_type("bcrypt"));
- }
-
- $users_id = Db::name("users")->insertGetId($addData);
-
- Db::name("wx_users")->insert([
- "users_id" => $users_id,
- "openid" => "openid",
- "nickname" => $username,
- "headimgurl" => !empty($userInfo["avatarUrl"]) ? $userInfo["avatarUrl"] : ROOT_DIR . "/public/static/common/images/dfboy.png",
- "add_time" => getTime(),
- ]);
-
- return $users_id;
- }
-
- /**
- * 个人中心菜单列表
- * @return array
- */
- public function getMenus()
- {
- $menus = [
- // 'address' => [
- // 'name' => '收货地址',
- // 'url' => 'pages/address/index',
- // 'icon' => 'map'
- // ],
- // 'coupon' => [
- // 'name' => '领券中心',
- // 'url' => 'pages/coupon/coupon',
- // 'icon' => 'lingquan'
- // ],
- // 'my_coupon' => [
- // 'name' => '我的优惠券',
- // 'url' => 'pages/user/coupon/coupon',
- // 'icon' => 'youhuiquan'
- // ],
- // 'sharing_order' => [
- // 'name' => '拼团订单',
- // 'url' => 'pages/sharing/order/index',
- // 'icon' => 'pintuan'
- // ],
- // 'my_bargain' => [
- // 'name' => '我的砍价',
- // 'url' => 'pages/bargain/index/index?tab=1',
- // 'icon' => 'kanjia'
- // ],
- // 'dealer' => [
- // 'name' => '分销中心',
- // 'url' => 'pages/dealer/index/index',
- // 'icon' => 'fenxiaozhongxin'
- // ],
- // 'help' => [
- // 'name' => '我的帮助',
- // 'url' => 'pages/user/help/index',
- // 'icon' => 'help'
- // ],
- ];
- // 判断分销功能是否开启
- // if (DealerSettingModel::isOpen()) {
- // $menus['dealer']['name'] = DealerSettingModel::getDealerTitle();
- // } else {
- // unset($menus['dealer']);
- // }
- return $menus;
- }
-
- /**
- * 返回状态给微信服务器
- * @param boolean $returnCode
- * @param string $msg
- */
- public function returnCode($returnCode = true, $msg = null)
- {
- // 返回状态
- $return = [
- 'return_code' => $returnCode ? 'SUCCESS' : 'FAIL',
- 'return_msg' => $msg ?: 'OK',
- ];
-
- // 记录日志
- // $value = [
- // 'describe' => '返回微信支付状态',
- // 'data' => $return
- // ];
- // $msg = is_string($value) ? $value : var_export($value, true);
- // \think\Log::record($msg, $type);
-
- die($this->toXml($return));
- }
-
- /**
- * 格式化参数格式化成url参数
- * @param $values
- * @return string
- */
- public function toUrlParams($values)
- {
- $buff = '';
- foreach ($values as $k => $v) {
- if ($k != 'sign' && $v != '' && !is_array($v)) {
- $buff .= $k . '=' . $v . '&';
- }
- }
- return trim($buff, '&');
- }
-
- /**
- * 输出xml字符
- * @param $values
- * @return bool|string
- */
- public function toXml($values)
- {
- if (!is_array($values)
- || count($values) <= 0
- ) {
- return false;
- }
-
- $xml = "<xml>";
- foreach ($values as $key => $val) {
- if (is_numeric($val)) {
- $xml .= "<" . $key . ">" . $val . "</" . $key . ">";
- } else {
- $xml .= "<" . $key . "><![CDATA[" . $val . "]]></" . $key . ">";
- }
- }
- $xml .= "</xml>";
- return $xml;
- }
-
- /**
- * 将xml转为array
- * @param $xml
- * @return mixed
- */
- public function fromXml($xml)
- {
- // 禁止引用外部xml实体
- libxml_disable_entity_loader(true);
- return json_decode(json_encode(simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA)), true);
- }
-
- /**
- * 生成签名
- * @param $values
- * @return string 本函数不覆盖sign成员变量,如要设置签名需要调用SetSign方法赋值
- */
- public function makeSign($values, $apikey = '')
- {
- if (empty($apikey)) {
- $minicode = Db::name('weapp')->where('code', self::$weapp_code)->value('data');
- $Setting = json_decode($minicode, true);
- $apikey = $Setting['apikey'];
- }
-
- //签名步骤一:按字典序排序参数
- ksort($values);
- $string = $this->toUrlParams($values);
- //签名步骤二:在string后加入KEY
- $string = $string . '&key=' . $apikey;
- //签名步骤三:MD5加密
- $string = md5($string);
- //签名步骤四:所有字符转为大写
- $result = strtoupper($string);
- return $result;
- }
-
- public function onPaySuccess($order, $payType = 20, $payData = [])
- {
- if (empty($order)) {
- return [
- 'code' => 0,
- 'msg' => '未找到该订单信息',
- ];
- }
- // 更新付款状态
- $status = $this->updatePayStatus($order, $payType, $payData);
-
- return $status;
- }
-
- /**
- * 更新付款状态
- * @param $payType
- * @param array $payData
- * @return bool
- */
- private function updatePayStatus($order, $payType, $payData = [])
- {
- // 验证余额支付时用户余额是否满足
- if ($payType == 10) {
- $users_money = Db::name('users')->where(['users_id' => $this->users_id])->getField('users_money');
- if (strval($users_money) < strval($order['order_amount'])) {
- return [
- 'code' => 0,
- 'msg' => '用户余额不足,无法使用余额支付',
- ];
- }
- }
- // 更新订单状态
- $Result = $this->updateOrderInfo($order, $payType, $payData);
-
- return $Result;
- }
-
- /**
- * 更新订单记录
- * @param $payType
- * @param $payData
- * @return false|int
- * @throws \Exception
- */
- private function updateOrderInfo($order, $payType, $payData)
- {
- $Result = [];
-
- $OrderWhere = [
- 'order_id' => $order['order_id'],
- 'order_code' => $payData['out_trade_no'],
- ];
- // 修改会员金额明细表中,对应的订单数据,存入返回的数据,订单已付款
- $OrderData = [
- 'order_status' => 1,
- // 'pay_name' => 'wechat', //微信支付
- 'pay_details' => serialize($payData),
- 'pay_time' => getTime(),
- 'update_time' => getTime(),
- ];
- $r = Db::name('shop_order')->where($OrderWhere)->update($OrderData);
-
- if (!empty($r)) {
-
- // 添加订单操作记录
- AddOrderAction($order['order_id'], $order['users_id'], '0', '1', '0', '1', '支付成功!', '会员使用微信小程序完成支付!');
-
- // $users = Db::name('users')->find($order['users_id']);
-
- // 邮箱发送
- // $SmtpConfig = tpCache('smtp');
- // $Result['email'] = GetEamilSendData($SmtpConfig, $users, $order, 1, 'wechat');
-
- // 手机发送
- // $SmsConfig = tpCache('sms');
- // $Result['mobile'] = GetMobileSendData($SmsConfig, $users, $order, 1, 'wechat');
-
- $Result['status'] = 1;
- }
-
- return $Result;
- }
-
- //获取收藏/喜欢(点赞)列表
- public function GetMyCollectList($param = [])
- {
- $orderby = !empty($orderby) ? $orderby : 'id desc';
- $page = !empty($param['page']) ? intval($param['page']) : 1;
- $pagesize = empty($param['pagesize']) ? config('paginate.list_rows') : $param['pagesize'];
- $type = empty($param['type']) ? 'users_collection' : $param['type'];
-
- $paginate = ['page' => $page];
- $pages = Db::name($type)
- ->alias('a')
- ->field('d.typename,c.*,a.*,c.add_time as arc_add_time')
- ->where('a.users_id', $this->users_id)
- ->where('a.channel', '>', 0)
- ->where('a.aid', '>', 0)
- ->join('archives c','a.aid = c.aid','left')
- ->join('arctype d', 'a.typeid = d.id','left')
- ->orderRaw($orderby)
- ->paginate($pagesize, false, $paginate);
-
- $result = $pages->toArray();
-
- $aids = get_arr_column($result['data'],'aid');
- if (!empty($result['data'])){
- $channel = get_arr_column($result['data'],'channel');
- $channelRow = Db::name('channeltype')->field('id,nid,table')
- ->where([
- 'id' => ['in',$channel],
- ])->getAllWithIndex('id');
- $count_arr = Db::name($type)->where('aid','in',$aids)->field('aid,count(id) as count')->group('aid')->getAllWithIndex('aid');
- foreach ($result['data'] as $key => $val) {
- $val['is_litpic'] = 0;
- if (!empty($val['litpic'])){
- $val['is_litpic'] = 1;
- }
- $val['litpic'] = $this->get_default_pic($val['litpic']); // 默认封面图
- $val['add_time'] = date('Y-m-d H:i:s',$val['add_time']);
- $val['arc_add_time_format'] = $this->time_format($val['arc_add_time']);
- $val['arc_add_time'] = date('Y-m-d H:i:s',$val['arc_add_time']);
- $val['update_time'] = date('Y-m-d H:i:s',$val['update_time']);
- $val['count'] = !empty($count_arr[$val['aid']]) ? $count_arr[$val['aid']]['count'] : 0;
- // 内容扩展表数据
- $tableExt = $channelRow[$val['channel']]['table'] . "_content";
- $content = Db::name($tableExt)->where(['aid' => $val['aid']])->value('content');
- $content = htmlspecialchars_decode($content);
- $val['img_list'] = $this->get_content_img($content);
- $result['data'][$key] = $val;
- }
- }
-
- return $result;
- }
-
- //获取内容里所有的图片
- private function get_content_img($content = '')
- {
- $arr = [];
- if (!empty($content)) {
- preg_match_all('/<img.*(\/)?>/iUs', $content, $imginfo);
- $imginfo = !empty($imginfo[0]) ? $imginfo[0] : [];
- if (!empty($imginfo)) {
- foreach ($imginfo as $key => $imgstr) {
- $imgstrNew = $imgstr;
- $url = preg_replace("/<img(.*?)src(\s*)=(\s*)[\'|\"](.*?)([^\/\'\"]*)[\'|\"](.*?)[\/]?(\s*)>/i", '${4}${5}', $imgstrNew);
- $url = handle_subdir_pic($url,'img',true);
- $info = @getimagesize($url);
- if ($info[0] >= 375 && $info[0] >= 250){
- $arr[] = get_default_pic($url,true);
- }
- if (count($arr) == 3){
- break;
- }
- }
- }
- }
- return $arr;
- }
-
- /**
- * 获取小程序全局唯一后台接口调用凭据(access_token)
- * @param $code
- * @return array|mixed
- */
- private function getAccessToken()
- {
- $inc = tpSetting("OpenMinicode.conf_weixin", [], self::$lang);
- $inc = json_decode($inc, true);
- if (empty($inc['appid'])) {
- $this->error('该开源插件未填写微信小程序配置');
- }
- $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={$inc['appid']}&secret={$inc['appsecret']}";
- $response = httpRequest($url);
- $params = json_decode($response, true);
- if (!empty($params['errcode'])) {
- $this->error($params['errmsg']);
- }
- return $params['access_token'];
- }
-
- //code换取用户手机号
- public function getPhone($code)
- {
- $access_token = $this->getAccessToken();
- $url = "https://api.weixin.qq.com/wxa/business/getuserphonenumber?access_token={$access_token}";
- $response = httpRequest($url,'POST',json_encode(['code'=>$code]));
- $params = json_decode($response, true);
- if (!empty($params['errcode'])) {
- $this->error($params['errmsg']);
- }
- $this->success('获取成功','',$params['phone_info']);
- }
-
- //获取我的足迹列表
- public function GetMyFootprintList($param = [])
- {
- $page = !empty($param['page']) ? intval($param['page']) : 1;
- $pagesize = empty($param['pagesize']) ? config('paginate.list_rows') : $param['pagesize'];
- $condition['a.users_id'] = $this->users_id;
- if (!empty($param['channel'])){
- $condition['a.channel'] = $param['channel'];
- }
-
- $paginate = ['page' => $page];
- $pages = Db::name('users_footprint')
- ->field('d.typename,c.*,a.*,c.add_time as arc_add_time')
- ->alias('a')
- ->join('arctype d', 'a.typeid = d.id','left')
- ->join('archives c', 'a.aid = c.aid','left')
- ->where($condition)
- ->order('a.update_time desc')
- ->paginate($pagesize, false, $paginate);
-
- $result = $pages->toArray();
-
- foreach ($result['data'] as $key => $val) {
- $val['is_litpic'] = 0;
- if (!empty($val['litpic'])){
- $val['is_litpic'] = 1;
- }
- $val['litpic'] = $this->get_default_pic($val['litpic']); // 默认封面图
- $val['add_time'] = date('Y-m-d H:i:s',$val['add_time']);
- $val['arc_add_time_format'] = $this->time_format($val['arc_add_time']);
- $val['arc_add_time'] = date('Y-m-d H:i:s',$val['arc_add_time']);
- $val['update_time'] = date('Y-m-d H:i:s',$val['update_time']);
- $result['data'][$key] = $val;
- }
- return $result;
- }
-
- public function guestbookList()
- {
- $param = input('param.');
- $page = !empty($param['page']) ? intval($param['page']) : 1;
- $pagesize = empty($param['pagesize']) ? config('paginate.list_rows') : 10;
- // $typeid = !empty($param['typeid']) ? $param['typeid'] : 0;
- if (!empty($param['typeid'])){
- $condition['typeid'] = $param['typeid'] ;
- }
-
- $condition['users_id'] = $this->users_id;
- $condition['lang'] = self::$lang;
-
- $paginate = ['page' => $page];
- $pages = Db::name('guestbook')
- ->where($condition)
- ->order('add_time desc')
- ->paginate($pagesize, false, $paginate);
- $result = $pages->toArray();
- $list = $result['data'];
-
- if (!empty($list)) {
- $aid_arr = get_arr_column($result['data'],'aid');
- $where = [
- 'b.aid' => ['IN', $aid_arr],
- 'a.lang' => self::$lang,
- 'a.is_del' => 0,
- ];
- $row = Db::name('guestbook_attribute')
- ->field('a.attr_name, b.attr_value, b.aid, b.attr_id,a.attr_input_type')
- ->alias('a')
- ->join('__GUESTBOOK_ATTR__ b', 'b.attr_id = a.attr_id', 'LEFT')
- ->where($where)
- ->order('b.aid desc, a.sort_order asc, a.attr_id asc')
- ->getAllWithIndex();
- $attr_list = array();
- foreach ($row as $key => $val) {
- if (9 == $val['attr_input_type']){
- //如果是区域类型,转换名称
- $val['attr_value'] = Db::name('region')->where('id','in',$val['attr_value'])->column('name');
- $val['attr_value'] = implode('',$val['attr_value']);
- }else if(10 == $val['attr_input_type']){
- $val['attr_value'] = date('Y-m-d H:i:s',$val['attr_value']);
- }
- if (preg_match('/(\.(jpg|gif|png|bmp|jpeg|ico|webp))$/i', $val['attr_value'])) {
- if (!stristr($val['attr_value'], '|')) {
- $val['attr_value'] = handle_subdir_pic($val['attr_value']);
- $val['attr_value'] = "<img src='{$val['attr_value']}' width='60' height='60' style='float: unset;cursor: pointer;' onclick=\"Images('{$val['attr_value']}', 650, 350);\" />";
- }
- } else {
- $val['attr_value'] = str_replace(PHP_EOL, ' | ', $val['attr_value']);
- }
- $attr_list[$val['aid']][] = $val;
- }
- foreach ($list as $key => $val) {
- $list[$key]['attr_list'] = isset($attr_list[$val['aid']]) ? $attr_list[$val['aid']] : array();
- }
- $result['data'] = $list;
- }
- return $result;
- }
-
- public function GetMyBookDetail($param)
- {
- $aid = !empty($param['aid']) ? intval($param['aid']) : 0;
- if (empty($aid)){
- $this->error('缺少aid');
- }
- $data = Db::name('guestbook')
- ->where(['aid'=>$aid,'users_id'=>$this->users_id])
- ->order('add_time desc')
- ->find();
- $where = [
- 'b.aid' => $aid,
- 'a.is_del' => 0,
- ];
- $data['add_time'] = date('Y-m-d H:i:s');
- $row = Db::name('guestbook_attribute')
- ->field('a.attr_name, b.attr_value, b.aid, b.attr_id,a.attr_input_type')
- ->alias('a')
- ->join('__GUESTBOOK_ATTR__ b', 'b.attr_id = a.attr_id', 'LEFT')
- ->where($where)
- ->order(' a.sort_order asc, a.attr_id asc')
- ->getAllWithIndex();
- foreach ($row as $key => $val) {
- if (9 == $val['attr_input_type']){
- //如果是区域类型,转换名称
- $val['attr_value'] = Db::name('region')->where('id','in',$val['attr_value'])->column('name');
- $val['attr_value'] = implode('',$val['attr_value']);
- }else if(10 == $val['attr_input_type']){
- $val['attr_value'] = date('Y-m-d H:i:s',$val['attr_value']);
- }
- if (preg_match('/(\.(jpg|gif|png|bmp|jpeg|ico|webp))$/i', $val['attr_value'])) {
- if (!stristr($val['attr_value'], '|')) {
- $val['attr_value'] = handle_subdir_pic($val['attr_value']);
- // $val['attr_value'] = "<img src='{$val['attr_value']}' width='60' height='60' style='float: unset;cursor: pointer;' onclick=\"Images('{$val['attr_value']}', 650, 350);\" />";
- }
- } else {
- $val['attr_value'] = str_replace(PHP_EOL, ' | ', $val['attr_value']);
- }
- $row[$key] = $val;
- }
- return ['data'=>$data,'list'=>$row];
- }
-
- /**
- * 手机号注册
- * @param array $post
- * @return string
- * @throws BaseException
- * @throws \think\Exception
- * @throws \think\exception\DbException
- */
- public function mobile_reg($post)
- {
- if (empty($post['mobile'])) $this->error('手机号不能为空!');
- if (!check_mobile($post['mobile'])) $this->error('手机号格式不正确!');
- //查询手机号是否已经注册过
- $is_reg = Db::name('users')->where(['mobile'=>$post['mobile'],'is_del'=>0])->find();
- if (!empty($is_reg)){
- $this->error('手机号码已经注册!');
- }
-
- if (!empty($post['have_password']) && 1 == $post['have_password']) {
- //手机号注册时需要填写密码但是不需要确认密码
- if (empty($post['password']) || !trim($post['password'])) $this->error('密码不能为空!');
- } elseif (!empty($post['have_password']) && 2 == $post['have_password']){
- //手机号注册时需要填写密码并确认密码
- if (empty($post['password']) || !trim($post['password'])) $this->error('密码不能为空!');
- if (empty($post['confirm_password']) || !trim($post['confirm_password'])) $this->error('确认密码不能为空!');
- if ($post['password'] != $post['confirm_password']) $this->error('两次输入密码不一致!');
- }
-
- if (empty($post['mobile_code'])) {
- $this->error('验证码不能为空!');
- }
- // 验证验证码
- $RecordWhere = [
- 'source' => 0,
- 'mobile' => $post['mobile'],
- 'code' => $post['mobile_code'],
- 'is_use' => 0,
- 'lang' => self::$lang
- ];
- $is_verify = Db::name('sms_log')->where($RecordWhere)->find();
- if (!empty($is_verify)){
- $RecordData = [
- 'is_use' => 1,
- 'update_time' => getTime()
- ];
- // 更新数据
- Db::name('sms_log')->where($RecordWhere)->update($RecordData);
- }else{
- $this->error('验证码错误!');
- }
- $users_id = $this->setReg($post);
- if (!empty($users_id)) {
- Db::name('users_list')->insert(['users_id'=>$users_id,'para_id'=>1,'info'=>$post['mobile'],'lang'=>self::$lang,'add_time'=>getTime(),'update_time'=>getTime()]);
-
- // 更新会员信息
- $update = [
- 'last_ip' => clientIP(),
- 'last_login' => getTime(),
- 'login_count' => Db::raw('login_count+1'),
- 'update_time' => getTime(),
- ];
- // 查询用户信息
- $usersData = Db::name('users')->where(['users_id' => $users_id])->find();
-
- // 如果有推荐注册的分销商ID信息则查询并绑定
- $parentUsersID = !empty($post['parent_users_id']) ? intval($post['parent_users_id']) : 0;
- $parentDealerID = !empty($post['parent_dealer_id']) ? intval($post['parent_dealer_id']) : 0;
- $parentDealer = [];
- if (!empty($parentUsersID) && !empty($parentDealerID)) {
- $where = [
- 'a.dealer_status' => 1,
- 'a.users_id' => $parentUsersID,
- 'a.dealer_id' => $parentDealerID,
- ];
- $field = 'a.*, b.is_dealer, b.parent_users_id, b.parent_dealer_id';
- $parentDealer = Db::name('weapp_dealer')->alias('a')->field($field)->where($where)->join('__USERS__ b', 'a.users_id = b.users_id', 'LEFT')->find();
- $dealerOpen = getUsersConfigData('dealer.dealer_open');
- if ((isset($dealerOpen) && 0 === intval($dealerOpen)) || $usersData['users_id'] == $parentDealer['users_id']) {
- $parentDealer = [];
- }
- }
- if (!empty($parentDealer) && empty($usersData['is_dealer'])) {
- // 如果当前登录用户没有上级分销商则绑定分销商
- if (empty($usersData['parent_users_id']) && empty($usersData['parent_dealer_id'])) {
- $update['parent_users_id'] = intval($parentDealer['users_id']);
- $update['parent_dealer_id'] = intval($parentDealer['dealer_id']);
- $update['bind_dealer_time'] = getTime();
- }
- // 如果当前用户绑定的上级分销商有上级分销商,有则绑定为顶级分销商
- if (!empty($parentDealer['parent_users_id']) && !empty($parentDealer['parent_dealer_id'])) {
- $update['top_users_id'] = intval($parentDealer['parent_users_id']);
- $update['top_dealer_id'] = intval($parentDealer['parent_dealer_id']);
- if (empty($update['bind_dealer_time'])) $update['bind_dealer_time'] = getTime();
- }
- }
- Db::name('users')->where(['users_id' => $users_id])->update($update);
- }
-
- // 生成token (session3rd)
- $this->token = $this->token('', 'session_key', $users_id, 'openid');
-
- return $users_id;
- }
-
- /**
- * 用户注册 用户名注册
- */
- public function account_reg($post)
- {
- if (empty($post["username"])) {
- $this->error("用户名不能为空!");
- }
-
- // 查询用户名是否已经注册过
- $is_reg = Db::name("users")->where(["username" => $post["username"], "is_del" => 0])->find();
-
- if (!empty($is_reg)){
- $this->error("用户名已经注册!");
- }
-
- if (!empty($post["have_password"]) && 1 == $post["have_password"]) {
- // 用户名注册时需要填写密码但是不需要确认密码
- if (empty($post["password"]) || !trim($post["password"])) {
- $this->error("密码不能为空!");
- }
- } elseif (!empty($post["have_password"]) && 2 == $post["have_password"]){
- // 用户名注册时需要填写密码并确认密码
- if (empty($post["password"]) || !trim($post["password"])) {
- $this->error("密码不能为空!");
- }
-
- if (empty($post["confirm_password"]) || !trim($post["confirm_password"])) {
- $this->error("确认密码不能为空!");
- }
-
- if ($post["password"] != $post["confirm_password"]) {
- $this->error("两次输入密码不一致!");
- }
- } else {
- // 用户名注册时需要提那些密码但是不需要填写重复密码
- if (empty($post["password"]) || !trim($post["password"])) {
- $this->error("密码不能为空!");
- }
- }
-
- $users_id = $this->setAccountReg($post);
-
- if(!empty($users_id)) {
- // 更新会员信息
- $update = [
- "last_ip" => clientIP(),
- "last_login" => getTime(),
- "login_count" => Db::raw("login_count+1"),
- "update_time" => getTime(),
- ];
-
- // 查询用户信息
- $usersData = Db::name("users")->where(["users_id" => $users_id])->find();
-
- // 如果有推荐注册的分销商ID信息则查询并绑定
- $parentDealer = [];
- $parentUsersID = !empty($post["parent_users_id"]) ? intval($post["parent_users_id"]) : 0;
- $parentDealerID = !empty($post["parent_dealer_id"]) ? intval($post["parent_dealer_id"]) : 0;
-
- if (!empty($parentUsersID) && !empty($parentDealerID)) {
- $where = [
- "a.dealer_status" => 1,
- "a.users_id" => $parentUsersID,
- "a.dealer_id" => $parentDealerID,
- ];
-
- $field = "a.*, b.is_dealer, b.parent_users_id, b.parent_dealer_id";
-
- $parentDealer = Db::name("weapp_dealer")->alias("a")->field($field)->where($where)->join("__USERS__ b", "a.users_id = b.users_id", "LEFT")->find();
-
- $dealerOpen = getUsersConfigData("dealer.dealer_open");
-
- if ((isset($dealerOpen) && 0 === intval($dealerOpen)) || $usersData["users_id"] == $parentDealer["users_id"]) {
- $parentDealer = [];
- }
- }
-
- if (!empty($parentDealer) && empty($usersData["is_dealer"])) {
- // 如果当前登录用户没有上级分销商则绑定分销商
- if (empty($usersData["parent_users_id"]) && empty($usersData["parent_dealer_id"])) {
- $update["parent_users_id"] = intval($parentDealer["users_id"]);
- $update["parent_dealer_id"] = intval($parentDealer["dealer_id"]);
- $update["bind_dealer_time"] = getTime();
- }
-
- // 如果当前用户绑定的上级分销商有上级分销商,有则绑定为顶级分销商
- if (!empty($parentDealer["parent_users_id"]) && !empty($parentDealer["parent_dealer_id"])) {
- $update["top_users_id"] = intval($parentDealer["parent_users_id"]);
-
- $update["top_dealer_id"] = intval($parentDealer["parent_dealer_id"]);
-
- if (empty($update["bind_dealer_time"])) {
- $update["bind_dealer_time"] = getTime();
- }
- }
- }
-
- Db::name("users")->where(["users_id" => $users_id])->update($update);
- }
-
- // 生成token (session3rd)
- $this->token = $this->token('', "session_key", $users_id, "openid");
-
- return $users_id;
- }
-
- /**
- * 用户登录 手机号验证码登录/手机号密码登录
- */
- public function mobile_login($post)
- {
- if (empty($post['mobile'])) $this->error('手机号不能为空!');
- if (!check_mobile($post['mobile'])) $this->error('手机号格式不正确!');
- $where['mobile'] = $post['mobile'];
- $where['is_mobile'] = 1;
- $where['is_del'] = 0;
- $users = Db::name('users')->where($where)->find();
- if (empty($users)) $this->error('用户不存在!');
-
- //验证码登录和密码登录取其一
- if (empty($post['password']) || !trim($post['password'])) {
- if (empty($post['mobile_code'])) {
- $this->error('验证码不能为空!');
- }
- // 验证验证码
- $RecordWhere = [
- 'source' => 2,
- 'mobile' => $post['mobile'],
- 'code' => $post['mobile_code'],
- 'is_use' => 0,
- 'lang' => self::$lang
- ];
- $is_verify = Db::name('sms_log')->where($RecordWhere)->find();
- if (!empty($is_verify)){
- $RecordData = [
- 'is_use' => 1,
- 'update_time' => getTime()
- ];
- // 更新数据
- Db::name('sms_log')->where($RecordWhere)->update($RecordData);
- }else{
- $this->error('验证码错误!');
- }
- $users_id = $users['users_id'];
- } else{
- if (empty($post['password']) || !trim($post['password'])) {
- $this->error('密码不能为空!');
- }
- if (0 == config('global.opencodetype')) {
- $where['password'] = func_encrypt($post['password'], false, pwd_encry_type('bcrypt'));
- }
-
- $users_id = Db::name('users')->where($where)->value('users_id');
- if (empty($users_id)) $this->error('密码不正确');
- }
-
- if (!empty($users_id)) {
- // 更新会员信息
- $update = [
- 'last_ip' => clientIP(),
- 'last_login' => getTime(),
- 'login_count' => Db::raw('login_count+1'),
- 'update_time' => getTime(),
- ];
- Db::name('users')->where(['users_id' => $users_id])->update($update);
- }
-
- // 生成token (session3rd)
- $this->token = $this->token('', 'session_key', $users_id, 'openid');
-
- return $users_id;
- }
-
-
- /**
- * 用户登录 账号密码登录
- */
- public function account_login($post)
- {
- $post["username"] = trim($post["username"]);
- if (empty($post["username"])) {
- $this->error("用户名不能为空!");
- }
- $post["password"] = trim($post["password"]);
- if (empty($post["password"])) {
- $this->error("密码不能为空!");
- }
-
- $where = [];
- $where["username"] = $post["username"];
- $where["is_del"] = 0;
- $users = Db::name("users")->where($where)->find();
- if (empty($users)) {
- $this->error('该用户名不存在,请注册!');
- }
- if ($users["password"] != func_encrypt($post["password"], false, pwd_encry_type("bcrypt"))) {
- $this->error("密码不正确!");
- }
- if (!empty($users['admin_id'])) {
- // 后台账号不允许在前台通过账号密码登录,只能后台登录时同步到前台
- $this->error('前台禁止管理员登录!');
- }
- if (empty($users['is_activation'])) {
- $this->error('该会员尚未激活,请联系管理员!');
- }
- // 更新会员信息
- $update = [
- "last_ip" => clientIP(),
- "last_login" => getTime(),
- "login_count" => Db::raw("login_count + 1"),
- "update_time" => getTime(),
- ];
- Db::name("users")->where(["users_id" => $users['users_id']])->update($update);
- // 生成token (session3rd)
- $this->token = $this->token('', "session_key", $users['users_id'], "openid");
-
- return $users['users_id'];
- }
- }
|