第一部分是destoon 的登录过程
登录是使用member->login的函数来实现的login.inc.php
代码在login.inc.php这个文件中
- if($MOD['passport'] == 'uc') include DT_ROOT.'/api/'.$MOD['passport'].'.inc.php';
-
- $do = new member;
-
- $user = $do->login($username, $password, $cookietime);
member这个类在member.class.php中定义
- 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;
- }
如果登录成后,那么给用户设置cookie,使用的set_cookie函数是在include/global.func.php中实现
- 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);
- }
如果说用js来判断是否登录,可以通过cookie来取得相应的值是否为空
在这里说明一下cookie是有前缀的,所以推荐使用系统带的取得cookie的函数 get_cookie
系统中原自带的处理判断用户是否登录是使用的以下函数,在footer.htm中
show_task('{$taomodi_task}');
经过编译后会转化成
<script type="text/Javascript">
show_task('moduleid=1&html=index');
</script>
show_task函数在page.js中实现,有兴趣的话,可以看一下,返回的是一段js代码,js模板在template/chip/line.htm中