Cette astuce montre comment savoir, en JS, si un visiteur est connecté à ses comptes sociaux. C’est tout bête, mais étonnamment ça marche à peu près partout.

Le principe

La plupart des sites ont une page de login :

https://exemple.com/login

Quand on accède à une autre page pour laquelle on doit être connecté, on est redirigé vers la page de login, dont l’URL mentionne alors l’URL ou le chemin qui avait été demandée :

https://exemple.com/login?redir=/page-demandée

L’astuce en JS, c’est de forger l’URL pour un site, en redirigeant sur une image. Typiquement, la favicon (présente sur tous les sites). Comme ça :

https://exemple.com/login?redir=/favicon.ico

On fait donc une requête AJAX et on regarde ce qui se passe :

  • si le fichier retourné est une image (l’icône), alors c’est qu’il y a une redirection, parce que l’utilisateur est connecté. Bingo.
  • autrement (si on ne reçoit pas une image), alors on est probablement sur la page de login (en HTML), car l’utilisateur n’est pas connecté.

En JS, ça veut dire que si on met l’URL forgée sur un img.src, alors :
– img.onload() fonctionne si l’utilisateur est connecté (img reçoit bien une image)
– img.error() est lancée si l’utilisation n’est pas connecté (img reçoit un document HTML).

On peut essayer, ça marche sur beaucoup de sites. Sur les liens suivants, si vous voyez l’icône, alors vous êtes connecté. Autrement, vous verrez la page de connexion du site.
Ce test peut très bien être effectué par n’importe quel site web sur tous les sites du monde. N’importe quel site web peut donc voir si vous êtes connecté ou non sur Twitter, Facebook, Amazon…

Essayer ici ?

ÉDIT : oui, le bouton "twitter" ne marche pas : ils semblent bloquer les requêtes comme ça. Tant mieux.
Si aucun compte n’est marqué "connecté" alors que vous l’êtes, souriez car c’est votre navigateur — ou une extension — qui vous protège.
Si le bouton ne fait rien du tout, c’est que vous bloquez les scripts sur mon site. C’est une bonne façon de se protéger aussi :).

Mais essayez dans un navigateur fraîchement installé, vous verrez, ça marche. Et c’est bien là le problème : la configuration par défaut des navigateurs laisse passer ce « problème ».

Vous pouvez tester ici, pour 5 sites :

    Le risque

    Ici je ne fais rien de méchant. Par ailleurs, aucune information n’est envoyée à mon site.

    Mais j’aurais pu.

    J’aurais également pu faire ça massivement, et voir quel pourcentage de mes visiteurs sont connectés à Twitter, ou à Facebook.

    Pire, si je vois que vous êtes connectés, alors il peut très bien lancer une requête sur la page de déconnexion et vous déconnecter :

    http://example.com/logout?

    Ce n’est pas dangereux, ça, mais c’est chiant.

    Ce qui peut être dangereux, c’est si j’accède à ce genre de page :

    • example.com/panier
    • example.com/paiement (pour ça, n’activez jamais le paiement en 1 clic sur les sites d’achat, je pense à Amazon par exemple).
    • example.com/mon_compte (là, ne mettez pas l’ID ou le nom d’utilisateur du compte dans l’URL de "mon compte" — même si une requête plus ciblée et plus complexe permettrait très bien d’extraire certaines informations)
    • example.com/changer_mon_mot_de_passe (pour ça, il faut toujours aussi exiger de taper l’ancien mdp pour en choisir un nouveau)
    • example.com/mot_de_passe_perdu (pour ça, validez en plusieurs étapes : demandez un code dans un l’email ou un truc en 2FA).
    • etc.

    Une solution ?

    Pour l’internaute

    Installez un bloqueur de requêtes, de scripts externes ou de publicité.

    µBlock Origin peut bloquer toutes les requêtes vers les sites tiers.
    L’extension kimetrak, elle, montre les requêtes qui sont faites.

    Sous Firefox, on peut aussi isoler chaque site en mettant à « true » la clé suivante dans about:config : about:config?filter=privacy.firstparty.isolate (attention, ça va vous déconnecter de tous les sites, mais après il suffit de se reco et c’est bon). Merci à Mart-e pour l’astuce !

    Pour les sites

    Ça me semble assez simple : quand on accède à la page de login, alors on demande systématiquement de se connecter.
    Peu importe si l’utilisateur est connecté ou pas, on exige une reconnexion. Seulement après la reconnexion on procède à la redirection.

    C’est ce que fait par exemple Amazon : cette astuce, même avec le bon lien (ici) ne marche pas, car Amazon demande le mot de passe qu’on soit connecté ou pas. C’est bien.
    Par contre, étrangement, c’est le cas pour Amazon.FR, mais pas pour Amazon.COM (lien de test), où l’astuce décrite ici fonctionne.

    Sources

    Ce « problème » n’est pas nouveau. Cet article, datant de 2012, en parle déjà : Detect if visitors are logged into Twitter, Facebook or Google+. Peu de sites semblent s’être bougés, pourtant.

    J’ai mentionné Amazon.FR ci-dessus. Flickr et Yahoo semblent également avoir corrigé le problème.
    La requête vers Twitter semble aussi poser problème quand elle est faite en AJAX. Pour les autres sites, je n’ai pas tout testé.

    Il existe aussi des scripts tout fait avec plein de sites dedans, pour voir si on est connecté : login-check.js.

    Sachez que tout ce qu’on navigateur affiche dans une page web, peut finir sur les serveurs de n’importe quel site qui possède un script dans cette page. Pensez-y.

    Enfin, pour voir une liste d’informations que votre navigateur sait de vous : https://lehollandaisvolant.net/tout/tools/browser/

    Sur Twitter, je vois quotidiennement des messages du style « j’ai trouvé ce téléphone, aidez-moi à retrouver son propriétaire ! », et tout le monde de partager le tweet en espérant que le propriétaire tombe dessus (supposant déjà qu’il soit sur sur le réseau social).

    Si le téléphone est déverrouillé (pas de code), on peut chercher dans les contacts ou trouver le compte social de son propriétaire (à faire à bon escient, évidemment).
    S’il est verrouillé, c’est plus compliqué.

    Sous Android, il y a pourtant une façon relativement simple : il suffit d’afficher un numéro de contact ou un e-mail sur l’écran de verrouillage.

    Sur Android 8.1, il faut aller dans les Paramètres et de rechercher « message sur écran verrouillé », ou d’aller dans Sécurité et localisation > Verrouillage de l’écran et d’aller sur les paramètres de cette option.

    paramètres d’android
    Ensuite, on peut choisir de mettre un message sur l’écran verrouillé :

    ajouter une message sur l’écran de verrouillage
    Et le résultat :

    capture d’écran du message qui s’affiche alors
    Voilà !

    C’est très rapide à mettre en place, mais pratique : comme ça, si vous perdez votre téléphone et que la personne qui le trouve essaye de vous retrouver, elle aura votre e-mail immédiatement.
    Vous pouvez aussi ajouter votre nom, compte handle Twitter ou le numéro d’un proche.

    N’y mettez évidemment pas le numéro de portable sur téléphone lui-même.

    Pour aller plus loin, Android 7+ permet d’ajouter des informations d’urgence qui pourront être disponibles à quiconque vous « trouverait » en situation de détresse (malaise, évanouis…). Ces informations concernent votre nom, votre groupe sanguin, vos allergies et des personnes à contacter. Ça peut être très pratique pour les secours. Je vous laisse lire ça ici : Android et iOS : Partager des informations d’urgence en cas… d’urgence !.

    Cet article traite seulement le sujet des pauvres et des riches, et que s’il n’y a plus de pauvres pour produire ce que les riches ont besoin, ben ça sera fini. Je résume l’article du Point. Ceci est vrai, mais il ne terminera pas notre civilisation. Seulement notre modèle social.

    Car pour notre civilisation, ceci ne suffit pas. L’article reste très superficiel. Pourtant, même si on regarde plus largement, la conclusion identique me semble inévitable. Peut-être pas « quelques décennies », mais quelques siècles, très certainement. C’est en tout cas mon avis.

    Premièrement, notre civilisation vit grâce au pétrole (pour le transport, la chimie, les médicaments, la bouffe…), aux ressources minières (habitations, technologie…), végétales (bouffe, bois, et surtout la production d’oxygène et la réduction du CO2) et animales (bouffe, pollinisation…).
    Les deux premières vont s’épuiser. Il viendra un moment où tout sera utilisé et où il faudra soit faire sans, soit avoir trouvé des alternatives durables et viables. On en est très loin. Par exemple, la voiture électrique c’est sympa pour se passer du pétrole, mais on a besoin de lithium pour les batteries, et ça n’est pas gagné. Aussi, s’il n’y a plus de pétrole, y a plus de plastique. On sera avancé.

    Les deux dernières… ben… c’est tout aussi perdu, à ce rythme. Poissons, abeilles, petits oiseaux… toutes les populations sont en chute libre. Quant aux plantes, le fait de ne toujours planter que la même chose, on favorise l’apparition des parasites : on va tout droit vers le scénario d’Interstellar, où un parasite à détruit tout le blé et où le monde survit grâce au maïs. C’est déjà arrivé, à l’échelle d’un pays. Et ça recommencera.

    Ensuite, deuxièmement, conséquence de la première : nos émissions polluantes sont trop importantes : déchets plastiques, déchets chimiques et surtout le CO2 tuent d’autres espèces animales et modifient le climat qui permet à TOUS de cohabiter (végétaux, animaux…).

    Troisièmement, une conséquences davantage politique : les gens deviennent vraiment trop cons. Antivax, anti-science, terre-plate, homéopathie… toutes ces conneries pullulent et font aussi des morts et contribuent à des épidémies.
    Un effet de bord, quand des gens parmi ces idiots arrivent au pouvoir, ben… la recherche scientifique stagne : la Nasa qui observe et alerte le monde sur l’état de santé de notre atmosphère est réduite au silence. Les labos de recherche sur les vaccins, contre le cancer, alzheimer, le sida, etc. ne sont plus financés assez (y compris en France)…

    Enfin, quatrièmement, quand des têtes de mules comme Trump ou Kim J. Un se disputent, ils mettent l’humanité en jeu en jouant avec leurs missiles.

    Bref, voilà juste quatre possibilités de fin de l’humanité. Et au rythme actuel, il n’est qu’une question de temps pour qu’un de ces trucs arrive :

    • épidémie mondiale (accentuée par le tourisme et les flux de population et rendue possible par les anti-vax et le non financement de la recherche)
    • dérèglement climatique total (la suppression du gulf-stream donnerait à l’Europe le climat Canadien, grosso-modo, et desertifirait toute l’Afrique et l’Amérique du Sud…).
    • guerre nucléaire (et avec les alliances dans tous les sens, ça va être mondial : CDN, USA, Chine, Russie…)
    • chaos social et guerres civiles par l’absence de ressources vitales (eau/bouffe, donc famine), ou techniques (pétrole, minerais, métaux…).

    Bonne journée :)