cookies可以跨域了~单点登陆(a.com.cn与b.com.cn可以共享cookies)

简介:

如果您的a.com.cn站点需要与b.com.cn站点共享cookies,一般满足这种要求的系统是为了做单点登陆的,现在我来讲一下实现方法:

a.com.cn登陆后,写cookies,在b.com.cn里,登陆状态为已经登陆,即它们的cookies可以共享

在a.com.cn站里写cookies的同时,调用b.com.cn里的写cookies的方法,代码如下

<script type="text/javascript">
        function CategoryRedirect(id, url) {
            location.href = "/Help/CategoryRedirect?id="+id+"&url="+url;
        }
    </script>

controller代码文件:
        [HttpGet]
        /// <summary>
        /// 需要跨域读取,写COOKIES(跨域有问题)
        /// </summary>
        /// <param name="id"></param>
        /// <returns></returns>
        public ActionResult CategoryRedirect()
        {
            this.ControllerContext.HttpContext.Response.AddHeader("cache-control", "no-cache");
            VCommons.Http.CookieHelper.Remove("CategoryID");
            VCommons.Http.CookieHelper.Write("CategoryID", Request["id"]);
            ViewData["id"] = Request["id"];
            ViewData["url"] = Request["url"];
            return View();
        }

VIEW文件

   <script language="javascript">
        window.onload = function() {
            location.href = '<%=ViewData["url"] %>';
        }
    </script>
 
    <div>
        <iframe src='http://b.com.cn/setcookies.aspx?id=<%=ViewData["id"] %>' style="display:none"></iframe>
    </div>

这样每页a.com.cn写COOKIES时,都调用了一个b.com.cn的写COOKIES的方法,达到的效果就是在b.com.cn里可以读到这个cookies。

同理如果b.com.cn要写的cookies在a.com.cn里共享的话,再用相同的方法做一次就可以了

b.com.cn里的设置cookies代码如下:

setcookies.aspx

  public partial class setcookies : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            HttpContext.Current.Response.AddHeader("p3p", "CP=CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR");
            VCommons.Http.CookieHelper.Remove("CategoryID");
            HttpCookie cookie = new HttpCookie("CategoryID", Request["id"]);
            cookie.Domain = "c2cedu.com";
            HttpContext.Current.Response.AppendCookie(cookie);
 
        }
    }
 
目录
相关文章
|
8月前
|
前端开发
解决前端ajax跨域请求不携带cookie信息JSESSIONID的问题
解决前端ajax跨域请求不携带cookie信息JSESSIONID的问题
|
5月前
|
存储 JavaScript 前端开发
Cookie 反制策略详解:Cookie加解密原理、Cookie和Session机制、Cookie hook、acw_sc__v2、jsl Cookie调试、重定向Cookie
Cookie 反制策略详解:Cookie加解密原理、Cookie和Session机制、Cookie hook、acw_sc__v2、jsl Cookie调试、重定向Cookie
325 1
|
8月前
|
存储 移动开发 前端开发
HTTP请求中token、cookie、session有什么区别
HTTP请求中token、cookie、session有什么区别
295 0
|
存储 缓存 前端开发
【计算机网络】Cookie、Session和上传文件重点知识汇总
【计算机网络】Cookie、Session和上传文件重点知识汇总
157 0
|
存储 Java
cookie 生命周期和cookie有效路径超级详细讲解
cookie 生命周期和cookie有效路径超级详细讲解
203 0
|
数据采集 Web App开发 数据库
python爬虫中如何获取cookie和添加代理池
python爬虫中如何获取cookie和添加代理池
|
Web App开发 JavaScript iOS开发
vue跨域携带Cookies发起请求
vue跨域携带Cookies发起请求,解决safari seesion问题
240 0
68 cookie在登录中的作用
68 cookie在登录中的作用
105 0
68 cookie在登录中的作用
|
存储 安全 JavaScript
Cors跨域(二):实现跨域Cookie共享的三要素(上)
Cors跨域(二):实现跨域Cookie共享的三要素(上)
Cors跨域(二):实现跨域Cookie共享的三要素(上)