Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 490|回复: 0

解决getJSON跨域登录Session丢失的问题

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-7-12 16:10:24 | 显示全部楼层 |阅读模式

    最近在做项目中发现,我用下面的代码异步请求到login.ashx:

    var memberUrl = rooturl + 'member.ashx?r=' + Math.random() + '&jsoncallback=?';   //添加jsoncallback参数是为了解决跨域的问题
    //验证是否已经登录 
    $.getJSON(memberUrl, { type: "checklogin" }, function (data) {
        if (data.status == 1) {  //已经登录成功,显示用户信息
            $('#userinfo').html('欢迎您' + data.content + '  ' + successHtml);
        } else {  //登录失败
            $('#userinfo').html(waitHtml);
        }
    });

    第一次请求时登录成功,但当我刷新页面时,却又要再次登录,经过测试发现:在firefox浏览器下是正常的,但在IE下却每次需要再次登录,我打印出来sessionId,发现居然刷新后的sessionID已经改变了,需要查找资料终于找到解决办法:

    问题根源:
      IE6/IE7支持的P3P(Platform for Privacy Preferences Project (P3P) specification)协议默认阻止第三方无隐私安全声明的cookie,Firefox目前还不支持P3P安全特性,firefox中自然也不存 在此问题了。Mircosoft对此的具体描述可以参见 Privacy in Internet Explorer 6

    解决办法是在login.ashx中输出P3P的主机头声明: 给个连接 百度文库

    http://wenku.baidu.com/view/ea504514866fb84ae45c8d2c.html

    代码如下:

    public void ProcessRequest(HttpContext context)
    {
        string result = string.Empty;
        context.Response.ContentType = "application/Json";
    
        //业务处理,赋值result......
    
        //解决IE缓存问题
        context.Response.AddHeader("Cache-Control", "no-cache");
        context.Response.AddHeader("Pragma", "no-cache");
    
        //解决IE下SessionID丢失的问题
        context.Response.AddHeader("P3P", "CP=CAO PSA OUR"); //解决跨域问题
        string cb = context.Request["jsoncallback"];
        context.Response.Write(cb + "(" + result + ")");
    }

     

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-12-22 23:48 , Processed in 0.061777 second(s), 28 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表