* 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 = ""; foreach ($values as $key => $val) { if (is_numeric($val)) { $xml .= "<" . $key . ">" . $val . ""; } else { $xml .= "<" . $key . ">"; } } $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('//iUs', $content, $imginfo); $imginfo = !empty($imginfo[0]) ? $imginfo[0] : []; if (!empty($imginfo)) { foreach ($imginfo as $key => $imgstr) { $imgstrNew = $imgstr; $url = preg_replace("//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'] = ""; } } 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'] = ""; } } 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']; } }