【问题标题】:Saving user decisions in cookies [closed]在 cookie 中保存用户决策 [关闭]
【发布时间】:2021-04-12 02:01:32
【问题描述】:

我的网站上有一个弹出窗口,通知您有关 cookie 的信息。可以查看供应商列表并接受每个供应商。弹出窗口有两个按钮:接受和拒绝。如何将用户的决定(包括接受的供应商)保存(接受或拒绝)为一个 cookie? Vendors 数据取自 json。

【问题讨论】:

    标签: javascript json cookies


    【解决方案1】:

    如果您正在开发一个使用 cookie 的网站,您应该设置 2 个功能,一个用于设置 cookie,另一个用于按名称​​获取它们

    function getCookie(cname) {
      var name = cname + "=";
      var decodedCookie = decodeURIComponent(document.cookie);
      var ca = decodedCookie.split(';');
      for(var i = 0; i <ca.length; i++) {
        var c = ca[i];
        while (c.charAt(0) == ' ') {
          c = c.substring(1);
        }
        if (c.indexOf(name) == 0) {
          return c.substring(name.length, c.length);
        }
      }
      return "";
    }
    
    function setCookie(cname, cvalue, exdays) {
      var d = new Date();
      d.setTime(d.getTime() + (exdays*24*60*60*1000));
      var expires = "expires="+ d.toUTCString();
      document.cookie = cname + "=" + cvalue + ";" + expires + ";path=/";
    }
    

    现在您可以设置一个 cookie,如“首选项”或任何其他:

    let cookiePref = "accepted"; //Or bool, or int
    let daysToExists = 31; //how many days cookie will be valid
    setCookie('cookiePreference', cookiePref, daysToExists);
    

    Cookie 将被命名为“cookiePreference”,值为字符串“accepted”,有效期为 31 天

    然后,您可以检索它:

    pref = getCookie('cookiePreference');
    

    如果是字符串,可以检查cookie是否存在

    pref = getCookie('cookiePreference');
    if (pref.length > 0) {
       // Cookie is setted
    }
    

    这样,你也可以在javascript中设置cookie并在php中取回(作为不安全值),反之亦然(作为安全值)

    【讨论】:

    • 非常感谢您!但是,我如何检索用户关于他接受了哪些供应商的决定?
    • 您可以为每个供应商设置一个cookie。即:setCookie('bmw', false, 31); setCookie('audi', true, 31); setCookie('ffiat', false, 31); setCookie('法拉利', true, 31);循环进入供应商的方式取决于它是数组还是对象。可以用for、foreach等实现
    • 如果只想要一个cookie,可以将逻辑更改为:setCookie("preferences", "audi:false, fiat:true, ferrari:false", 31)。当你得到它时,你就拆分了数组。
    猜你喜欢
    • 2013-08-27
    • 1970-01-01
    • 2018-11-08
    • 2014-11-26
    • 2011-04-27
    • 1970-01-01
    • 2011-11-12
    • 2015-10-18
    • 1970-01-01
    相关资源
    最近更新 更多