-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathtest.php
115 lines (95 loc) · 3.43 KB
/
test.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
<?php
error_reporting(E_ALL);
ini_set('display_errors', '1');
class SimpleDB{
var $dbh;
var $dbIP = 'localhost';
var $dbName = 'bomberman';
var $dbLoginName = 'root';
var $dbPassword = 'fr5zbbqf';
var $sessionTable = 'bbm_session';
var $accountTable = 'bbm_account';
const session_duration = 20;//20s for experimental use
function __construct(){
$this->dbh = new PDO("mysql:host=$this->dbIP;dbname=$this->dbName", $this->dbLoginName, $this->dbPassword);
}
function getSessionKeyBySession($usr_session){
// =========get DB session key===========
$query = $this->dbh->prepare("SELECT session FROM $this->sessionTable WHERE session=?");
$query->execute(array($usr_session));
$db_session = $query->fetch(PDO::FETCH_ASSOC);
if ($db_session != null){
return $db_session['session'];
}else{
return null;
}
}
function getSessionExpiryTime($usr_session){
//=========get DB expiry time =========
$query = $this->dbh->prepare("SELECT expiry_time FROM $this->sessionTable WHERE session=?");
$query->execute(array($usr_session));
$db_expiry_time = $query->fetch(PDO::FETCH_ASSOC);//e.g. 2013-04-25 07:13:12
if ($db_expiry_time != null){
return strtotime($db_expiry_time['expiry_time']);
}else{
return null;
}
}
function updateSession($usr_session){
//=====update session key=====
$new_expiry_time = time()+self::session_duration;
$query = $this->dbh->prepare("UPDATE $this->sessionTable SET expiry_time=? WHERE session=?");
$query->execute(array(date('Y-m-d H:i:s',$new_expiry_time), $usr_session));
}
function getPassword($id){
$query = $this->dbh->prepare("SELECT password FROM $this->accountTable WHERE id=?");
$query->execute(array($id));
$db_pwd = $query->fetch(PDO::FETCH_ASSOC);
if ($db_pwd != null){
return $db_pwd['password'];
}else{
return null;
}
}
function createSession($id){
// ===prepare cookie===
$characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
$session_key = null;
for ($i = 0; $i < 20; $i++){
$session_key = $session_key.$characters[rand(0,strlen($characters)-1)];
}
$query = $this->dbh->prepare("SELECT session FROM $this->sessionTable WHERE id=?");
$query->execute(array($id));
$result = $query->fetch();
if ($result != null){
//clear any old session
$query = $this->dbh->prepare("DELETE FROM $this->sessionTable WHERE id=?");
$query->execute(array($id));
}
//append session
$expiry_time = time()+self::session_duration;
$query = $this->dbh->prepare("INSERT INTO $this->sessionTable (id, session, expiry_time) VALUES (?,?,?)");
$query->execute(array($id, $session_key, date('Y-m-d H:i:s',$expiry_time)));
// ====================
return $session_key;
}
function removeSessionBySession($usr_session){
//remove the session when logout
$query = $this->dbh->prepare("DELETE FROM $this->sessionTable WHERE session=?");
$query->execute(array($usr_session));
}
}
#Test updateSessionKey()
$MyDB = new SimpleDB();
$sessionKey = $MyDB->createSession('admin');
/*
#Test getSessionKey()
$MyDB = new SimpleDB();
$sessionKey = $MyDB->getSessionKey('1');
echo $sessionKey['session'];
#Test getSessionExpiryTime()
$MyDB = new SimpleDB();
$expiry_time = $MyDB->getSessionExpiryTime('2');
echo $expiry_time;
*/
?>