更新时间:2022-07-02 16:36:39
第一部分是destoon 的登录过程
登录是使用member->login的函数来实现的login.inc.php
代码在login.inc.php这个文件中
if($MOD['passport'] == 'uc') include DT_ROOT.'/api/'.$MOD['passport'].'.inc.php'; //7 line $do = new member; //42 line $user = $do->login($username, $password, $cookietime);
function login($login_username, $login_password, $login_cookietime = 0, $admin = false) { global $DT_TIME, $DT_IP, $MOD, $MODULE, $L; ........................ $auth=encrypt($user['userid']."\t".$user['username']."\t".$user['groupid']."\t".$user['password']."\t".$user['admin'], md5(DT_KEY.$DT_IP)); set_cookie('auth', $auth, $cookietime); set_cookie('userid', $user['userid'], $cookietime); set_cookie('username', $user['username'], $DT_TIME + 86400*365); $this->db->query("UPDATE {$this->table_member} SET loginip='$DT_IP',logintime=$DT_TIME,logintimes=logintimes+1 WHERE userid=$userid"); return $user; }
function set_cookie($var, $value = '', $time = 0) { global $CFG, $DT_TIME; $time = $time > 0 ? $time : (empty($value) ? $DT_TIME - 3600 : 0); $port = $_SERVER['SERVER_PORT'] == '443' ? 1 : 0; $var = $CFG['cookie_pre'].$var; return setcookie($var, $value, $time, $CFG['cookie_path'], $CFG['cookie_domain'], $port); }
在这里说明一下cookie是有前缀的,所以推荐使用系统带的取得cookie的函数 get_cookie
系统中原自带的处理判断用户是否登录是使用的以下函数,在footer.htm中
show_task('{$destoon_task}');
经过编译后会转化成
<script type="text/javascript">
show_task('moduleid=1&html=index');
</script>
show_task函数在page.js中实现,有兴趣的话,可以看一下,返回的是一段js代码,js模板在template/chip/line.htm中