You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

161 lines
6.1 KiB

<?php
/**
* Created by PhpStorm.
* User: a
* Date: 2017/3/1
* Time: 18:53
*/
if (!defined('IN_DZZ')) {
exit('Access Denied');
}
global $_G;
if ($_G['uid'] > 0) {
$param = array(
'username' => $_G['username'],
'usergroup' => $_G['group']['grouptitle'],
'uid' => $_G['uid'],
'groupid' => $_G['groupid'],
'syn' => 0
);
$loginmessage = 'login_succeed';
$location = dreferer();//待修改
$href = str_replace("'", "\'", $location);
$href = preg_replace("/user\.php\?mod\=login.*?$/i", "", $location);
$messageText = lang($loginmessage, $param);
writelog('loginlog', '登录成功');
showmessage($messageText, $href);
}
$setting = isset($_G['setting']) ? $_G['setting'] : '';
if (empty($setting)) {
$setting = C::t('setting')->fetch_all(array(), true);
}
$_G['allow_loginmod'] = $setting['allow_loginmod'] = unserialize($setting['allow_loginmod']);
//Hook::listen('login_check');//检查登录状态
$from_connect = $setting['connect']['allow'] && !empty($_GET['from']) ? 1 : 0;
$seccodecheck = $from_connect ? false : $setting['seccodestatus'] & 2;//是否开启验证码
$seccodestatus = !empty($_GET['lssubmit']) ? false : $seccodecheck;
if (!isset($_GET['loginsubmit'])) {//是否提交
$username = !empty($_G['cookie']['loginuser']) ? dhtmlspecialchars($_G['cookie']['loginuser']) : '';
$cookietimecheck = !empty($_G['cookie']['cookietime']) || !empty($_GET['cookietime']) ? 'checked="checked"' : '';
if ($seccodecheck) $seccode = random(6, 1);
$referer = (isset($_GET['referer'])) ? $_GET['referer'] : dreferer();
$_G['sso_referer'] = $referer;
$navtitle = lang('title_login');
$templateId = isset($_GET['template']) ? $_GET['template'] : (isset($setting['loginset']['template']) ? $setting['loginset']['template'] : 1);
if ($templateId == 4) {
if (isset($_GET['template']) && $_GET['template'] == 4) {
$templateId = 1;
}
if ($setting['loginset']['template'] == 4) {
$templateId = 4;
$data = array();
if($setting['loginset']['orgid'] && $setting['loginset']['orgid'] !== 'other') {
$orgid = $setting['loginset']['orgid'];
$param = array('organization_user', 'organization_job', 'user');
$sql = "ou.orgid = %d AND u.adminid != 1 AND u.status = 0";
$users = DB::fetch_all("SELECT u.uid,u.username,j.name as jobname FROM %t ou LEFT JOIN %t j ON ou.jobid = j.jobid LEFT JOIN %t u ON ou.uid = u.uid WHERE $sql ORDER BY u.uid ASC LIMIT 1000",array_merge($param, array($orgid)));
foreach ($users as $user) {
$data[] = array(
'uid' => $user['uid'],
'username' => $user['username'],
'jobname' => $user['jobname'] ?: '成员'
);
}
}
}
}
include template('login_single' . $templateId);
} else {
$type = isset($_GET['returnType']) ? $_GET['returnType'] : 'json';//返回值方式
Hook::listen('login_valchk', $_GET);//验证登录输入值及登录失败次数
//验证码开启,检测验证码
if ($seccodecheck && !check_seccode($_GET['seccodeverify'], $_GET['sechash'])) {
showTips(array('error' => lang('submit_seccode_invalid')), $type);
}
//登录
$result = userlogin($_GET['email'], $_GET['password'], $_GET['questionid'], $_GET['answer'], 'auto', $_G['clientip']);
if ($result['status'] == -2) {
$errorlog = "用户" . ($result['ucresult']['email'] ? $result['ucresult']['email'] : $_GET['email']) . "尝试登录失败,该用户已停用。";
writelog('loginlog', $errorlog);
showTips(array('error' => lang('user_stopped_please_admin')), $type);
} elseif ($_G['setting']['bbclosed'] > 0 && $result['member']['adminid'] != 1) {
showTips(array('error' => lang('site_closed_please_admin')), $type);
}
if ($result['status'] > 0) {
//设置登录
setloginstatus($result['member'], $_GET['cookietime'] ? 2592000 : 0);
if ($_G['member']['lastip'] && $_G['member']['lastvisit']) {
dsetcookie('lip', $_G['member']['lastip'] . ',' . $_G['member']['lastvisit']);
}
//记录登录
C::t('user_status')->update($_G['uid'], array('lastip' => $_G['clientip'], 'lastvisit' => TIMESTAMP, 'lastactivity' => TIMESTAMP));
//邀请登录
//Hook::listen('inviate');
//登录成功提示信息
$param = array(
'username' => $result['ucresult']['username'],
'usergroup' => $_G['group']['grouptitle'],
'uid' => $_G['member']['uid'],
'groupid' => $_G['groupid'],
'syn' => 0
);
$loginmessage = /*$_G['groupid'] == 8 ? 'login_succeed_inactive_member' :*/'login_succeed';
$location = /*$_G['groupid'] == 8 ? 'user.php?mod=profile' :*/dreferer();//待修改
$href = str_replace("'", "\'", $location);
$href = preg_replace("/user\.php\?mod\=login.*?$/i", "", $location);
$messageText = lang($loginmessage, $param);
writelog('loginlog', '登录成功');
showTips(array('success' => array('message' => $messageText, 'url_forward' => $href)), $type);
} else {//登录失败记录日志
//写入日志
$errorlog = "用户" . ($result['ucresult']['email'] ? $result['ucresult']['email'] : $_GET['email']) . "尝试登录[" . $password . "]错误";
writelog('loginlog', $errorlog);
loginfailed($_GET['email']);//更新登录失败记录
if ($_G['member_loginperm'] > 1) {
showTips(array('error' => lang('login_invalid', array('loginperm' => $_G['member_loginperm'] - 1))), $type);
} elseif ($_G['member_loginperm'] == -1) {
showTips(array('error' => lang('login_password_invalid')), $type);
} else {
showTips(array('error' => lang('login_strike', array('forbiddentime' => $_G['setting']['forbiddentime'] ? $_G['setting']['forbiddentime'] : 900))), $type);
}
}
}