|   昨天在手机端测试自己的项目遇到如下情况。 1.在手机上(苹果qq浏览器),登陆时存在session中的图片验证码结果,一直获取不到,考虑是cookies的问题。但是其他网站有貌似可以正常使用cookies,这是第一点矛盾。 2.在平板上(安卓qq浏览器),一直可以正常使用session,证明cookies传递没问题,证明代码没问题。 3.在手机上(苹果UC浏览器),浏览器刚下载的时候,第一次使用session成功,推出再次登陆,session又不能正常使用了,之后一直不正常。 4.PC端一直正常。   解决办法: 手动实现session机制 1.给Redis 增加key Val缓存内容。    (1)首先guid生成一个key(相当于sessionId的值)    (2)cookie名称叫做“vcode_sessionid”,并把第一步的key放到此键名的cookie中作为cookie的value,返回给浏览器。    (3)将第一步生成的key作为redis的key,redis缓存的值就是我们之前需要存到session的值  
             int num1 = rd.Next(0, 10); int num2 = rd.Next(0, 10); string vcodeKey = Guid.NewGuid().ToString(); string vcodeVal = (num1 + num2).ToString(); HttpCookie cookie = new HttpCookie("vcode_sessionid", vcodeKey); RedisHelper.SetKeyVal(vcodeKey, vcodeVal); RedisHelper.SetKeyExpressTime(vcodeKey, 300); HttpContext.Current.Response.SetCookie(cookie); 2. 读取redis缓存的结果     HttpCookie cookie = HttpContext.Current.Request.Cookies["vcode_sessionid"];     然后从cookie对象中取出cookie的值,这个值就是我们redis中的键,根据键取value.  
        string vcodeFromRedis = RedisHelper.GetValByKey(vcodeSessionId);
  这样一来session机制就实现了。其实这也是session原理,没什么复杂之处。   3.但是在某些手机qq浏览器中不回传cookie,这样依然不能在手机上正常使用我们自己实现的session机制。    最后的解决办法就是使用如下方法,获取执行cookie值,并跟在url后面回传给服务器。    js方法如下:     
 getCookie: function (cookieName) {
            var strCookie = document.cookie;
            var arrCookie = strCookie.split("; ");
            for (var i = 0; i < arrCookie.length; i++) {
                var arr = arrCookie.split("=");
                if (cookieName == arr[0]) {
                    return arr[1];
                }
            }
            return "";
        }   最后,我上百个ajax都要手动将cookie值跟在后面?有好的方法欢迎推荐。            |