您的位置:首页 > 其它

destoon 的登录过程,如何使用cookie来判断用户是否登录

2014-07-16 14:33 766 查看
第一部分是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);


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('{$destoon_task}');

经过编译后会转化成

<script type="text/javascript">

show_task('moduleid=1&html=index');

</script>

show_task函数在page.js中实现,有兴趣的话,可以看一下,返回的是一段js代码,js模板在template/chip/line.htm中
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐