0

我正在运行 Android Honeycomb 3.2.1,但无法让浏览器停止接受 cookie。我有以下代码:

第一个.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>

第二个.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,我会被重定向并按预期收到一条显示“测试 cookie”的警报。

现在,如果我在禁用 cookie 的 Android 平板电脑上运行它,它总是会在警报中返回“test cookie”。我是否打开或关闭cookie都没关系。我尝试更改设置、删除 cookie 和缓存、重新启动浏览器,甚至重新启动平板电脑,结果都一样。

任何帮助表示赞赏。

4

2 回答 2

0

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

于 2012-02-13T17:26:37.270 回答
0

您可以尝试使用服务器端代码检查它。例如,如果您使用 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"; 
            }
%>

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

于 2012-04-19T17:20:57.137 回答