table('member')->field($field)->where($condition)->master($master)->find(); } /** * 取得会员详细信息(优先查询缓存) * 如果未找到,则缓存所有字段 * @param int $member_id * @param string $field 需要取得的缓存键值, 例如:'*','member_name,member_sex' * @return array */ public function getMemberInfoByID($member_id, $fields = '*') { $member_info = rcache($member_id, 'member', $fields); if (empty($member_info)) { $member_info = $this->getMemberInfo(array('member_id' => $member_id), '*', true); wcache($member_id, $member_info, 'member'); } return $member_info; } /** * 会员列表 * @param array $condition * @param string $field * @param number $page * @param string $order */ public function getMemberList($condition = array(), $field = '*', $page = 0, $order = 'member_id desc', $limit = '') { return $this->table('member')->field($field)->where($condition)->page($page)->order($order)->limit($limit)->select(); } /** * 会员数量 * @param array $condition * @return int */ public function getMemberCount($condition) { return $this->table('member')->where($condition)->count(); } /** * 编辑会员 * @param array $condition * @param array $data */ public function editMember($condition, $data) { $update = $this->table('member')->where($condition)->update($data); if ($update && $condition['member_id']) { dcache($condition['member_id'], 'member'); } return $update; } /** * 登录时创建会话SESSION * * @param array $member_info 会员信息 */ public function createSession($member_info = array(), $reg = false) { if (empty($member_info) || !is_array($member_info)) return; $_SESSION['is_login'] = '1'; $_SESSION['member_id'] = $member_info['member_id']; $_SESSION['member_mobile'] = $member_info['member_mobile']; $_SESSION['member_wxunionid'] = $member_info['member_wxunionid']; $_SESSION['member_wxopenid'] = $member_info['member_wxopenid']; $_SESSION['member_name'] = $member_info['member_name']; $_SESSION['member_email'] = $member_info['member_email']; $_SESSION['is_buy'] = isset($member_info['is_buy']) ? $member_info['is_buy'] : 1; $_SESSION['avatar'] = $member_info['member_avatar']; $_SESSION['member_avatar'] = $member_info['member_avatar']; $_SESSION['member_truename'] = $member_info['member_truename']; $_SESSION['member_nickname'] = $member_info['member_nickname']; $_SESSION['member_signname'] = $member_info['member_signname']; $_SESSION['member_sex'] = $member_info['member_sex']; $_SESSION['member_birthday'] = $member_info['member_birthday']; $_SESSION['member_mobile_bind'] = $member_info['member_mobile_bind']; $_SESSION['member_state'] = $member_info['member_state']; $seller_info = Model('seller')->getSellerInfo(array('member_id' => $_SESSION['member_id'])); $_SESSION['store_id'] = $seller_info['store_id']; if (trim($member_info['member_qqopenid'])) { $_SESSION['openid'] = $member_info['member_qqopenid']; } if (trim($member_info['member_sinaopenid'])) { $_SESSION['slast_key']['uid'] = $member_info['member_sinaopenid']; } if (!$reg) { //添加会员积分 $this->addPoint($member_info); //添加会员经验值 $this->addExppoint($member_info); } if (!empty($member_info['member_login_time'])) { $update_info = array( 'member_login_num' => ($member_info['member_login_num'] + 1), 'member_login_time' => time(), 'member_old_login_time' => $member_info['member_login_time'], 'member_login_ip' => getIp(), 'member_old_login_ip' => $member_info['member_login_ip'] ); $this->editMember(array('member_id' => $member_info['member_id']), $update_info); } if(is_mobile() == false) { setNcCookie('cart_goods_num', '', -3600); } } /** * 获取会员信息 * @param array $param 会员条件 * @param string $field 显示字段 * @return array 数组格式的返回结果 */ public function infoMember($param, $field = '*') { if (empty($param)) return false; //得到条件语句 $condition_str = $this->getCondition($param); $param = array(); $param['table'] = 'member'; $param['where'] = $condition_str; $param['field'] = $field; $param['limit'] = 1; $member_list = Db::select($param); $member_info = $member_list[0]; if (intval($member_info['store_id']) > 0) { $param = array(); $param['table'] = 'store'; $param['field'] = 'store_id'; $param['value'] = $member_info['store_id']; $field = 'store_id,store_name,grade_id'; $store_info = Db::getRow($param, $field); if (!empty($store_info) && is_array($store_info)) { $member_info['store_name'] = $store_info['store_name']; $member_info['grade_id'] = $store_info['grade_id']; } } return $member_info; } /** * 注册 */ public function register($register_info) { // 注册验证 $obj_validate = new Validator(); $obj_validate->validateparam = array( array("input" => $register_info["username"], "require" => "true", "message" => '用户名不能为空'), array("input" => $register_info["password"], "require" => "true", "message" => '密码不能为空'), array("input" => $register_info["password_confirm"], "require" => "true", "validator" => "Compare", "operator" => "==", "to" => $register_info["password"], "message" => '密码与确认密码不相同'), //array("input"=>$register_info["email"], "require"=>"true", "validator"=>"email", "message"=>'电子邮件格式不正确'), ); $error = $obj_validate->validate(); if ($error != '') { return array('error' => $error); } // 验证用户名是否重复 $check_member_name = $this->getMemberInfo(array('member_name' => $register_info['username'])); if (is_array($check_member_name) and count($check_member_name) > 0) { return array('error' => '用户名已存在'); } // 验证邮箱是否重复 $check_member_email = $this->getMemberInfo(array('member_email' => $register_info['email'])); if (is_array($check_member_email) and count($check_member_email) > 0) { return array('error' => '邮箱已存在'); } // 会员添加 $member_info = array(); $member_info['member_name'] = $register_info['username']; $member_info['member_passwd'] = $register_info['password']; $member_info['member_email'] = $register_info['email']; //添加邀请人(推荐人)会员积分 by abc.com $member_info['inviter_id'] = $register_info['inviter_id']; $insert_id = $this->addMember($member_info); if ($insert_id) { //添加会员积分 if (C('points_isuse')) { Model('points')->savePointsLog('regist', array('pl_memberid' => $insert_id, 'pl_membername' => $register_info['username']), false); //添加邀请人(推荐人)会员积分 by abc.com $inviter_name = Model('member')->table('member')->getfby_member_id($member_info['inviter_id'], 'member_name'); Model('points')->savePointsLog('inviter', array('pl_memberid' => $register_info['inviter_id'], 'pl_membername' => $inviter_name, 'invited' => $member_info['member_name'])); } // 添加默认相册 $insert['ac_name'] = '买家秀'; $insert['member_id'] = $insert_id; $insert['ac_des'] = '买家秀默认相册'; $insert['ac_sort'] = 1; $insert['is_default'] = 1; $insert['upload_time'] = time(); $this->table('sns_albumclass')->insert($insert); $member_info['member_id'] = $insert_id; $member_info['is_buy'] = 1; return $member_info; } else { return array('error' => '注册失败'); } } private function empty_model() { $member = []; $member['member_time'] = time(); $member['member_login_time'] = time(); $member['member_old_login_time'] = time(); $member['member_login_ip'] = getIp(); $member['member_old_login_ip'] = $member['member_login_ip']; return $member; } /** * 注册商城会员 * * @param array $param 会员信息 * @return array 数组格式的返回结果 */ public function addMember($param) { if (empty($param)) { return false; } $info = $this->empty_model(); foreach ($param as $key => $value) { if ($key == 'member_passwd') { $passwd = trim($param['member_passwd']); $info['member_passwd'] = empty($passwd) ? $passwd : md5($passwd); } elseif ($key == 'member_time') { $info['member_time'] = time(); } elseif ($key == 'member_login_time') { $info['member_login_time'] = time(); } elseif ($key == 'member_login_ip') { $info['member_login_ip'] = getIp(); } else { $info[$key] = $value; } } if(is_mobile()) { $mobile = $info['member_mobile']; if(!empty($mobile)) { $member = $this->getMemberInfo(array('member_mobile' => $mobile)); if(!empty($member)) return false; } } try { $trans = new trans_wapper($this,__METHOD__); $insert_id = $this->table('member')->insert($info); if (!$insert_id) { throw new Exception(); } $insert = $this->addMemberCommon(array('member_id' => $insert_id)); if (!$insert) { throw new Exception(); } $trans->commit(); return $insert_id; } catch (Exception $e) { $trans->rollback(); return false; } } /** * 会员登录检查 * */ public function checkloginMember() { if ($_SESSION['is_login'] == '1') { @header("Location: index.php"); exit(); } } /** * 检查会员是否允许举报商品 * */ public function isMemberAllowInform($member_id) { $condition = array(); $condition['member_id'] = $member_id; $member_info = $this->getMemberInfo($condition, 'inform_allow'); if (intval($member_info['inform_allow']) === 1) { return true; } else { return false; } } /** * 取单条信息 * @param unknown $condition * @param string $fields */ public function getMemberCommonInfo($condition = array(), $fields = '*') { return $this->table('member_common')->where($condition)->field($fields)->find(); } /** * 插入扩展表信息 * @param unknown $data * @return Ambigous */ public function addMemberCommon($data) { return $this->table('member_common')->insert($data); } /** * 编辑会员扩展表 * @param unknown $data * @param unknown $condition * @return Ambigous */ public function editMemberCommon($data, $condition) { return $this->table('member_common')->where($condition)->update($data); } /** * 添加会员积分 * @param unknown $member_info */ public function addPoint($member_info) { if (!C('points_isuse') || empty($member_info)) return; //一天内只有第一次登录赠送积分 if (trim(@date('Y-m-d', $member_info['member_login_time'])) == trim(date('Y-m-d'))) return; //加入队列 $queue_content = array(); $queue_content['member_id'] = $member_info['member_id']; $queue_content['member_name'] = $member_info['member_name']; QueueClient::push('addPoint', $queue_content); } /** * 添加会员经验值 * @param unknown $member_info */ public function addExppoint($member_info) { if (empty($member_info)) return; //一天内只有第一次登录赠送经验值 if (trim(@date('Y-m-d', $member_info['member_login_time'])) == trim(date('Y-m-d'))) return; //加入队列 $queue_content = array(); $queue_content['member_id'] = $member_info['member_id']; $queue_content['member_name'] = $member_info['member_name']; QueueClient::push('addExppoint', $queue_content); } /** * 取得会员安全级别 * @param unknown $member_info */ public function getMemberSecurityLevel($member_info = array()) { $tmp_level = 0; if ($member_info['member_email_bind'] == '1') { $tmp_level += 1; } if ($member_info['member_mobile_bind'] == '1') { $tmp_level += 1; } if ($member_info['member_paypwd'] != '') { $tmp_level += 1; } return $tmp_level; } /** * 获得会员等级 * @param bool $show_progress 是否计算其当前等级进度 * @param int $exppoints 会员经验值 * @param array $cur_level 会员当前等级 */ public function getMemberGradeArr($show_progress = false, $exppoints = 0, $cur_level = '') { $member_grade = C('member_grade') ? unserialize(C('member_grade')) : array(); //处理会员等级进度 if ($member_grade && $show_progress) { $is_max = false; if ($cur_level === '') { $cur_gradearr = $this->getOneMemberGrade($exppoints, false, $member_grade); $cur_level = $cur_gradearr['level']; } foreach ($member_grade as $k => $v) { if ($cur_level == $v['level']) { $v['is_cur'] = true; } $member_grade[$k] = $v; } } return $member_grade; } /** * 将条件数组组合为SQL语句的条件部分 * * @param array $conditon_array * @return string */ private function getCondition($conditon_array) { $condition_sql = ''; if ($conditon_array['member_id'] != '') { $condition_sql .= " and member_id= '" . intval($conditon_array['member_id']) . "'"; } if ($conditon_array['member_name'] != '') { $condition_sql .= " and member_name='" . $conditon_array['member_name'] . "'"; } if ($conditon_array['member_passwd'] != '') { $condition_sql .= " and member_passwd='" . $conditon_array['member_passwd'] . "'"; } //是否允许举报 if ($conditon_array['inform_allow'] != '') { $condition_sql .= " and inform_allow='{$conditon_array['inform_allow']}'"; } //是否允许购买 if ($conditon_array['is_buy'] != '') { $condition_sql .= " and is_buy='{$conditon_array['is_buy']}'"; } //是否允许发言 if ($conditon_array['is_allowtalk'] != '') { $condition_sql .= " and is_allowtalk='{$conditon_array['is_allowtalk']}'"; } //是否允许登录 if ($conditon_array['member_state'] != '') { $condition_sql .= " and member_state='{$conditon_array['member_state']}'"; } if ($conditon_array['friend_list'] != '') { $condition_sql .= " and member_name IN (" . $conditon_array['friend_list'] . ")"; } if ($conditon_array['member_email'] != '') { $condition_sql .= " and member_email='" . $conditon_array['member_email'] . "'"; } if ($conditon_array['no_member_id'] != '') { $condition_sql .= " and member_id != '" . $conditon_array['no_member_id'] . "'"; } if ($conditon_array['like_member_name'] != '') { $condition_sql .= " and member_name like '%" . $conditon_array['like_member_name'] . "%'"; } if ($conditon_array['like_member_email'] != '') { $condition_sql .= " and member_email like '%" . $conditon_array['like_member_email'] . "%'"; } if ($conditon_array['like_member_truename'] != '') { $condition_sql .= " and member_truename like '%" . $conditon_array['like_member_truename'] . "%'"; } if ($conditon_array['in_member_id'] != '') { $condition_sql .= " and member_id IN (" . $conditon_array['in_member_id'] . ")"; } if ($conditon_array['in_member_name'] != '') { $condition_sql .= " and member_name IN (" . $conditon_array['in_member_name'] . ")"; } if ($conditon_array['member_qqopenid'] != '') { $condition_sql .= " and member_qqopenid = '{$conditon_array['member_qqopenid']}'"; } if ($conditon_array['member_sinaopenid'] != '') { $condition_sql .= " and member_sinaopenid = '{$conditon_array['member_sinaopenid']}'"; } return $condition_sql; } /** * 删除会员 * * @param int $id 记录ID * @return array $rs_row 返回数组形式的查询结果 */ public function del($id) { if (intval($id) > 0) { $where = " member_id = '" . intval($id) . "'"; $result = Db::delete('member', $where); return $result; } else { return false; } } /** * 获得某一会员等级 * @param int $exppoints * @param bool $show_progress 是否计算其当前等级进度 * @param array $member_grade 会员等级 */ public function getOneMemberGrade($exppoints, $show_progress = false, $member_grade = array()) { if (!$member_grade) { $member_grade = C('member_grade') ? unserialize(C('member_grade')) : array(); } if (empty($member_grade)) {//如果会员等级设置为空 $grade_arr['level'] = -1; $grade_arr['level_name'] = '暂无等级'; return $grade_arr; } $exppoints = intval($exppoints); $grade_arr = array(); if ($member_grade) { foreach ($member_grade as $k => $v) { if ($exppoints >= $v['exppoints']) { $grade_arr = $v; } } } //计算提升进度 if ($show_progress == true) { if (intval($grade_arr['level']) >= (count($member_grade) - 1)) {//如果已达到顶级会员 $grade_arr['downgrade'] = $grade_arr['level'] - 1;//下一级会员等级 $grade_arr['downgrade_name'] = $member_grade[$grade_arr['downgrade']]['level_name']; $grade_arr['downgrade_exppoints'] = $member_grade[$grade_arr['downgrade']]['exppoints']; $grade_arr['upgrade'] = $grade_arr['level'];//上一级会员等级 $grade_arr['upgrade_name'] = $member_grade[$grade_arr['upgrade']]['level_name']; $grade_arr['upgrade_exppoints'] = $member_grade[$grade_arr['upgrade']]['exppoints']; $grade_arr['less_exppoints'] = 0; $grade_arr['exppoints_rate'] = 100; } else { $grade_arr['downgrade'] = $grade_arr['level'];//下一级会员等级 $grade_arr['downgrade_name'] = $member_grade[$grade_arr['downgrade']]['level_name']; $grade_arr['downgrade_exppoints'] = $member_grade[$grade_arr['downgrade']]['exppoints']; $grade_arr['upgrade'] = $member_grade[$grade_arr['level'] + 1]['level'];//上一级会员等级 $grade_arr['upgrade_name'] = $member_grade[$grade_arr['upgrade']]['level_name']; $grade_arr['upgrade_exppoints'] = $member_grade[$grade_arr['upgrade']]['exppoints']; $grade_arr['less_exppoints'] = $grade_arr['upgrade_exppoints'] - $exppoints; $grade_arr['exppoints_rate'] = round(($exppoints - $member_grade[$grade_arr['level']]['exppoints']) / ($grade_arr['upgrade_exppoints'] - $member_grade[$grade_arr['level']]['exppoints']) * 100, 2); } } return $grade_arr; } /** * @param $user_id 用户ID * @return float 获取用户预存款金额 */ public function getPdAmount($member_id){ //查询会员信息 $member_id = intval($member_id); $member_info = $this->getMemberInfo(array('member_id'=>$member_id)); if (!is_array($member_info) || count($member_info)<=0){ return 0.0; // 用户信息不对 } return floatval($member_info['available_predeposit']); } /** * @param $user_id 用户ID * @return array 获取用户预存款, 冻结预存款金额 */ public function getMemberPdInfo($member_id) { //查询会员信息 $member_id = intval($member_id); $member_info = $this->getMemberInfo(array('member_id'=>$member_id)); if (!is_array($member_info) || count($member_info)<=0){ return 0; // 用户信息不对 } $available_predeposit=floatval($member_info['available_predeposit']); $freeze_predeposit=floatval($member_info['freeze_predeposit']); $available_relay_balance=floatval($member_info['available_relay_balance']); $freeze_relay_balance=floatval($member_info['freeze_relay_balance']); $rate_version = intval($member_info['rate_version']); return array('available_predeposit' => $available_predeposit, 'freeze_predeposit' => $freeze_predeposit, 'available_relay_balance' => $available_relay_balance, 'freeze_relay_balance' => $freeze_relay_balance, 'rate_version' => $rate_version); } public function inc_rate_version($member_id) { $this->table('member')->where(array('member_id' => $member_id))->update(array('rate_version' => array('exp', "rate_version+1"))); } }