Publié le 02/10/2015
Auteur fobec
Réseaux sociaux
0 partages
0 tweets
5 plus
0 commentaires

Afficher l'avertissement sur l'utilisation des cookies

L'application de nouvelles règles quant à l'obtention du consentement des utilisateurs finaux de l'Union européenne impose une application qui affiche sur les sites internet un avertissement semblable à: "En poursuivant votre navigation sur ce site, vous acceptez l’utilisation de Cookies utilisés ...."
N'ayant pas envie d'utiliser les librairies que l'on trouve sur cookiechoices.org, je vous propose une solution en Javascript qui stocke l'autorisation de l'internaute sous forme d'un cookie.

Comment mettre mon site web en conformité ?

D'après la CNIL, "La loi impose désormais aux responsables de sites et aux fournisseurs de solutions d'informer les internautes et de recueillir leur consentement avant l'insertion de cookies ou autres traceurs."
Certains scripts demandent une autorisation pour chaque service présent sur le site internet ayant besoin de déposer un cookie dans le cache du navigateur internet.
Sur les gros sites web français, une simple banderole apparait à la première visite pour nous informer de l'utilisation de cookie.

Afficher le bandeau des cookies en Javascript

Toutes les fonctions permettant de gérer l'acceptation et le contrôle du cookie ont été rassemblées dans l’objet Javascript Cookie_Eu. Pour informer et recueillir l'autorisation des internautes, l'objet Cookie_Eu comprend les fonctions suivantes:
1. isSet(): recherche si un cookie signalant l'autorisation de l'internaute a déjà été déposé dans le cache du navigateur,
2. write(): écrire un nouveau cookie dans le cache du navigateur,
3. askForAgree(): afficher le bandeau d'information et de demande d'autorisation concernant le dépôt de cookie.

/**
 * Afficher l'avertissement sur l'utilisation des cookies
 * http://www.fobec.com/tuto/1172/afficher-avertissement-sur-utilisation-cookies.html
 * @author Fobec septembre 2015
 */
var Cookie_Eu = {
    //Ecrire un cookie contenant la date d'acceptation
    write: function(d) {
        var buf = '';
        if (d) {
            var date = new Date();
            date.setTime(date.getTime() + (d * 24 * 60 * 60 * 1000));
            buf = "cookie_policy_validation=agree; expires=" + date.toGMTString() + "; domain=" + document.domain + ";";
            document.cookie = buf;
 
            var div = document.getElementById('cookie_policy_msg');
            if (div) {
                div.parentNode.removeChild(div);
            }
        }
    },
    //Cherche le cookie contenant la date d'acceptation
    isSet: function()
    {
        var nameEQ = "cookie_policy_validation=";
        var ca = document.cookie.split(';');
        for (var i = 0; i < ca.length; i++) {
            var c = ca[i];
            while (c.charAt(0) == ' ')
                c = c.substring(1, c.length);
            if (c.indexOf(nameEQ) == 0) {
                var val = c.substring(nameEQ.length, c.length);
                if (val.trim() === 'agree') {
                    return true;
                }
            }
        }
        return false;
    },
    //Afficher le bandeau d'avertissement
    askForAgree: function() {
        if (this.isSet() == false) {
            var docbody = document.body || document.getElementsByTagName('body')[0];
 
            var div_cookie = document.createElement('div');
            div_cookie.id = 'cookie_policy_msg';
            div_cookie.className = 'cookie_policy_msg';
            var t = "<div>En poursuivant votre navigation sur ce site, vous acceptez l’utilisation de Cookies utilisés pour les publicités et pour les statistiques de visites,";
            t += '<a href="http://monsite.com/politique-cookie.html">en savoir plus</a><a href="javascript:Cookie_Eu.write(365);">OK</a></div>';
 
            div_cookie.innerHTML = t;
            docbody.insertBefore(div_cookie, docbody.childNodes[0]);
        }
    }
};
//Lancer le test d'existance du cookie
Cookie_Eu.askForAgree();

Intégrer le script sur son site web

Le code Javascript est prêt à l'emploi, seuls quelques modifications sont nécessaires pour l'adapter à votre site internet:

1. personnaliser la page "en savoir plus"
A ce que j'ai compris, l'internaute doit avoir accès à une page sur son site internet dans laquelle le webmaster explique pourquoi son site utilise des cookies, quels services nécessitent des traceurs et comment l'internaute peut s'en protéger.
Dans le script, vous avez à remplacer l'url http://monsite.com/politique-cookie.html par l'url de votre site web ou il est question de la politique de confidentialité des cookies.

2. style du bandeau
Pour personnaliser l’aspect du bandeau d’avertissement, veuillez modifier les styles ci-dessous:
/* cookie eu */
div.cookie_policy_msg{width:100%;background:#111;}
div.cookie_policy_msg>div{max-width:1200px;margin:0 auto;color:#999;padding:10px}
div.cookie_policy_msg>div>a:first-child{color:#fff;display:inline-block;margin-left:10px}
div.cookie_policy_msg>div>a:last-child{display:inline-block;margin-left:20px;height:28px;width:32px;color:#fff}

Pour déployer le script Cookie_Eu sur un site internet, je vous conseille de placer les ressources dans une librairie JS ou de copier/coller le script et la feuille de style dans chaque page du site.

Est-ce suffisant pour être en conformité avec les recommandations de la CNIL ?
En analysant les solutions mises en place sur les sites internet depuis un mois, les fonctions rendues par Cookie_Eu semblent bonnes pour l'obligation de recueillir leur consentement avant l'insertion de cookies.

Ajouter un commentaire

Les champs marqués d'un * sont obligatoires, les adresses emails se sont pas publiées.

A lire aussi

Réseaux sociaux
Présentation de l'article
Catégorie
tuto - webmaster
Mise a jour
02/10/2015
Visualisation
vu 2582 fois
Public
Internaute
Auteur de la publication
Fobec
Admin
Auteur de 261 articles
|BIO_PSEUDO|
Commentaires récents

Publié par Candide dans logiciel

Cree avec Lazarus.
un help est fourni dans le ZIP

Publié par Patrice dans tuto

Bonjour

je cherche a activer mod_headers chez 1and1, impossible de mettre mes jpg en cache, auriez vous une piste ? merci !

Publié par fobec dans tuto

Effectivement, l'interface du site a evolue. Le lien de telechargement est ici: http://www.rainforestnet.com/download/sample.zip

Publié par Patrice dans CMS

Concernant la commande ShellExecute :

Si vous voulez lancer un programme dont le nom est contenu dans une propriété text,
caption, items bref d\'un string ... n'oubliez pas de transfor...

Publié par tactictoe dans CMS

Erreur ligne 8 et 26:
Lire : Reg.OpenKey('\Software\Microsoft\Internet Explorer\Main\', false);
et non pas Reg.OpenKey('SoftwareMicrosoftInternet ExplorerMain', false);