mrclay/userland-session 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱: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.13k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 6
  • 点击次数: 3
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固