Android浏览器不尊重cookies被禁用

Android browser not respecting cookies disabled

本文关键字:cookies 浏览器 Android      更新时间:2023-09-26

我正在运行Android Honeycomb 3.2.1,我遇到了让浏览器停止接受cookie的问题。我有以下代码:

first.html:

<!DOCTYPE html>
<html>
    <head>
        <title></title>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <script type="text/javascript" src="cookie.js"></script>
        <script type="text/javascript">
            setCookie('testing','test cookie',365);
            window.location.href = 'second.html';
        </script>
    </head>
    <body>
    </body>
</html>

second.html:

<!DOCTYPE html>
<html>
    <head>
        <title></title>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <script type="text/javascript" src="cookie.js"></script>
        <script type="text/javascript">
            var temp = getCookie('testing');
            alert(temp);
        </script>
    </head>
    <body>
    </body>
</html>

cookie.js:

function setCookie(c_name,value,exdays)
{
    var exdate=new Date();
    exdate.setDate(exdate.getDate() + exdays);
    var c_value=escape(value) + ((exdays==null) ? "" : ";     expires="+exdate.toUTCString());
    document.cookie=c_name + "=" + c_value;
}
function getCookie(c_name)
{
    var i,x,y,ARRcookies=document.cookie.split(";");
    for (i=0;i<ARRcookies.length;i++)
    {
        x=ARRcookies[i].substr(0,ARRcookies[i].indexOf("="));
        y=ARRcookies[i].substr(ARRcookies[i].indexOf("=")+1);
        x=x.replace(/^'s+|'s+$/g,"");
        if (x==c_name)
        {
            return unescape(y);
        }
    }
    return null;
}

现在,如果我关闭cookie并在任何桌面浏览器上访问first.html,我将获得重定向并得到一个警告,如预期的那样显示为null。

如果我打开cookie并在任何桌面浏览器上访问first.html,我将获得重定向并得到一个警告,如预期的那样说"test cookie"。

现在,如果我在禁用cookie的Android平板电脑上运行此程序,它总是在警报中返回"test cookie"。不管我有没有饼干都没关系。我试过更改设置,删除cookie和缓存,重新启动浏览器,甚至重新启动平板电脑,所有的结果都是一样的。

我遇到了同样的问题-我们最终在服务器上检查cookie并返回HTTP错误代码,如果cookie未设置

您可以尝试用服务器端代码检查它。例如,如果您正在使用JSP。你可以在onLoad或$(document).ready(){}:

中执行此操作
<%
            String cookieAllowed = "false";
            Cookie cookie = new Cookie ("username","value");
            cookie.setMaxAge(365 * 24 * 60 * 60);
            response.addCookie(cookie);
            String cookieName = "username";
            Cookie cookies [] = request.getCookies ();
            Cookie myCookie = null;
            if (cookies != null)
            {
                //If true then cookies are not null
                cookieAllowed = "true";
            }
            %>
            if(! <%=cookieAllowed%>)
            {
                window.location = "/static/nocookies.html"; 
            }
%>

我相信其他服务器端脚本也应该工作。