Vypnuté cookies

Cookies jsou data v prohlížeči návštěvníka, která se při požadavku na stránku přenášejí na server, ten podle nich může uživatele identifikovat a například mu zobrazit, že je přihlášen.

Ačkoliv není v dnešní době příliš běžné, že by návštěvník neměl podporu / měl vypnuté cookies, pokud je aplikace vyžaduje, je dobré o tom informovat, když nebudou zapnuté.

Může se stát, že si je návštěvník omylem vypne a nepůjde se mu z pro něj neznámé příčiny například přihlásit. Hláškou o tom, že stránka cookies potřebuje, mu můžeme pomoci. Případně to ještě vylepšit návodem/postupem, jak toho ve svém prohlížeči dosáhne.

Detekce vypnutých cookies v JavaScriptu

Testovat zapnutí nebo vypnutí cookies je možné JavaScriptem přes navigator.cookieEnabled.

if (!navigator.cookieEnabled) {
  alert("Cookies jsou vypnuté");
}

Živá ukázka

Podle mých testů se Internet Explorer 11 při určitém zablokování cookies může stále tvářit, že jsou zapnuté – navigator.cookieEnabled vrací true.

Vysoká hodnota nastavení cookies

IE totiž umožňuje nastavení pravidel pro ukládání cookie na několik úrovní + vlastní nastavení, které potom blokují různé typy cookies. Zdá se, že pro cokoliv jiného než nejvyšší volbu „Blokovat všechny soubory cookie“ vrátí navigator.cookieEnabled hodnotu true, nezávisle na tom, jestli bude možné cookie nastavit nebo ne, což například na druhou nejvyšší úroveň („Vysoká“) nepůjde.

Stejně tak v případě vlastního nastavení.

Vlastní nastavení a blokování cookies

Nejspolehlivější možnost je proto cookie zkusit vytvořit a testovat, zda se to povedlo. Ideální je i použít stejnou path a expires jako se používají v aplikaci.

function zapnuteCookies() {
  // vytvoříme testovací cookie
  document.cookie = "testovaci-cookie";
  return (document.cookie.indexOf("testovaci-cookie") > 0);
}

Živá ukázka

Možná by se nabízelo na začátku testovat, jestli už nějaká cookie v prohlížeči není.

if (document.cookie.length > 0) {
  return true;
}

Bohužel to opět nebude spolehlivé, neboť může nastat případ, kdy nějaké cookies pro stránku existují, ale přidávání nových je blokováno. Můžeme ale testovat přítomnost skutečné cookie potřebné k identifikaci a v takovém případě už zjišťování pomocí vytvoření testovací cookie neprovádět.

Detekce zapnutých cookie na straně serveru

Na straně serveru je jediná možnost:

  1. vytvořit cookie,
  2. přesměrovat (klidně na tu samou stránku),
  3. testovat, jestli cookie z kroku 1 existuje

To je pro samotnou detekci značně nepraktické, ale v případě, že uživatel například vyplní a odešle přihlašovací formulář, můžeme na stránce, kam bude v případě úspěšného přihlášení přesměrován, zjistit, že cookie, která by měla, neexistuje.

Zapnutí/vypnutí cookies v prohlížečích

Internet Explorer

Nástroje Alt + XMožnosti InternetuOsobní údajeVyberte nastavení pro zónu Internetu

Vypnutí cookies v IE

Chrome

Nastavení (chrome://settings/) → Zobrazit rozšířená nastavení...Ochrana soukromíNastavení obsahuSoubory cookie

Vypnutí cookies v Chrome

Firefox

MožnostiSoukromíHistoriePoužít pro historii vlastní nastavení.

Vypnutí cookies ve Firefoxu

Opera

NastaveníSoukromí & BezpečnostCookies

Vypnutí cookies v Opeře

Anonymní režim

Pro účely testování, jak bude webu fungovat, když na něj přijde člověk bez žádných cookies, mohou dobře posloužit anonymní režimy prohlížečů.

  • FirefoxCtrl + Shift + P
  • ChromeCtrl + Shift + N
  • OperaCtrl + Shift + N

Odkazy jinam

To je všechno. Líbil se vám článek a chcete se dozvědět, až vyjde další?

Sledujte:

 

Připomínky mi pište do komentářů ↓

Fixní postranní panel

Jak vytvořit fixovaný banner?

JavaScriptové řešení prvku, který při rolování zůstane stále viditelný.

Aktivování/deaktivování okna

Zachycení aktivování a deaktivování okna v JS

V JavaScriptu lze relativně snadno reagovat na aktivování nebo deaktivování okna/záložky/tabu.

Baterka v CSS a JavaScriptu

Vytvoření efektu baterky v CSS a JS

Jak jednoduše vytvořit na stránce efekt baterky? Tedy ztmavit web a prohlížet ho jakýmsi průzorem.

Test existence obrázku JavaScriptem

Ověření existence obrázku pomocí JS

Jak JavaScriptem ověřit existenci obrázku?

Načtení obrázku, až když je potřeba

Zpožděné načtení obrázku, až když je potřeba

Kromě potřeby nahrát obrázek dopředu (preload), aby byl v době použití 100% připravený, může být potřeba opačná – načíst jej, až v momentě, kdy je potřeba. Z důvodu nemrhání datovým přenosem.

Komentáře