项目a:部署在192.168.0.1上
项目b:部署在192.168.0.2上现在要做个项目c,要实现的功能是登陆功能:a、b项目都要通过c登陆以后才能访问。登陆状态我准备保存到Cookie中,但是a和b在两台不同的服务器上,要怎么传递这个会话(Cookie)呢?
求思路,谢谢!

解决方案 »

  1.   

    模拟Cookie我就想到了CURL,但是还是不知道该怎么做。。
      

  2.   

    session写在表中或在内存缓存中 只在一个地方维护用户的状态
      

  3.   

    嗯,但是SessionID不是保存在Cookie中吗,如果登陆用户登陆成功以后,当他选择去另一台服务器的时候,如何把SessionID传过去呢?这不是跨域了吗?
      

  4.   

    如果是一二级域名 设置cookie的作用域为根域名
    不同的域名可将sessionid跟在url后面 再进行验证
    session写入表的时候 取头信息加IP进行加密 在直接输域名的情况下取这一段信息进行验证
    类似这样 sprintf('%08x', crc32(!empty($_SERVER['HTTP_USER_AGENT']) ? $_SERVER['HTTP_USER_AGENT'] . ROOT_PATH . $ip . $session_id : ROOT_PATH . $ip . $session_id));版主说不定有更好的解决方法
      

  5.   

    你可以去研究一下单点登录 
    我们的设想是将 PHP 的 Session 数据集中存储,这样对于不同服务器中运行的 PHP 来说,只有一个共有的 Session 数据库,那么用户在服务器 A 登录所生成的 Session 数据在服务器 B、C、D 等服务器都可以共享,就可以免除多次登录。但由于 PHP 的 Session 是需要 Cookie 的,而 Cookie 又是与域名相关的,所以采用这个方案的各个服务器需要有相同的域名(至少是相同的二级域名),比如:
    1、所有服务器的域名都是 www.whybsd.com,这个东东 DNS 轮询就可以实现;这个时候,在 PHP 中将 Cookie 域名设置为 www.whybsd.com 即可;
    2、所有服务器的域名都是以 .whybsd.com 结尾的三级域名,比如 a.whybsd.com,b.whybsd.com 等等,这个时候,在 PHP 中将 Cookie 域名设置为 .whybsd.com 就可以共享 Cookie 了。
      

  6.   

    嗯。。我先研究一下将Session存入表的操作。
      

  7.   

    Cookie是客户端的,session菜式服务器端的吧。你在另一台服务器上验证登陆,然后用php socket
      

  8.   

    本帖最后由 PhpNewnew 于 2012-08-06 16:06:44 编辑
      

  9.   

    搞一台独立memcache服务器,存储用户状态,两台服务器共享memcache数据
      

  10.   


    那也得以SESSIONID当KEY吧?
    如果跨域(不是同一级域名的情况下),还是需要用SID放在URL后边吧?
      

  11.   

    http://www.phpweblog.net/linxiaobo/archive/2009/04/15/6419.html
    这是常见的一种,地址我随便搜的,P3P 后面的一串记不下来,你可以看看。稍微看了一下,只要P3P设置正确,肯定可以。这种方案个人解决过跨域cookie问题。需要注意两个域名对应的地方。。不加P3P,IE,Safari【不确定】通不过的,这大概叫第三方cookie?
    另外还可以是借助iframe【这可没有跨域的概念】,不同的域父子框架之间传值,可通过url锚点……思路自己扩展咯
      

  12.   

    session 放到缓存里共享
    cookie  做到域共享
      

  13.   

    涉及两个问题
    1. Session共享
    2. SessionID的传递1的解决方法就是重写SessionHandler,把session数据集中保存在同一个数据库里。
    http://il.php.net/manual/en/class.sessionhandler.php2的解决方法是放到URL里作为参数传递