定制 mrclay/userland-session 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

mrclay/userland-session

最新稳定版本:3.0.0

Composer 安装命令:

composer require mrclay/userland-session

包简介

Provides a an HTTP cookie-based session in plain PHP, allowing concurrent use with existing native sessions.

README 文档

README

https://travis-ci.org/mrclay/UserlandSession.png?branch=master

UserlandSession is an HTTP cookie-based session components implemented in plain PHP, allowing it to be used concurrently with--and completely independent of--existing native sessions. This makes it handy for bridging session state across multiple PHP apps with incompatible sessions.

  • Loosely-coupled components that introduce no global state (except headers)
  • Uses PHP's SessionHandlerInterface, so you can re-use existing 3rd-party handlers
  • Session data is only accessible via the object instead of a global
// create a files-based session, directory sniffed from session.save_path
$session = \UserlandSession\SessionBuilder::instance()->build();
$session->start();

// use public $session->data array property...
$session->data['foo'] = 'bar';

// ...or use set/get()
$session->set('foo', 'bar');

$session->writeClose(); // ...or let destructor do this

Handlers

The save handler interface is PHP's SessionHandlerInterface, and handlers FileHandler and PdoHandler are included.

Feel free to use your own save handler class, or use these as handlers for native sessions!

Creating a Session

Easy ways to get a files-based session:

// from script (save path sniffed from session.save_path)
$session = (require 'path/to/UserlandSession/scripts/get_file_session.php');

// using builder (here we set the session name to MYSESS)
$session = SessionBuilder::instance()
    ->setSavePath('/tmp')
    ->setName('MYSESS')
    ->build();

File Storage Options

// turn off file locking
$session = SessionBuilder::instance()
    ->setFileLocking(false)
    ->build();

Using PDO

// pre-existing PDO connection
$session = SessionBuilder::instance()
    ->setPdo($myConnection)
    ->setTable('userland_sessions')
    ->build();

// or if you want it to connect for you when needed:
$session = SessionBuilder::instance()
    ->setDbCredentials(array(
        'dsn' => 'mysql:host=localhost;dbname=ulsess;charset=UTF8',
        'username' => 'fred',
        'password' => 'password1',
    ))
    ->setTable('userland_sessions')
    ->build();

Extras

You can check for data matching the client's cookie without starting the session:

if ($session->sessionLikelyExists()) {
    $session->start();
    // use session
} else {
    // don't start if we don't need to
}

Simpler cookie removal:

$session->removeCookie();

// or specify true when destroying the session
$session->destroy(true);

License

MIT. See LICENSE.

统计信息

  • 总下载量: 58.17k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 6
  • 点击次数: 1
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 5
  • Watchers: 2
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2014-03-08