123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398 |
- <?php
- /**
- * 账户安全
- *
- *
- *
- ***/
- defined('InShopNC') or exit('Access Invalid!');
- class member_securityControl extends BaseMemberControl {
- public function __construct() {
- parent::__construct();
- }
- /**
- * 安全列表
- */
- public function indexOp() {
- self::profile_menu('index','index');
- $member_info = $this->member_info;
- $member_info['security_level'] = Model('member')->getMemberSecurityLevel($member_info);
- Tpl::output('member_info',$member_info);
- Tpl::showpage('member_security.index');
- }
- /**
- * 绑定邮箱 - 发送邮件
- */
- public function send_bind_emailOp() {
- $obj_validate = new Validator();
- $obj_validate->validateparam = array(
- array("input"=>$_POST["email"], "require"=>"true", 'validator'=>'email',"message"=>'请正确填写邮箱')
- );
- $error = $obj_validate->validate();
- if ($error != ''){
- showValidateError($error);
- }
- $model_member = Model('member');
- $condition = array();
- $condition['member_email'] = $_POST['email'];
- $condition['member_id'] = array('neq',$_SESSION['member_id']);
- $member_info = $model_member->getMemberInfo($condition,'member_id');
- if ($member_info) {
- showDialog('该邮箱已被使用');
- }
- $data = array();
- $data['member_email'] = $_POST['email'];
- $data['member_email_bind'] = 0;
- $update = $model_member->editMember(array('member_id'=>$_SESSION['member_id']),$data);
- if (!$update) {
- showDialog('系统发生错误,如有疑问请与管理员联系');
- }
- $seed = random(6);
- $data = array();
- $data['auth_code'] = $seed;
- $data['send_acode_time'] = TIMESTAMP;
- $update = $model_member->editMemberCommon($data,array('member_id'=>$_SESSION['member_id']));
- if (!$update) {
- showDialog('系统发生错误,如有疑问请与管理员联系');
- }
- $uid = base64_encode(encrypt($_SESSION['member_id'].' '.$_POST["email"]));
- $verify_url = SHOP_SITE_URL.'/index.php?act=login&op=bind_email&uid='.$uid.'&hash='.md5($seed);
- $model_tpl = Model('mail_templates');
- $tpl_info = $model_tpl->getTplInfo(array('code'=>'bind_email'));
- $param = array();
- $param['site_name'] = C('site_name');
- $param['user_name'] = $_SESSION['member_name'];
- $param['verify_url'] = $verify_url;
- $subject = ncReplaceText($tpl_info['title'],$param);
- $message = ncReplaceText($tpl_info['content'],$param);
- $email = new Email();
- $result = $email->send_sys_email($_POST["email"],$subject,$message);
- showDialog('验证邮件已经发送至您的邮箱,请于24小时内登录邮箱并完成验证!','index.php?act=member_security&op=index','succ','',5);
- }
- /**
- * 统一身份验证入口
- */
- public function authOp() {
- $model_member = Model('member');
- if (chksubmit(false,true)) {
- if (!in_array($_POST['type'],array('modify_pwd','modify_mobile','modify_email','modify_paypwd','pd_cash'))) {
- redirect('index.php?act=member_security&op=index');
- }
- $member_common_info = $model_member->getMemberCommonInfo(array('member_id'=>$_SESSION['member_id']));
- if (empty($member_common_info) || !is_array($member_common_info)) {
- showMessage('验证失败','','html','error');
- }
- if ($member_common_info['auth_code'] != $_POST['auth_code'] || TIMESTAMP - $member_common_info['send_acode_time'] > 1800) {
- showMessage('验证码已被使用或超时,请重新获取验证码','','html','error');
- }
- $data = array();
- $data['auth_code'] = '';
- $data['send_acode_time'] = 0;
- $update = $model_member->editMemberCommon($data,array('member_id'=>$_SESSION['member_id']));
- if (!$update) {
- showMessage('系统发生错误,如有疑问请与管理员联系',SHOP_SITE_URL,'html','error');
- }
- setNcCookie('seccode'.$_POST['nchash'], '',-3600);
- $_SESSION['auth_'.$_POST['type']] = TIMESTAMP;
- self::profile_menu($_POST['type'],$_POST['type']);
- if ($_POST['type'] == 'pd_cash') {
- Tpl::showpage('member_pd_cash.add');
- } else {
- Tpl::showpage('member_security.'.$_POST['type']);
- }
- } else {
- if (!in_array($_GET['type'],array('modify_pwd','modify_mobile','modify_email','modify_paypwd','pd_cash'))) {
- redirect('index.php?act=member_security&op=index');
- }
-
- //继承父类的member_info
- $member_info = $this->member_info;
- if (!$member_info){
- $member_info = $model_member->getMemberInfo(array('member_id'=>$_SESSION['member_id']),'member_email,member_email_bind,member_mobile,member_mobile_bind');
- }
- self::profile_menu($_GET['type'],$_GET['type']);
- //第一次绑定邮箱,不用发验证码,直接进下一步
- //第一次绑定手机,不用发验证码,直接进下一步
- if (($_GET['type'] == 'modify_email' && $member_info['member_email_bind'] == '0') ||
- ($_GET['type'] == 'modify_mobile' && $member_info['member_mobile_bind'] == '0')) {
- $_SESSION['auth_'.$_GET['type']] = TIMESTAMP;
- Tpl::showpage('member_security.'.$_GET['type']);
- exit;
- }
- //修改密码、设置支付密码时,必须绑定邮箱或手机
- if (in_array($_GET['type'],array('modify_pwd','modify_paypwd')) && $member_info['member_email_bind'] == '0' &&
- $member_info['member_mobile_bind'] == '0') {
- showMessage('请先绑定邮箱或手机','index.php?act=member_security&op=index','html','error');
- }
- Tpl::output('member_info',$member_info);
- Tpl::showpage('member_security.auth');
- }
- }
- /**
- * 统一发送身份验证码
- */
- public function send_auth_codeOp() {
- if (!in_array($_GET['type'],array('email','mobile'))) exit();
- $model_member = Model('member');
- $member_info = $model_member->getMemberInfoByID($_SESSION['member_id'],'member_email,member_mobile');
- $verify_code = rand(100,999).rand(100,999);
- $data = array();
- $data['auth_code'] = $verify_code;
- $data['send_acode_time'] = TIMESTAMP;
- $update = $model_member->editMemberCommon($data,array('member_id'=>$_SESSION['member_id']));
- if (!$update) {
- exit(json_encode(array('state'=>'false','msg'=>'系统发生错误,如有疑问请与管理员联系')));
- }
- $model_tpl = Model('mail_templates');
- $tpl_info = $model_tpl->getTplInfo(array('code'=>'authenticate'));
- $param = array();
- $param['send_time'] = date('Y-m-d H:i',TIMESTAMP);
- $param['verify_code'] = $verify_code;
- $param['site_name'] = C('site_name');
- $subject = ncReplaceText($tpl_info['title'],$param);
- $message = ncReplaceText($tpl_info['content'],$param);
- if ($_GET['type'] == 'email') {
- $email = new Email();
- $result = $email->send_sys_email($member_info["member_email"],$subject,$message);
- } elseif ($_GET['type'] == 'mobile') {
- $sms = new Sms();
- $result = $sms->send($member_info["member_mobile"],$message);
- }
- if ($result) {
- exit(json_encode(array('state'=>'true','msg'=>'验证码已发出,请注意查收')));
- } else {
- exit(json_encode(array('state'=>'false','msg'=>'验证码发送失败')));
- }
- }
- /**
- * 修改密码
- */
- public function modify_pwdOp() {
- $model_member = Model('member');
- //身份验证后,需要在30分钟内完成修改密码操作
- if (TIMESTAMP - $_SESSION['auth_modify_pwd'] > 1800) {
- showMessage('操作超时,请重新获得验证码','index.php?act=member_security&op=auth&type=modify_pwd','html','error');
- }
- if(!chksubmit()) exit();
- $obj_validate = new Validator();
- $obj_validate->validateparam = array(
- array("input"=>$_POST["password"], "require"=>"true", "message"=>'请正确输入密码'),
- array("input"=>$_POST["confirm_password"], "require"=>"true", "validator"=>"Compare","operator"=>"==","to"=>$_POST["password"],"message"=>'两次密码输入不一致'),
- );
- $error = $obj_validate->validate();
- if ($error != ''){
- showValidateError($error);
- }
- $update = $model_member->editMember(array('member_id'=>$_SESSION['member_id']),array('member_passwd'=>md5($_POST['password'])));
- $message = $update ? '密码修改成功' : '密码修改失败';
- unset($_SESSION['auth_modify_pwd']);
- showDialog($message,'index.php?act=member_security&op=index',$update ? 'succ' : 'error');
- }
- /**
- * 设置支付密码
- */
- public function modify_paypwdOp() {
- $model_member = Model('member');
- //身份验证后,需要在30分钟内完成修改密码操作
- if (TIMESTAMP - $_SESSION['auth_modify_paypwd'] > 1800) {
- showMessage('操作超时,请重新获得验证码','index.php?act=member_security&op=auth&type=modify_paypwd','html','error');
- }
- if(!chksubmit()) exit();
- $obj_validate = new Validator();
- $obj_validate->validateparam = array(
- array("input"=>$_POST["password"], "require"=>"true", "message"=>'请正确输入密码'),
- array("input"=>$_POST["confirm_password"], "require"=>"true", "validator"=>"Compare","operator"=>"==","to"=>$_POST["password"],"message"=>'两次密码输入不一致'),
- );
- $error = $obj_validate->validate();
- if ($error != ''){
- showValidateError($error);
- }
- $update = $model_member->editMember(array('member_id'=>$_SESSION['member_id']),array('member_paypwd'=>md5($_POST['password'])));
- $message = $update ? '密码设置成功' : '密码设置失败';
- unset($_SESSION['auth_modify_paypwd']);
- showDialog($message,'index.php?act=member_security&op=index',$update ? 'succ' : 'error');
- }
- /**
- * 绑定手机
- */
- public function modify_mobileOp() {
- $model_member = Model('member');
- $member_info = $model_member->getMemberInfoByID($_SESSION['member_id'],'member_mobile_bind');
- if (chksubmit()) {
- $obj_validate = new Validator();
- $obj_validate->validateparam = array(
- array("input"=>$_POST["mobile"], "require"=>"true", 'validator'=>'mobile',"message"=>'请正确填写手机号'),
- array("input"=>$_POST["vcode"], "require"=>"true", 'validator'=>'number',"message"=>'请正确填写手机验证码'),
- );
- $error = $obj_validate->validate();
- if ($error != ''){
- showValidateError($error);
- }
- $condition = array();
- $condition['member_id'] = $_SESSION['member_id'];
- $condition['auth_code'] = intval($_POST['vcode']);
- $member_common_info = $model_member->getMemberCommonInfo($condition,'send_acode_time');
- if (!$member_common_info) {
- showDialog('手机验证码错误,请重新输入');
- }
- if (TIMESTAMP - $member_common_info['send_acode_time'] > 1800) {
- showDialog('手机验证码已过期,请重新获取验证码');
- }
- $data = array();
- $data['auth_code'] = '';
- $data['send_acode_time'] = 0;
- $update = $model_member->editMemberCommon($data,array('member_id'=>$_SESSION['member_id']));
- if (!$update) {
- showDialog('系统发生错误,如有疑问请与管理员联系');
- }
- $update = $model_member->editMember(array('member_id'=>$_SESSION['member_id']),array('member_mobile_bind'=>1));
- if (!$update) {
- showDialog('系统发生错误,如有疑问请与管理员联系');
- }
- showDialog('手机号绑定成功','index.php?act=member_security&op=index','succ');
- }
- }
- /**
- * 修改手机号 - 发送验证码
- */
- public function send_modify_mobileOp() {
- $obj_validate = new Validator();
- $obj_validate->validateparam = array(
- array("input"=>$_GET["mobile"], "require"=>"true", 'validator'=>'mobile',"message"=>'请正确填写手机号码'),
- );
- $error = $obj_validate->validate();
- if ($error != ''){
- exit(json_encode(array('state'=>'false','msg'=>$error)));
- }
- $model_member = Model('member');
- $condition = array();
- $condition['member_mobile'] = $_GET['mobile'];
- $condition['member_id'] = array('neq',$_SESSION['member_id']);
- $member_info = $model_member->getMemberInfo($condition,'member_id');
- if ($member_info) {
- exit(json_encode(array('state'=>'false','msg'=>'该手机号已被使用,请更换其它手机号')));
- }
- $update = $model_member->editMember(array('member_id'=>$_SESSION['member_id']),array('member_mobile'=>$_GET['mobile']));
- if (!$update) {
- exit(json_encode(array('state'=>'false','msg'=>'系统发生错误,如有疑问请与管理员联系')));
- }
- $verify_code = rand(100,999).rand(100,999);
- $data = array();
- $data['auth_code'] = $verify_code;
- $data['send_acode_time'] = TIMESTAMP;
- $update = $model_member->editMemberCommon($data,array('member_id'=>$_SESSION['member_id']));
- if (!$update) {
- exit(json_encode(array('state'=>'false','msg'=>'系统发生错误,如有疑问请与管理员联系')));
- }
- $model_tpl = Model('mail_templates');
- $tpl_info = $model_tpl->getTplInfo(array('code'=>'modify_mobile'));
- $param = array();
- $param['site_name'] = C('site_name');
- $param['send_time'] = date('Y-m-d H:i',TIMESTAMP);
- $param['verify_code'] = $verify_code;
- $message = ncReplaceText($tpl_info['content'],$param);
- $sms = new Sms();
- $result = $sms->send($_GET["mobile"],$message);
- if ($result) {
- exit(json_encode(array('state'=>'true','msg'=>'发送成功')));
- } else {
- exit(json_encode(array('state'=>'false','msg'=>'发送失败')));
- }
- }
- /**
- * 用户中心右边,小导航
- *
- * @param string $menu_type 导航类型
- * @param string $menu_key 当前导航的menu_key
- * @return
- */
- private function profile_menu($menu_type,$menu_key='') {
- $menu_array = array();
- switch ($menu_type) {
- case 'index':
- $menu_array = array(
- array('menu_key'=>'index', 'menu_name'=>'账户安全','menu_url'=>'index.php?act=member_security&op=index'),
- );
- break;
- case 'modify_pwd':
- $menu_array = array(
- array('menu_key'=>'index', 'menu_name'=>'账户安全','menu_url'=>'index.php?act=member_security&op=index'),
- array('menu_key'=>'modify_pwd','menu_name'=>'修改登录密码','menu_url'=>'index.php?act=member_security&op=auth&type=modify_pwd'),
- );
- break;
- case 'modify_email':
- $menu_array = array(
- array('menu_key'=>'index', 'menu_name'=>'账户安全','menu_url'=>'index.php?act=member_security&op=index'),
- array('menu_key'=>'modify_email', 'menu_name'=>'邮箱验证','menu_url'=>'index.php?act=member_security&op=auth&type=modify_email'),
- );
- break;
- case 'modify_mobile':
- $menu_array = array(
- array('menu_key'=>'index', 'menu_name'=>'账户安全','menu_url'=>'index.php?act=member_security&op=index'),
- array('menu_key'=>'modify_mobile','menu_name'=>'手机验证','menu_url'=>'index.php?act=member_security&op=auth&type=modify_mobile'),
- );
- break;
- case 'modify_paypwd':
- $menu_array = array(
- array('menu_key'=>'index', 'menu_name'=>'账户安全','menu_url'=>'index.php?act=member_security&op=index'),
- array('menu_key'=>'modify_paypwd','menu_name'=>'设置支付密码','menu_url'=>'index.php?act=member_security&op=auth&type=modify_paypwd'),
- );
- break;
- case 'pd_cash':
- $menu_array = array(
- array('menu_key'=>'loglist','menu_name'=>'账户余额', 'menu_url'=>'index.php?act=predeposit&op=pd_log_list'),
- array('menu_key'=>'recharge_list','menu_name'=>'充值明细', 'menu_url'=>'index.php?act=predeposit&op=index'),
- array('menu_key'=>'cashlist','menu_name'=>'余额提现', 'menu_url'=>'index.php?act=predeposit&op=pd_cash_list'),
- array('menu_key'=>'pd_cash','menu_name'=>'提现申请','menu_url'=>'index.php?act=member_security&op=auth&type=pd_cash'),
- );
- break;
- }
- Tpl::output('member_menu',$menu_array);
- Tpl::output('menu_key',$menu_key);
- }
- }
|