素材牛VIP会员
如何实现多个域名 共享session
 qq***qq  分类:PHP代码  人气:1558  回帖:12  发布于6年前 收藏

场景

项目公用一套代码,现在的需求是把其中的几个大功能分别用指定的二级域名进行访问:

例如:

项目代码都在 website 这个目录下,且是单一入口文件架构方式。

现在的服务器配置是 (nginx)的配置方式是

ServerName www.project.com, a.project.com, b.project.com

Root 都指向 website 目录

现在是可以实现基本需求,几个功能模块都可以以二级域名的形式进行访问。

问题来了

怎样实现session的共享呢?

搜了下,网上的其中的一个解决方案是将session_id 放到cookie 里面, 然后在session_start 之前取出cookie中的session_id,手动设置session_id。

还有说,使用 session_get_cookie_params 方法,设置 domain 为 .project.com

这种方法尝试了下,发现时可以的,但是问题是对应的 管理后台的 management.project.com 的登录出现了问题,即使正确登录也无法登录成功!

那么

像这种的架构方式一般都是怎样实现的呢?

更新

现在采用的session存储方式是使用数据库,

 标签:nginxphp

讨论这个帖子(12)垃圾回帖将一律封号处理……

Lv6 码匠
ga***23 产品经理 6年前#1

你好,我的项目中也从在同样的场景,目前我也在考虑解决方案,问题的核心不是存储,而是如何进行跨域共享的问题。我在考虑使用JSONP,之后会进行技术验证,希望能共同讨论。

Lv4 码徒
醉***o JAVA开发工程师 6年前#2

http://fuweiyi.com/others/2013/03/08/a-domain-pan-resolve-rewrite-cross-session.html
是根据这个实现吗?

JSESSIONID FC33C9C32AB81A8FDD5D815A77FD442E demo.dadaping.com
JSESSIONID FC33C9C32AB81A8FDD5D815A77FD442E test.dadaping.com
JSESSIONID FC33C9C32AB81A8FDD5D815A77FD442E maps.dadaping.com

要实现上面的方式,但是在服务器端,如果遇到域名不同,jsession的值就重新生成了。

Lv3 码奴
34***86 JAVA开发工程师 6年前#3

感觉最好还是持久化共享,或者你还可以像CI那样,把session用双向加密算写到cookie里面,不过,如果密钥泄露了就麻烦了!哈哈哈....

Lv4 码徒
pe***ei 移动开发工程师 6年前#4

url queryString

Lv5 码农
走***鹿 移动开发工程师 6年前#5

cookie有domain属性,只给要共享的cookie设置就可以了

Lv6 码匠
hx***lf JAVA开发工程师 6年前#6

cookie domain设置为*.project.com

Lv4 码徒
风***j 技术总监 6年前#7

相同顶级域名的话是可以通过设置实现的,如果顶级域名也不相同的话,很遗憾无法实现。但你可以通过auth实现,做一个接口接收传递过来的参数进行验证,通过后为用户生成session就像用户通过正常的登陆实现一样

Lv6 码匠
飞***z 站长 6年前#8

持久化session

Lv2 入门
jh***23 Web前端工程师 6年前#9

你可以再写一个app,用来存储不同app的共享数据,然后通过api来相互调用,将用户的特征传入api,应该很容易实现针对统一回话的键值对管理吧?就是让这个app实现api:(session_id,key)返回value。

Lv5 码农
so***70 移动开发工程师 6年前#10

cookie,db,memcache,redis以及任何能够存储的地方

上一页12下一页
 文明上网,理性发言!   😉 阿里云幸运券,戳我领取