更新一下:php
个人一个项目用的TP2.0开发的,如今要给这项目加一些功能,可是新功能我不想用TP开发了,laravel
想用Laravel,Laravel放在旧项目的一个子目录里,可是为何没法读取TP的SESSION。git
我这样说 会不会更明白一些。github
不要告诉存数据库什么的,存不存数据库Laravel的Session都是二次处理过的。。。数据库
有没有人遇到过?json
两个项目在同一台服务器,同一个域名,不存在跨域,跨服务器问题,segmentfault
Laravel好像对session作了特殊处理。跨域
连var_dump($_SESSION)都会出现错误提示。服务器
config/session.php设置files和cookiecookie
只会把其余项目的session给清除掉。。。
@kankana 在评论中回答了这个问题,
我这边总结一下,也许之后有人会须要,
其实Laravel的session并非用PHP自带的session管理器。而是完彻底全本身实现了一个。
注意是完彻底全本身实现的,并非传统意义上用session_set_save_handler
自定义的session处理器。
因此解决 和另外一个ThinkPHP项目的session共用 的问题就很简单了~
在Laravel中启动PHP自带的session就行了,也就是session_start。
这是他们的代码注释 "Note that the Laravel sessions do not make use of PHP "native" sessions in any way since they are crappy."
请记住Laravel在任何地方都没有用到PHP“原生”的session,由于它很蹩脚。
好吧,我如今只要启动蹩脚的session就行了。
by kankana
以上是如何从laravel访问其余程序的session.
如下,则是如何从外部访问laravel的session (file).
当laravel的session driver设置为file, 这些session files都是以json形式存放在app/storage/sessions里面.
关键是,如何找到对应的session文件?
这个文件名是以加密形式存储在cookie的laravel_session里.
如何解密laravel_session获取这个文件名?
1, 首先安装这个库:
https://github.com/illuminate/encryption
2, 获取加密key
位于app/config/app.php 的 key
3,
$encrypter = new Illuminate\Encryption\Encrypter($key); $session_filename = $encrypter->decrypt($_COOKIE['laravel_session']);
大体如此.
ankana补充的已经差很少了, 我再多说下
内部解析 session 到明文:
1: 拿到 session_id
use Illuminate\Encryption\Encrypter; $encrypter = new Encrypter(Config::get('app.key')); $session_id = $encrypter->decrypt($_COOKIE[Config::get('session.cookie')]);
2: 读取 session 内容
$handler = Session::getHandler(); $session = $handler->read($session_id); $session = unserialize($session);