dongtingxiao4697 2018-05-28 11:49
浏览 170

如何在beego框架的子域之间共享cookie

We intend to set cookie for *.1234tv.com in login.1234tv.com. However it does not work.

enter image description here

I have configure the container as below:

beego.InsertFilter("*", beego.BeforeRouter, cors.Allow(&cors.Options{
    AllowAllOrigins: true,
    AllowOrigins:     []string{"http://*.1234tv.com"},
    AllowMethods:    []string{"GET", "POST", "PUT", "DELETE","PATCH","HEAD", "OPTIONS"},
    AllowHeaders:    []string{"Origin", "Authorization", "Access-Control-Allow-Origin", "Content-Type"},
    ExposeHeaders:   []string{"Content-Length", "Access-Control-Allow-Origin"},
    AllowCredentials: true,
}))

and set cookie in controller like this:

this.Ctx.SetCookie("UNION_TOKEN", utoken, 3600*24*7,"/", ".1234tv.com",false,false)
  • 写回答

2条回答 默认 最新

  • drnpwmq4536 2018-05-29 03:33
    关注

    The cause is set-cookie by response does not work. 1.Since it is an across sites Ajax request, .withCredentials() can active the ability of set cookie by response.

    $.ajax( {
       /* Setup the call */
       xhrFields: {
         withCredentials: true
       }
     });
    

    2.On the side of response server, "Access-Control-Allow-Credentials" must be "true" and "Access-Control-Allow-Origin" must not be "*" and "Access-Control-Allow-Origin" could be "http://*.domain.com".

    评论

报告相同问题?

悬赏问题

  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看