且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

如何在php app和Java EE app之间共享会话?

更新时间:2023-12-04 11:52:28

使用 session_set_save_handler()

更新
效率明智的,它将是非常小的,与读取文本文件到查询数据库(可能使用现有连接)的区别。

UPDATE Efficiency wise it would be very mininal, the difference from reading a text file to querying a database (presumably using an existing connection).

一些示例代码(简化了我使用的内容) )

Some example code (simplified from what I use)

class Session {
    public function __construct() {
        session_start();       
        $this->clean();        
    }
    public function __destruct() {
        session_write_close();
    }
    public function open() {
        return TRUE;
    }    
    public function close() {
        return TRUE;
    }    
    public function read($id) {
        global $Database;
        if ($Database->select('session_data FROM sessions WHERE session_id="%s"', $id)) {
            list($data) = $Database->fetch(MYSQL_NUM);
            return $data;
        } else {
            return '';
        }
    }    
    public function write($id, $data) {
        global $Database;
        return $Database->replace('sessions SET session_id="%s", session_data="%s", session_updated=%d', array($id, $data, time()));
    }    
    public function destroy($id) {
        global $Database;
        $_SESSION = array();
        return $db->delete('sessions WHERE session_id="%s"', $id);
    }    
    public function clean($expire = 600) {
        global $Database;
        $Database->delete('FROM sessions WHERE session_updated<%d', $time - $expire);
        return TRUE;
    }
}
// Declare the functions to use:
session_set_save_handler(array('Session', 'open'), array('Session', 'close'), array('Session', 'read'), array('Session', 'write'), array('Session', 'destroy'), array('Session', 'clean'));
$Session = new Session;

您可以使用 $ _ SESSION ['读取/写入会话数据名称'] =数据; 采用通常的技术。

The you can read/write to the session data using $_SESSION['name'] = data; in the usual technique.