1 | <?php
|
---|
2 |
|
---|
3 | /*
|
---|
4 | V4.80 8 Mar 2006 (c) 2000-2007 John Lim (jlim#natsoft.com.my). All rights reserved.
|
---|
5 | Released under both BSD license and Lesser GPL library license.
|
---|
6 | Whenever there is any discrepancy between the two licenses,
|
---|
7 | the BSD license will take precedence.
|
---|
8 | Set tabs to 4 for best viewing.
|
---|
9 |
|
---|
10 | Latest version is available at http://adodb.sourceforge.net
|
---|
11 | */
|
---|
12 |
|
---|
13 | function NotifyExpire($ref,$key)
|
---|
14 | {
|
---|
15 | print "<p><b>Notify Expiring=$ref, sessionkey=$key</b></p>";
|
---|
16 | }
|
---|
17 |
|
---|
18 | //-------------------------------------------------------------------
|
---|
19 |
|
---|
20 | error_reporting(E_ALL);
|
---|
21 |
|
---|
22 |
|
---|
23 | ob_start();
|
---|
24 | include('../session/adodb-cryptsession2.php');
|
---|
25 |
|
---|
26 | $options['debug'] = 99;
|
---|
27 | $db = 'postgres';
|
---|
28 |
|
---|
29 | #### CONNECTION
|
---|
30 | switch($db) {
|
---|
31 | case 'oci8':
|
---|
32 | $options['table'] = 'adodb_sessions2';
|
---|
33 | ADOdb_Session::config('oci8', '', 'jcollect', 'natsoft', '',$options);
|
---|
34 | break;
|
---|
35 |
|
---|
36 | case 'postgres':
|
---|
37 | ADOdb_Session::config('postgres', 'localhost', 'tester', 'test', 'test',$options);
|
---|
38 | break;
|
---|
39 |
|
---|
40 | case 'mysql':
|
---|
41 | default:
|
---|
42 | ADOdb_Session::config('mysql', 'localhost', 'root', '', 'xphplens_2',$options);
|
---|
43 | break;
|
---|
44 |
|
---|
45 |
|
---|
46 | }
|
---|
47 |
|
---|
48 |
|
---|
49 |
|
---|
50 | #### SETUP NOTIFICATION
|
---|
51 | $USER = 'JLIM'.rand();
|
---|
52 | $ADODB_SESSION_EXPIRE_NOTIFY = array('USER','NotifyExpire');
|
---|
53 |
|
---|
54 | adodb_session_create_table();
|
---|
55 | session_start();
|
---|
56 |
|
---|
57 | adodb_session_regenerate_id();
|
---|
58 |
|
---|
59 | ### SETUP SESSION VARIABLES
|
---|
60 | if (empty($_SESSION['MONKEY'])) $_SESSION['MONKEY'] = array(1,'abc',44.41);
|
---|
61 | else $_SESSION['MONKEY'][0] += 1;
|
---|
62 | if (!isset($_GET['nochange'])) @$_SESSION['AVAR'] += 1;
|
---|
63 |
|
---|
64 |
|
---|
65 | ### START DISPLAY
|
---|
66 | print "<h3>PHP ".PHP_VERSION."</h3>";
|
---|
67 | print "<p><b>\$_SESSION['AVAR']={$_SESSION['AVAR']}</b></p>";
|
---|
68 |
|
---|
69 | print "<hr /> <b>Cookies</b>: ";
|
---|
70 | print_r($_COOKIE);
|
---|
71 |
|
---|
72 | var_dump($_SESSION['MONKEY']);
|
---|
73 |
|
---|
74 | ### RANDOMLY PERFORM Garbage Collection
|
---|
75 | ### In real-production environment, this is done for you
|
---|
76 | ### by php's session extension, which calls adodb_sess_gc()
|
---|
77 | ### automatically for you. See php.ini's
|
---|
78 | ### session.cookie_lifetime and session.gc_probability
|
---|
79 |
|
---|
80 | if (rand() % 5 == 0) {
|
---|
81 |
|
---|
82 | print "<hr /><p><b>Garbage Collection</b></p>";
|
---|
83 | adodb_sess_gc(10);
|
---|
84 |
|
---|
85 | if (rand() % 2 == 0) {
|
---|
86 | print "<p>Random session destroy</p>";
|
---|
87 | session_destroy();
|
---|
88 | }
|
---|
89 | }
|
---|
90 | ?> |
---|