Certificat AgentReady.md vérifié
Émis le sig: 0f23ffae8b965ec7 Vérifier →

URL analysée

https://karaoke-service.com/

Analyser une autre URL

Score AI-Ready

63 / C

Passable

sur 100

Économie de tokens

Tokens HTML 8406
Tokens Markdown 520
Économie 94%

Détail du score

HTML sémantique 45/100
Efficacité du contenu 78/100
Visibilité IA 55/100
Données structurées 45/100
Accessibilité 93/100

Protocoles émergents

0 sur 3 détectés

Endpoints well-known recherchés par les agents IA. Détecté signifie qu’un agent peut découvrir et se connecter automatiquement à votre service.

  • OAuth Discovery RFC 8414
    /.well-known/oauth-authorization-server
  • MCP Server Card Anthropic
    /.well-known/mcp.json
  • A2A Agent Card Google
    /.well-known/agent.json

Votre page n’utilise pas d’éléments <article> ou <main>. Ces conteneurs sémantiques aident les AI agents à identifier la zone de contenu principal et à ignorer la navigation, les barres latérales et les pieds de page.

Comment implémenter

Ajoutez un élément <main> autour du contenu principal de votre page, et utilisez <article> pour les blocs de contenu autonomes comme les billets de blog ou les descriptions de produits.

Votre site ne supporte pas Markdown for Agents. Ce standard Cloudflare permet aux agents IA de demander du contenu en format markdown, réduisant l'utilisation de tokens de ~80%.

Comment implémenter

Implémentez un ou plusieurs : (1) Répondre à Accept: text/markdown avec du contenu markdown. (2) Servir des URLs .md (ex : /page.md). (3) Ajouter des balises <link rel="alternate" type="text/markdown">. (4) Ajouter des en-têtes HTTP Link pour la découverte markdown.

{\n res.setHeader('Vary', 'Accept');\n res.setHeader('Link', '; rel=\"alternate\"; type=\"text/markdown\"');\n if ((req.headers.accept || '').includes('text/markdown')) {\n res.type('text/markdown; charset=utf-8');\n return res.send(renderMarkdown('page'));\n }\n res.render('page');\n});"},{"id":"fastify","label":"Fastify","language":"javascript","filename":"server.js","code":"// Mechanisms 1 + 4: content negotiation + Link header\nfastify.get('/page', async (req, reply) => {\n reply.header('Vary', 'Accept');\n reply.header('Link', '; rel=\"alternate\"; type=\"text/markdown\"');\n if ((req.headers.accept || '').includes('text/markdown')) {\n return reply.type('text/markdown; charset=utf-8').send(renderMarkdown('page'));\n }\n return reply.view('/page.ejs');\n});"},{"id":"nextjs","label":"Next.js","language":"typescript","filename":"app/page/route.ts","code":"// Next.js App Router — Route Handler returning Markdown\nimport { NextRequest } from 'next/server';\nimport { renderMarkdown } from '@/lib/md';\nexport async function GET(req: NextRequest) {\n const accept = req.headers.get('accept') || '';\n if (accept.includes('text/markdown')) {\n return new Response(await renderMarkdown('page'), {\n headers: {\n 'Content-Type': 'text/markdown; charset=utf-8',\n 'Vary': 'Accept',\n },\n });\n }\n // Fall through to the page component\n return new Response(null, { status: 404 });\n}"},{"id":"wordpress","label":"WordPress","language":"php","filename":"functions.php","code":"post_content));\n exit;\n});"},{"id":"static","label":"Hugo / Jekyll / Astro","language":"txt","filename":"static/page.md","code":"# Mechanism 2: serve .md alongside .html\n# Hugo: place page.md in /static/ — built unchanged\n# Jekyll: drop page.md in /assets/ — copied as-is\n# Astro: src/pages/page.md.ts that exports a GET returning markdown\n\n# Then advertise with mechanism 3 in :\n# "}] }'>

Aucune directive Content-Signal trouvée. Celles-ci indiquent aux agents IA comment ils peuvent utiliser votre contenu (indexation, entrée IA, données d'entraînement). L'emplacement recommandé est robots.txt.

Comment implémenter

Ajoutez Content-Signal à votre robots.txt : User-agent: *\nContent-Signal: search=yes, ai-input=yes, ai-train=no. Vous pouvez aussi l'ajouter comme en-tête HTTP sur les réponses markdown.

{\n res.setHeader('Content-Signal', 'search=yes, ai-input=yes, ai-train=no');\n next();\n});\n\n// Fastify\nfastify.addHook('onSend', (request, reply, payload, done) => {\n reply.header('Content-Signal', 'search=yes, ai-input=yes, ai-train=no');\n done();\n});"}] }'>

Votre page repose fortement sur les éléments <div>. Les éléments sémantiques comme <section>, <nav>, <header>, <footer> et <aside> fournissent une structure significative pour les AI agents.

Comment implémenter

Remplacez les conteneurs <div> génériques par les éléments sémantiques appropriés. Utilisez <section> pour les groupes thématiques, <nav> pour la navigation, <header>/<footer> pour les en-têtes et pieds de page ou de section.

Certaines images manquent de texte alternatif descriptif. De bons textes alt aident les AI agents à comprendre le contenu et le contexte des images.

Comment implémenter

Ajoutez des attributs alt descriptifs à toutes les images. Décrivez ce que l’image montre, pas juste « image » ou « photo ». Pour les images décoratives, utilisez alt="" (vide).

Votre page a un faible ratio de contenu réel par rapport au HTML total. Une grande partie du poids de la page est du balisage, des scripts ou des styles plutôt que du contenu.

Comment implémenter

Déplacez le CSS vers des feuilles de style externes, supprimez les styles en ligne, minimisez le JavaScript et assurez-vous que le HTML se concentre sur la structure du contenu.

Aucune donnée structurée Schema.org trouvée. JSON-LD aide les AI agents à extraire des informations factuelles et structurées de vos pages.

Comment implémenter

Ajoutez un bloc <script type="application/ld+json"> avec du balisage Schema.org. Utilisez les types appropriés : Article pour les billets de blog, Product pour les produits, Organization pour la page de votre entreprise.

Aucune URL canonique trouvée. Cela aide les AI agents à identifier la version préférée d’une page et à éviter le contenu dupliqué.

Comment implémenter

Ajoutez une balise <link rel="canonical" href="..."> pointant vers l’URL canonique de la page.

Aucun attribut lang sur l’élément <html>. Cela indique aux AI agents la langue principale de la page.

Comment implémenter

Ajoutez lang="fr" (ou votre langue) à la balise <html> : <html lang="fr">.

Tokens Markdown: 520
![](https://karaoke-service.com/index/i/logo.png)

������������������ �� ����� ��� � ������� ���������� �����:

[![](https://karaoke-service.com/index/i/logo_w.png)](https://karaoke-service.com/)

1\. ��� ������ �� ������ �����, ������� �� 5-�� ������� �����. ��������: "00010".

2\. ��� ������ "�� �����������" � "�� �������� �����", ���������� �������� ��� ������, ���� ����� ��������� � �����.

3\. ��� �� ������� ����������� ��� ������ �� ����������� ���������.

�����

+

�� �������� ����� �� �����������

����������� � ����������� KARAOKE PRO

���������������. ������� ������ ������ ������� �����.

������������������ �� ����� ��� � ������� ���������� �����:

![](https://karaoke-service.com/index/i/man.png)![](https://karaoke-service.com/index/i/woman.png)

��������, ���, ���������.������ ��� ������.

�������� ������� �����

������� ������� ��� ����.���� ������� ������.

����� ����������

���������� ����������

![](https://karaoke-service.com/index/i/comp1.png)![](https://karaoke-service.com/index/i/comp2.png)

�������� ������� ��� �������-�����.������ ����� � ������ ���������.

������������ ������� PRO.

-   ��������� ������� ������
-   ����� ����������� ����������
-   ������� ����������
-   ������ ���������
-   ����� �������� ��������
-   ��������� ����-�����
-   �������� ���������� PRO
-   ����������� ���������

������� � ������ �� Karaoke PRO.���������� � ��������� ��������� ������.

![](https://karaoke-service.com/index/i/boy.png)![](https://karaoke-service.com/index/i/girl.png)

����� 17000 �������� �������������.�����, �����������, ���������� ����������� ������ � **KARAOKE PRO**

������� � �������
���� ������� ����� ������, ����������� ��������� | Karaoke PRO - ��� ��������� � ��������������

|  |
|  |

![](https://karaoke-service.com/index/i/logo.png)

������������������ �� ����� ��� � ������� ���������� �����:

  �����������

[](https://oauth.vk.com/authorize?client_id=6045680&redirect_uri=http://pay.techserver1.ru/oauth/vk/responce.php&scope=email,friends,video,offline%20&display=page)[](https://oauth.yandex.ru/authorize?response_type=code&client_id=805a99c62ee54772bc05df32ed6ba05b)

�����������

[������������ ������ � ��������](https://karaoke-service.com/rebuild)

[![](https://karaoke-service.com/index/i/logo_w.png)](https://karaoke-service.com/)

[��������� ����������](https://karaoke-service.com/catalog/%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD)

[��� ������](https://karaoke-service.com/myrecords)

[����������](https://karaoke-service.com/balance)

[������ � ������](https://karaoke-service.com/market)

[��� ���](https://karaoke-service.com/mybar)

[�������](https://karaoke-service.com/profile)

������������ ���,!

����� ���������� � ���������������� ������ ������� ����!

[

��������
���������

](https://karaoke-service.com/market)[��� ����
10000

+

](https://karaoke-service.com/profile)

[������� �������](https://karaoke-service.com/catalog)[����������](https://karaoke-service.com/catalog/%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD) [������������ ��������](https://karaoke-service.com/collections) [������](https://karaoke-service.com/records)

[������ ���������!](https://karaoke-service.com/catalog)

1\. ��� ������ �� ������ �����, ������� �� 5-�� ������� �����. ��������: "00010".

2\. ��� ������ "�� �����������" � "�� �������� �����", ���������� �������� ��� ������, ���� ����� ��������� � �����.

3\. ��� �� ������� ����������� ��� ������ �� ����������� ���������.

�����

+

 �� �������� �����  �� �����������

 ������

[

���������������� ONLINE ������E ����

# ����� 33000 ������� �����

](https://karaoke-service.com/#)[

���������������� ONLINE ������E ����

## ����� **33000** ����������� ����������

](https://karaoke-service.com/#)[

���������������� ONLINE ������E ����

## ������� ��������� **��� ���� �������������**

](https://karaoke-service.com/catalog)[

���������������� ONLINE ������E ����

## ��������� ������� ��� **��������� �������**

](https://karaoke-service.com/catalog)[

���������������� ONLINE ������E ����

## ������ ������� ��� **������� �����!**

](https://karaoke-service.com/catalog)

����������� � ����������� KARAOKE PRO

[

������� ���������

-   ������� ����� �����
-   ������ ������� � ����������
-   �������� � �����������

������ ����� ��� �������� �����?

](https://karaoke-service.com/catalog)[

������ ��� �����

-   ����� ����� �� ������ �����
-   ��������� � ����������
-   ����������� ���������

������ ���������

](https://karaoke-service.com/catalog)[

������� � ������

-   ���������� ��� �������������
-   ���������� PRO ��� �����
-   ��������� ��������� �������

������� � �������

](https://karaoke-service.com/market)[

������� PRO LIFE

-   �������� � �������
-   ������� � �������
-   �������� �����

������� � ������

](https://karaoke-service.com/records)

���������������. ������� ������ ������ ������� �����.

������������������ �� ����� ��� � ������� ���������� �����:

  �����������

[](https://oauth.vk.com/authorize?client_id=6045680&redirect_uri=http://pay.techserver1.ru/oauth/vk/responce.php&scope=email,friends,video,offline%20&display=page)[](https://oauth.yandex.ru/authorize?response_type=code&client_id=805a99c62ee54772bc05df32ed6ba05b)

�����������

[������������ ������ � ��������](https://karaoke-service.com/rebuild)

![](https://karaoke-service.com/index/i/man.png)![](https://karaoke-service.com/index/i/woman.png)

��������, ���, ���������.������ ��� ������.

[

\- ����� ������!

���������� ����������

](https://karaoke-service.com/catalog/%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD)

������ ����������� Karaoke pro

[

![](https://karaoke-service.com/index/i/avatar-1.png)

�������

1 �����

](https://karaoke-service.com/#)[

![](https://karaoke-service.com/index/i/avatar-2.png)

���

2 �����

](https://karaoke-service.com/#)[

![](https://karaoke-service.com/index/i/avatar-3.png)

׸���� ������

3 �����

](https://karaoke-service.com/#)

�������� ������� �����

[

����������� �������������

](https://karaoke-service.com/records)[

����������� �������������

](https://karaoke-service.com/records)[

������� �������������

](https://karaoke-service.com/records)

������� ������� ��� ����.���� ������� ������.

����� ����������

[](https://karaoke-service.com/#)

���������� ����������

[](https://karaoke-service.com/#)

![](https://karaoke-service.com/index/i/comp1.png)![](https://karaoke-service.com/index/i/comp2.png)

�������� ������� ��� �������-�����.������ ����� � ������ ���������.

������������ ������� PRO.

-   ��������� ������� ������
-   ����� ����������� ����������
-   ������� ����������
-   ������ ���������
-   ����� �������� ��������
-   ��������� ����-�����
-   �������� ���������� PRO
-   ����������� ���������

������������ � PRO �������

[������ ���������](https://karaoke-service.com/catalog)

������� � ������ �� Karaoke PRO.���������� � ��������� ��������� ������.

![](https://karaoke-service.com/index/i/boy.png)![](https://karaoke-service.com/index/i/girl.png)

[������� �����������](https://karaoke-service.com/market)[��������� ���������](https://karaoke-service.com/service)

����� 17000 �������� �������������.�����, �����������, ���������� ����������� ������ � **KARAOKE PRO**

[

](https://karaoke-service.com/records)

������� � �������

[

![](https://karaoke-service.com/index/i/news3.jpg)

#���������

������! ���������� #����������, �� �� �������! ��������� ������� ����� ��������� ��� ����������� ���������� ������ �������. � Instagram � ��������� ������ ��������� �������� ������� #�������! ��� ���, ��� ����� �� ������������� � ������������� ����� ��������� �� ������.

*������������� karaoke pro*

���� ����������: 04 ������ 2020

](https://vk.com/karaokeclub_pro?w=wall-114205271_137)[

![](https://karaoke-service.com/index/i/news1.png)

����� ����������� ��������!

��� ������ �������� �� ����� ����������� ��������. ���� ���������� � ������� �������� ��������. ������� ��� �� � ����!

*������������� karaoke pro*

���� ����������: 15 ���� 2017

](https://karaoke-service.com/#)[

![](https://karaoke-service.com/index/i/news.png)

�������� ������ ������!

��� ������ ��������, ��������� ������� ������ ������, �������� ��������������� � ������ � ������ ������. ��� ������� �������� ���������! ��������� ������������, ���������� ����� ����������, ������, �������������. ������� ��� �� � ����!

*������������� karaoke pro*

���� ����������: 10 ������ 2017

](https://karaoke-service.com/#)

![](https://karaoke-service.com/index/i/logo2.png)

������������������ �� ����� ��� � ������� ���������� �����:

  �����������

[](https://oauth.vk.com/authorize?client_id=6045680&redirect_uri=http://pay.techserver1.ru/oauth/vk/responce.php&scope=email,friends,video,offline%20&display=page)[](https://oauth.yandex.ru/authorize?response_type=code&client_id=805a99c62ee54772bc05df32ed6ba05b)

�����������

[������������ ������ � ��������](https://karaoke-service.com/rebuild)

-   [� �������](https://karaoke-service.com/about)
-   [����������](https://karaoke-service.com/agreement)
-   [�������� �����](https://karaoke-service.com/post_us)

-   [���� �������](https://karaoke-service.com/torder)
-   [������-�����](https://karaoke-service.com/faq)
-   [������� ���������](https://vk.com/karaokeclub_pro)

-   [��������� �������](https://karaoke-service.com/service)
-   [������ �����������](https://karaoke-service.com/service)
-   [����������� ����������](https://karaoke-service.com/service)

-   [���������������� ����������](https://karaoke-service.com/agreement)
-   [�������� ��������� ������������ ������](https://karaoke-service.com/upload/politikaconf.txt)
�

���������� �������:

[](https://karaoke-service.com/#)[](https://karaoke-service.com/#)

Téléversez ce fichier sous /index.md sur votre serveur pour que les AI agents puissent accéder à une version propre de votre page. Vous pouvez également configurer la négociation de contenu Accept: text/markdown pour le servir automatiquement.

Notre recommandation

Télécharger llms.txt
# karaoke-service.com

> ��� ������ ������� ����� ������ ? �������� ��������� ����� ����� 33 000 ����� � ������� � ��������. ? ����� ���������� ���� �����!

## Documentation
- [������-�����](https://karaoke-service.com/faq)
- [�������� ��������� ������������ ������](https://karaoke-service.com/upload/politikaconf.txt)

## Main
- [���� ������� ����� ������, ����������� ��������� | Karaoke PRO - ��� ��������� � ��������������](https://karaoke-service.com/): ��� ������ ������� ����� ������ ? �������� ��������� ����� ����� 33 000 ����� � ������� � ��������. ? ����� ����������…

Le llms.txt complet nécessite une analyse de tout le domaine (bientôt disponible)

Téléversez ce fichier vers https://karaoke-service.com/llms.txt à la racine de votre domaine. Les AI agents comme ChatGPT, Claude et Perplexity consultent ce fichier pour comprendre la structure de votre site.

Ce site possède déjà un fichier llms.txt.

Format valide
# Karaoke PRO (karaoke-service.com)
> ���������������� ������-�������-����: ����� 33 000 ����� � ������� � ��������, ���������� ����� ��� ������������������ �������������, ������ ������, ������ �������, ���������� � ������� ��� �������-�����.
Karaoke PRO � ���-������ �� https://karaoke-service.com ��� ��������� � ��������������. �������� ��������: ������� ���������� � ��������, ����� ��� ����� � ������������������ �������, ��� ������� �������� ���������� � ������������ ��� � ����������. ��� ��������� ������������� ���������� PRO (������ �����, ��������, ������� �����, ����������, ����� ���������� �� ��������). ���� ���������� � �������.
**�������� �����������**
- ������� �� 33 000+ �������-���������� (�������� 128�230 ����/�)
- ���������� ����� ������ (� �������������; ��� �������� � �� ����������)
- ������ ������, ��������, �����������, ������ �������
- ������ �����, ����� �����������, ����������, �������� � ��� ����� (���������� BAR / BAR+ / BAR++)
- ������� �����������, ��������� ��������� �������, ����������� ����������
- ����������� �� ����� ��� ����� VK / ������
**�� ������������� / �� ���������� ��� ��������� ������������** (������ ��������, ��. robots.txt): `/admin/`, `/mybar`, `/myrecords`, `/balance`, `/profile`, `/content/`.
## �������� �������
- [�������](https://karaoke-service.com/): ����� �������, �����������, ������������ Karaoke PRO
- [������� �����](https://karaoke-service.com/catalog): ����� � ������ �������-����������
- [���������� �����](https://karaoke-service.com/catalog/����������): ��� ���������� ��������
- [������������ ��������](https://karaoke-service.com/collections): �������� ����� �� �����
- [������� �������](https://karaoke-service.com/records): ������ �������������, ��������, Karaoke PRO LIFE
- [������� � ������](https://karaoke-service.com/market): ���������� ��� ������������� � ����� (PRO)
- [� �������](https://karaoke-service.com/about): �������� ������������, ��������� ������
- [������-�����](https://karaoke-service.com/faq): ������ �� ������ ������� �� �������������
## ��������� � �������
- [�������� �����](https://karaoke-service.com/post_us): ��������� � ��������������
- [���� �������](https://karaoke-service.com/torder): ����� ����� / ������ �������������
- [���������������� ����������](https://karaoke-service.com/agreement): ������� ������������� �������
- [�������� ��������� ������������ ������](https://karaoke-service.com/upload/politikaconf.txt): �������� ������������������ (��������� ����)
## ������
- [������ ������ �����������](https://karaoke-service.com/service): ��������� �������, ������, ����������� ����������
## Optional
- [�������������� ������](https://karaoke-service.com/rebuild): ����� ������ ��������
- [�����������](https://karaoke-service.com/registration): �������� ������� ������
- [������� ��������� (VK)](https://vk.com/karaokeclub_pro): ���������� ���������
- [Sitemap](https://karaoke-service.com/sitemap.xml): ����� ����� (����� ���� ����������)
- [robots.txt](https://karaoke-service.com/robots.txt): ������� ������ ��� ��������� �������

HTML sémantique

Utilise les éléments article ou main (0/100)

Missing <article> and <main> elements

Hiérarchie de titres correcte (100/100)

Clean heading hierarchy

Utilise des éléments HTML sémantiques (0/100)

0 semantic elements, 220 divs (ratio: 0%)

Textes alternatifs descriptifs pour les images (0/100)

0/15 images with meaningful alt text

Faible profondeur d’imbrication des divs (100/100)

Avg div depth: 4.6, max: 8

Efficacité du contenu

Bon ratio de réduction de tokens (100/100)

94% token reduction (HTML→Markdown)

Bon ratio contenu/bruit (25/100)

Content ratio: 5.9% (2642 content chars / 44927 HTML bytes)

Styles en ligne minimaux (100/100)

2/455 elements with inline styles (0.4%)

Poids de page raisonnable (100/100)

HTML size: 44KB

Visibilité IA

Possède un fichier llms.txt (100/100)

llms.txt exists and is valid

Possède un fichier robots.txt (100/100)

robots.txt exists

robots.txt autorise les bots IA (100/100)

All major AI bots allowed

Possède un sitemap.xml (100/100)

Sitemap found

Support Markdown for Agents (0/100)
&#10007; Accept: text/markdown &#10007; .md URL &#10007; <link> tag &#10007; Link header
A Content-Signal (robots.txt ou en-têtes HTTP) (0/100)
&#10003; robots.txt &#10003; HTTP header &#10007; Policy

Données structurées

Possède Schema.org / JSON-LD (0/100)

No JSON-LD / Schema.org found

Possède des balises Open Graph (100/100)

All OG tags present

Possède une meta description (100/100)

Meta description: 130 chars

Possède une URL canonique (0/100)

No canonical URL

Possède un attribut lang (0/100)

No lang attribute on <html>

Accessibilité

Contenu disponible sans JavaScript (100/100)

Content available without JavaScript

Taille de page raisonnable (100/100)

Page size: 44KB

Le contenu apparaît tôt dans le HTML (75/100)

Main content starts at 25% of HTML

{
  "url": "https://karaoke-service.com/",
  "timestamp": 1779808430650,
  "fetch": {
    "mode": "simple",
    "timeMs": 324,
    "htmlSizeBytes": 44927,
    "supportsMarkdown": false,
    "markdownAgents": {
      "contentNegotiation": false,
      "mdUrl": {
        "found": false,
        "url": null
      },
      "linkTag": {
        "found": false,
        "url": null
      },
      "linkHeader": {
        "found": false,
        "url": null
      },
      "responseHeaders": {
        "contentSignal": null,
        "xMarkdownTokens": null,
        "vary": null
      },
      "frontmatter": {
        "present": false,
        "fields": [],
        "level": "none"
      },
      "level": "none"
    },
    "statusCode": 200
  },
  "extraction": {
    "title": "���� ������� ����� ������, ����������� ��������� | Karaoke PRO - ��� ��������� � ��������������",
    "excerpt": "��� ������ ������� ����� ������ ? �������� ��������� ����� ����� 33 000 ����� � ������� � ��������. ? ����� ���������� ���� �����!",
    "byline": null,
    "siteName": null,
    "lang": null,
    "contentLength": 2642,
    "metadata": {
      "description": "��� ������ ������� ����� ������ ? �������� ��������� ����� ����� 33 000 ����� � ������� � ��������. ? ����� ���������� ���� �����!",
      "ogTitle": "���� ������� ����� ������, ����������� ��������� | Karaoke PRO - ��� ��������� � ��������������",
      "ogDescription": "��� ������ ������� ����� ������ ? �������� ��������� ����� ����� 33 000 ����� � ������� � ��������. ? ����� ���������� ���� �����!",
      "ogImage": "https://karaoke-service.com/images/logo_vk.jpg",
      "ogType": "website",
      "canonical": null,
      "lang": null,
      "schemas": [],
      "robotsMeta": "index, follow",
      "author": null,
      "generator": null,
      "markdownAlternateHref": null
    }
  },
  "markdown": "![](https://karaoke-service.com/index/i/logo.png)\n\n������������������ �� ����� ��� � ������� ���������� �����:\n\n[![](https://karaoke-service.com/index/i/logo_w.png)](https://karaoke-service.com/)\n\n1\\. ��� ������ �� ������ �����, ������� �� 5-�� ������� �����. ��������: \"00010\".\n\n2\\. ��� ������ \"�� �����������\" � \"�� �������� �����\", ���������� �������� ��� ������, ���� ����� ��������� � �����.\n\n3\\. ��� �� ������� ����������� ��� ������ �� ����������� ���������.\n\n�����\n\n+\n\n�� �������� ����� �� �����������\n\n����������� � ����������� KARAOKE PRO\n\n���������������. ������� ������ ������ ������� �����.\n\n������������������ �� ����� ��� � ������� ���������� �����:\n\n![](https://karaoke-service.com/index/i/man.png)![](https://karaoke-service.com/index/i/woman.png)\n\n��������, ���, ���������.������ ��� ������.\n\n�������� ������� �����\n\n������� ������� ��� ����.���� ������� ������.\n\n����� ����������\n\n���������� ����������\n\n![](https://karaoke-service.com/index/i/comp1.png)![](https://karaoke-service.com/index/i/comp2.png)\n\n�������� ������� ��� �������-�����.������ ����� � ������ ���������.\n\n������������ ������� PRO.\n\n-   ��������� ������� ������\n-   ����� ����������� ����������\n-   ������� ����������\n-   ������ ���������\n-   ����� �������� ��������\n-   ��������� ����-�����\n-   �������� ���������� PRO\n-   ����������� ���������\n\n������� � ������ �� Karaoke PRO.���������� � ��������� ��������� ������.\n\n![](https://karaoke-service.com/index/i/boy.png)![](https://karaoke-service.com/index/i/girl.png)\n\n����� 17000 �������� �������������.�����, �����������, ���������� ����������� ������ � **KARAOKE PRO**\n\n������� � �������\n",
  "fullPageMarkdown": "���� ������� ����� ������, ����������� ��������� | Karaoke PRO - ��� ��������� � ��������������\n\n|  |\n|  |\n\n![](https://karaoke-service.com/index/i/logo.png)\n\n������������������ �� ����� ��� � ������� ���������� �����:\n\n  �����������\n\n[](https://oauth.vk.com/authorize?client_id=6045680&redirect_uri=http://pay.techserver1.ru/oauth/vk/responce.php&scope=email,friends,video,offline%20&display=page)[](https://oauth.yandex.ru/authorize?response_type=code&client_id=805a99c62ee54772bc05df32ed6ba05b)\n\n�����������\n\n[������������ ������ � ��������](https://karaoke-service.com/rebuild)\n\n[![](https://karaoke-service.com/index/i/logo_w.png)](https://karaoke-service.com/)\n\n[��������� ����������](https://karaoke-service.com/catalog/%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD)\n\n[��� ������](https://karaoke-service.com/myrecords)\n\n[����������](https://karaoke-service.com/balance)\n\n[������ � ������](https://karaoke-service.com/market)\n\n[��� ���](https://karaoke-service.com/mybar)\n\n[�������](https://karaoke-service.com/profile)\n\n������������ ���,!\n\n����� ���������� � ���������������� ������ ������� ����!\n\n[\n\n��������\n���������\n\n](https://karaoke-service.com/market)[��� ����\n10000\n\n+\n\n](https://karaoke-service.com/profile)\n\n[������� �������](https://karaoke-service.com/catalog)[����������](https://karaoke-service.com/catalog/%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD) [������������ ��������](https://karaoke-service.com/collections) [������](https://karaoke-service.com/records)\n\n[������ ���������!](https://karaoke-service.com/catalog)\n\n1\\. ��� ������ �� ������ �����, ������� �� 5-�� ������� �����. ��������: \"00010\".\n\n2\\. ��� ������ \"�� �����������\" � \"�� �������� �����\", ���������� �������� ��� ������, ���� ����� ��������� � �����.\n\n3\\. ��� �� ������� ����������� ��� ������ �� ����������� ���������.\n\n�����\n\n+\n\n �� �������� �����  �� �����������\n\n ������\n\n[\n\n���������������� ONLINE ������E ����\n\n# ����� 33000 ������� �����\n\n](https://karaoke-service.com/#)[\n\n���������������� ONLINE ������E ����\n\n## ����� **33000** ����������� ����������\n\n](https://karaoke-service.com/#)[\n\n���������������� ONLINE ������E ����\n\n## ������� ��������� **��� ���� �������������**\n\n](https://karaoke-service.com/catalog)[\n\n���������������� ONLINE ������E ����\n\n## ��������� ������� ��� **��������� �������**\n\n](https://karaoke-service.com/catalog)[\n\n���������������� ONLINE ������E ����\n\n## ������ ������� ��� **������� �����!**\n\n](https://karaoke-service.com/catalog)\n\n����������� � ����������� KARAOKE PRO\n\n[\n\n������� ���������\n\n-   ������� ����� �����\n-   ������ ������� � ����������\n-   �������� � �����������\n\n������ ����� ��� �������� �����?\n\n](https://karaoke-service.com/catalog)[\n\n������ ��� �����\n\n-   ����� ����� �� ������ �����\n-   ��������� � ����������\n-   ����������� ���������\n\n������ ���������\n\n](https://karaoke-service.com/catalog)[\n\n������� � ������\n\n-   ���������� ��� �������������\n-   ���������� PRO ��� �����\n-   ��������� ��������� �������\n\n������� � �������\n\n](https://karaoke-service.com/market)[\n\n������� PRO LIFE\n\n-   �������� � �������\n-   ������� � �������\n-   �������� �����\n\n������� � ������\n\n](https://karaoke-service.com/records)\n\n���������������. ������� ������ ������ ������� �����.\n\n������������������ �� ����� ��� � ������� ���������� �����:\n\n  �����������\n\n[](https://oauth.vk.com/authorize?client_id=6045680&redirect_uri=http://pay.techserver1.ru/oauth/vk/responce.php&scope=email,friends,video,offline%20&display=page)[](https://oauth.yandex.ru/authorize?response_type=code&client_id=805a99c62ee54772bc05df32ed6ba05b)\n\n�����������\n\n[������������ ������ � ��������](https://karaoke-service.com/rebuild)\n\n![](https://karaoke-service.com/index/i/man.png)![](https://karaoke-service.com/index/i/woman.png)\n\n��������, ���, ���������.������ ��� ������.\n\n[\n\n\\- ����� ������!\n\n���������� ����������\n\n](https://karaoke-service.com/catalog/%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD%EF%BF%BD)\n\n������ ����������� Karaoke pro\n\n[\n\n![](https://karaoke-service.com/index/i/avatar-1.png)\n\n�������\n\n1 �����\n\n](https://karaoke-service.com/#)[\n\n![](https://karaoke-service.com/index/i/avatar-2.png)\n\n���\n\n2 �����\n\n](https://karaoke-service.com/#)[\n\n![](https://karaoke-service.com/index/i/avatar-3.png)\n\n׸���� ������\n\n3 �����\n\n](https://karaoke-service.com/#)\n\n�������� ������� �����\n\n[\n\n����������� �������������\n\n](https://karaoke-service.com/records)[\n\n����������� �������������\n\n](https://karaoke-service.com/records)[\n\n������� �������������\n\n](https://karaoke-service.com/records)\n\n������� ������� ��� ����.���� ������� ������.\n\n����� ����������\n\n[](https://karaoke-service.com/#)\n\n���������� ����������\n\n[](https://karaoke-service.com/#)\n\n![](https://karaoke-service.com/index/i/comp1.png)![](https://karaoke-service.com/index/i/comp2.png)\n\n�������� ������� ��� �������-�����.������ ����� � ������ ���������.\n\n������������ ������� PRO.\n\n-   ��������� ������� ������\n-   ����� ����������� ����������\n-   ������� ����������\n-   ������ ���������\n-   ����� �������� ��������\n-   ��������� ����-�����\n-   �������� ���������� PRO\n-   ����������� ���������\n\n������������ � PRO �������\n\n[������ ���������](https://karaoke-service.com/catalog)\n\n������� � ������ �� Karaoke PRO.���������� � ��������� ��������� ������.\n\n![](https://karaoke-service.com/index/i/boy.png)![](https://karaoke-service.com/index/i/girl.png)\n\n[������� �����������](https://karaoke-service.com/market)[��������� ���������](https://karaoke-service.com/service)\n\n����� 17000 �������� �������������.�����, �����������, ���������� ����������� ������ � **KARAOKE PRO**\n\n[\n\n](https://karaoke-service.com/records)\n\n������� � �������\n\n[\n\n![](https://karaoke-service.com/index/i/news3.jpg)\n\n#���������\n\n������! ���������� #����������, �� �� �������! ��������� ������� ����� ��������� ��� ����������� ���������� ������ �������. � Instagram � ��������� ������ ��������� �������� ������� #�������! ��� ���, ��� ����� �� ������������� � ������������� ����� ��������� �� ������.\n\n*������������� karaoke pro*\n\n���� ����������: 04 ������ 2020\n\n](https://vk.com/karaokeclub_pro?w=wall-114205271_137)[\n\n![](https://karaoke-service.com/index/i/news1.png)\n\n����� ����������� ��������!\n\n��� ������ �������� �� ����� ����������� ��������. ���� ���������� � ������� �������� ��������. ������� ��� �� � ����!\n\n*������������� karaoke pro*\n\n���� ����������: 15 ���� 2017\n\n](https://karaoke-service.com/#)[\n\n![](https://karaoke-service.com/index/i/news.png)\n\n�������� ������ ������!\n\n��� ������ ��������, ��������� ������� ������ ������, �������� ��������������� � ������ � ������ ������. ��� ������� �������� ���������! ��������� ������������, ���������� ����� ����������, ������, �������������. ������� ��� �� � ����!\n\n*������������� karaoke pro*\n\n���� ����������: 10 ������ 2017\n\n](https://karaoke-service.com/#)\n\n![](https://karaoke-service.com/index/i/logo2.png)\n\n������������������ �� ����� ��� � ������� ���������� �����:\n\n  �����������\n\n[](https://oauth.vk.com/authorize?client_id=6045680&redirect_uri=http://pay.techserver1.ru/oauth/vk/responce.php&scope=email,friends,video,offline%20&display=page)[](https://oauth.yandex.ru/authorize?response_type=code&client_id=805a99c62ee54772bc05df32ed6ba05b)\n\n�����������\n\n[������������ ������ � ��������](https://karaoke-service.com/rebuild)\n\n-   [� �������](https://karaoke-service.com/about)\n-   [����������](https://karaoke-service.com/agreement)\n-   [�������� �����](https://karaoke-service.com/post_us)\n\n-   [���� �������](https://karaoke-service.com/torder)\n-   [������-�����](https://karaoke-service.com/faq)\n-   [������� ���������](https://vk.com/karaokeclub_pro)\n\n-   [��������� �������](https://karaoke-service.com/service)\n-   [������ �����������](https://karaoke-service.com/service)\n-   [����������� ����������](https://karaoke-service.com/service)\n\n-   [���������������� ����������](https://karaoke-service.com/agreement)\n-   [�������� ��������� ������������ ������](https://karaoke-service.com/upload/politikaconf.txt)\n�\n\n���������� �������:\n\n[](https://karaoke-service.com/#)[](https://karaoke-service.com/#)\n",
  "markdownStats": {
    "images": 8,
    "links": 1,
    "tables": 0,
    "codeBlocks": 0,
    "headings": 0
  },
  "tokens": {
    "htmlTokens": 8406,
    "markdownTokens": 520,
    "reduction": 7886,
    "reductionPercent": 94
  },
  "score": {
    "score": 63,
    "grade": "C",
    "dimensions": {
      "semanticHtml": {
        "score": 45,
        "weight": 20,
        "grade": "D",
        "checks": {
          "uses_article_or_main": {
            "score": 0,
            "weight": 20,
            "details": "Missing <article> and <main> elements"
          },
          "proper_heading_hierarchy": {
            "score": 100,
            "weight": 25,
            "details": "Clean heading hierarchy"
          },
          "semantic_elements": {
            "score": 0,
            "weight": 20,
            "details": "0 semantic elements, 220 divs (ratio: 0%)"
          },
          "meaningful_alt_texts": {
            "score": 0,
            "weight": 15,
            "details": "0/15 images with meaningful alt text"
          },
          "low_div_nesting": {
            "score": 100,
            "weight": 20,
            "details": "Avg div depth: 4.6, max: 8"
          }
        }
      },
      "contentEfficiency": {
        "score": 78,
        "weight": 25,
        "grade": "B",
        "checks": {
          "token_reduction_ratio": {
            "score": 100,
            "weight": 40,
            "details": "94% token reduction (HTML→Markdown)"
          },
          "content_to_noise_ratio": {
            "score": 25,
            "weight": 30,
            "details": "Content ratio: 5.9% (2642 content chars / 44927 HTML bytes)"
          },
          "minimal_inline_styles": {
            "score": 100,
            "weight": 15,
            "details": "2/455 elements with inline styles (0.4%)"
          },
          "reasonable_page_weight": {
            "score": 100,
            "weight": 15,
            "details": "HTML size: 44KB"
          }
        }
      },
      "aiDiscoverability": {
        "score": 55,
        "weight": 25,
        "grade": "D",
        "checks": {
          "has_llms_txt": {
            "score": 100,
            "weight": 20,
            "details": "llms.txt exists and is valid"
          },
          "has_robots_txt": {
            "score": 100,
            "weight": 10,
            "details": "robots.txt exists"
          },
          "robots_allows_ai_bots": {
            "score": 100,
            "weight": 15,
            "details": "All major AI bots allowed"
          },
          "has_sitemap": {
            "score": 100,
            "weight": 10,
            "details": "Sitemap found"
          },
          "supports_markdown_negotiation": {
            "score": 0,
            "weight": 25,
            "details": "No Markdown for Agents support detected"
          },
          "has_content_signals": {
            "score": 0,
            "weight": 20,
            "details": "No Content-Signal found (robots.txt or HTTP headers)"
          }
        }
      },
      "structuredData": {
        "score": 45,
        "weight": 15,
        "grade": "D",
        "checks": {
          "has_schema_org": {
            "score": 0,
            "weight": 30,
            "details": "No JSON-LD / Schema.org found"
          },
          "has_open_graph": {
            "score": 100,
            "weight": 25,
            "details": "All OG tags present"
          },
          "has_meta_description": {
            "score": 100,
            "weight": 20,
            "details": "Meta description: 130 chars"
          },
          "has_canonical_url": {
            "score": 0,
            "weight": 15,
            "details": "No canonical URL"
          },
          "has_lang_attribute": {
            "score": 0,
            "weight": 10,
            "details": "No lang attribute on <html>"
          }
        }
      },
      "accessibility": {
        "score": 93,
        "weight": 15,
        "grade": "A",
        "checks": {
          "content_without_js": {
            "score": 100,
            "weight": 40,
            "details": "Content available without JavaScript"
          },
          "reasonable_page_size": {
            "score": 100,
            "weight": 30,
            "details": "Page size: 44KB"
          },
          "fast_content_position": {
            "score": 75,
            "weight": 30,
            "details": "Main content starts at 25% of HTML"
          }
        }
      }
    }
  },
  "recommendations": [
    {
      "id": "add_article_main",
      "priority": "critical",
      "category": "semanticHtml",
      "titleKey": "rec.add_article_main.title",
      "descriptionKey": "rec.add_article_main.description",
      "howToKey": "rec.add_article_main.howto",
      "effort": "quick-win",
      "estimatedImpact": 8,
      "checkScore": 0,
      "checkDetails": "Missing <article> and <main> elements"
    },
    {
      "id": "add_markdown_negotiation",
      "priority": "critical",
      "category": "aiDiscoverability",
      "titleKey": "rec.add_markdown_negotiation.title",
      "descriptionKey": "rec.add_markdown_negotiation.description",
      "howToKey": "rec.add_markdown_negotiation.howto",
      "effort": "significant",
      "estimatedImpact": 6,
      "checkScore": 0,
      "checkDetails": "No Markdown for Agents support detected"
    },
    {
      "id": "add_content_signals",
      "priority": "critical",
      "category": "aiDiscoverability",
      "titleKey": "rec.add_content_signals.title",
      "descriptionKey": "rec.add_content_signals.description",
      "howToKey": "rec.add_content_signals.howto",
      "effort": "quick-win",
      "estimatedImpact": 5,
      "checkScore": 0,
      "checkDetails": "No Content-Signal found (robots.txt or HTTP headers)"
    },
    {
      "id": "add_semantic_elements",
      "priority": "critical",
      "category": "semanticHtml",
      "titleKey": "rec.add_semantic_elements.title",
      "descriptionKey": "rec.add_semantic_elements.description",
      "howToKey": "rec.add_semantic_elements.howto",
      "effort": "moderate",
      "estimatedImpact": 5,
      "checkScore": 0,
      "checkDetails": "0 semantic elements, 220 divs (ratio: 0%)"
    },
    {
      "id": "improve_alt_texts",
      "priority": "critical",
      "category": "semanticHtml",
      "titleKey": "rec.improve_alt_texts.title",
      "descriptionKey": "rec.improve_alt_texts.description",
      "howToKey": "rec.improve_alt_texts.howto",
      "effort": "moderate",
      "estimatedImpact": 4,
      "checkScore": 0,
      "checkDetails": "0/15 images with meaningful alt text"
    },
    {
      "id": "improve_content_ratio",
      "priority": "high",
      "category": "contentEfficiency",
      "titleKey": "rec.improve_content_ratio.title",
      "descriptionKey": "rec.improve_content_ratio.description",
      "howToKey": "rec.improve_content_ratio.howto",
      "effort": "moderate",
      "estimatedImpact": 6,
      "checkScore": 25,
      "checkDetails": "Content ratio: 5.9% (2642 content chars / 44927 HTML bytes)"
    },
    {
      "id": "add_schema_org",
      "priority": "high",
      "category": "structuredData",
      "titleKey": "rec.add_schema_org.title",
      "descriptionKey": "rec.add_schema_org.description",
      "howToKey": "rec.add_schema_org.howto",
      "effort": "moderate",
      "estimatedImpact": 6,
      "checkScore": 0,
      "checkDetails": "No JSON-LD / Schema.org found"
    },
    {
      "id": "add_canonical_url",
      "priority": "high",
      "category": "structuredData",
      "titleKey": "rec.add_canonical_url.title",
      "descriptionKey": "rec.add_canonical_url.description",
      "howToKey": "rec.add_canonical_url.howto",
      "effort": "quick-win",
      "estimatedImpact": 3,
      "checkScore": 0,
      "checkDetails": "No canonical URL"
    },
    {
      "id": "add_lang_attribute",
      "priority": "high",
      "category": "structuredData",
      "titleKey": "rec.add_lang_attribute.title",
      "descriptionKey": "rec.add_lang_attribute.description",
      "howToKey": "rec.add_lang_attribute.howto",
      "effort": "quick-win",
      "estimatedImpact": 2,
      "checkScore": 0,
      "checkDetails": "No lang attribute on <html>"
    }
  ],
  "llmsTxtPreview": "# karaoke-service.com\n\n> ��� ������ ������� ����� ������ ? �������� ��������� ����� ����� 33 000 ����� � ������� � ��������. ? ����� ���������� ���� �����!\n\n## Documentation\n- [������-�����](https://karaoke-service.com/faq)\n- [�������� ��������� ������������ ������](https://karaoke-service.com/upload/politikaconf.txt)\n\n## Main\n- [���� ������� ����� ������, ����������� ��������� | Karaoke PRO - ��� ��������� � ��������������](https://karaoke-service.com/): ��� ������ ������� ����� ������ ? �������� ��������� ����� ����� 33 000 ����� � ������� � ��������. ? ����� ����������…\n\n",
  "llmsTxtExisting": "# Karaoke PRO (karaoke-service.com)\r\n> ���������������� ������-�������-����: ����� 33 000 ����� � ������� � ��������, ���������� ����� ��� ������������������ �������������, ������ ������, ������ �������, ���������� � ������� ��� �������-�����.\r\nKaraoke PRO � ���-������ �� https://karaoke-service.com ��� ��������� � ��������������. �������� ��������: ������� ���������� � ��������, ����� ��� ����� � ������������������ �������, ��� ������� �������� ���������� � ������������ ��� � ����������. ��� ��������� ������������� ���������� PRO (������ �����, ��������, ������� �����, ����������, ����� ���������� �� ��������). ���� ���������� � �������.\r\n**�������� �����������**\r\n- ������� �� 33 000+ �������-���������� (�������� 128�230 ����/�)\r\n- ���������� ����� ������ (� �������������; ��� �������� � �� ����������)\r\n- ������ ������, ��������, �����������, ������ �������\r\n- ������ �����, ����� �����������, ����������, �������� � ��� ����� (���������� BAR / BAR+ / BAR++)\r\n- ������� �����������, ��������� ��������� �������, ����������� ����������\r\n- ����������� �� ����� ��� ����� VK / ������\r\n**�� ������������� / �� ���������� ��� ��������� ������������** (������ ��������, ��. robots.txt): `/admin/`, `/mybar`, `/myrecords`, `/balance`, `/profile`, `/content/`.\r\n## �������� �������\r\n- [�������](https://karaoke-service.com/): ����� �������, �����������, ������������ Karaoke PRO\r\n- [������� �����](https://karaoke-service.com/catalog): ����� � ������ �������-����������\r\n- [���������� �����](https://karaoke-service.com/catalog/����������): ��� ���������� ��������\r\n- [������������ ��������](https://karaoke-service.com/collections): �������� ����� �� �����\r\n- [������� �������](https://karaoke-service.com/records): ������ �������������, ��������, Karaoke PRO LIFE\r\n- [������� � ������](https://karaoke-service.com/market): ���������� ��� ������������� � ����� (PRO)\r\n- [� �������](https://karaoke-service.com/about): �������� ������������, ��������� ������\r\n- [������-�����](https://karaoke-service.com/faq): ������ �� ������ ������� �� �������������\r\n## ��������� � �������\r\n- [�������� �����](https://karaoke-service.com/post_us): ��������� � ��������������\r\n- [���� �������](https://karaoke-service.com/torder): ����� ����� / ������ �������������\r\n- [���������������� ����������](https://karaoke-service.com/agreement): ������� ������������� �������\r\n- [�������� ��������� ������������ ������](https://karaoke-service.com/upload/politikaconf.txt): �������� ������������������ (��������� ����)\r\n## ������\r\n- [������ ������ �����������](https://karaoke-service.com/service): ��������� �������, ������, ����������� ����������\r\n## Optional\r\n- [�������������� ������](https://karaoke-service.com/rebuild): ����� ������ ��������\r\n- [�����������](https://karaoke-service.com/registration): �������� ������� ������\r\n- [������� ��������� (VK)](https://vk.com/karaokeclub_pro): ���������� ���������\r\n- [Sitemap](https://karaoke-service.com/sitemap.xml): ����� ����� (����� ���� ����������)\r\n- [robots.txt](https://karaoke-service.com/robots.txt): ������� ������ ��� ��������� �������",
  "emergingProtocols": {
    "oauthDiscovery": {
      "exists": false,
      "url": "https://karaoke-service.com/.well-known/oauth-authorization-server"
    },
    "mcpServerCard": {
      "exists": false,
      "url": "https://karaoke-service.com/.well-known/mcp.json"
    },
    "a2aAgentCard": {
      "exists": false,
      "url": "https://karaoke-service.com/.well-known/agent.json"
    },
    "count": 0
  },
  "snippets": [
    {
      "id": "add_canonical_url",
      "title": "Add canonical URL",
      "description": "The canonical URL tells AI agents which version of the page is the \"official\" one, avoiding duplicate content issues.",
      "language": "html",
      "code": "<link rel=\"canonical\" href=\"https://karaoke-service.com/\">",
      "filename": "<head>"
    },
    {
      "id": "add_lang_attribute",
      "title": "Add lang attribute",
      "description": "The lang attribute helps AI agents identify the language of your content.",
      "language": "html",
      "code": "<html lang=\"en\">",
      "filename": "Opening <html> tag"
    },
    {
      "id": "add_schema_org",
      "title": "Add Schema.org JSON-LD",
      "description": "Structured data helps AI agents understand the type, author, and purpose of your content.",
      "language": "html",
      "code": "<script type=\"application/ld+json\">\n{\n  \"@context\": \"https://schema.org\",\n  \"@type\": \"WebPage\",\n  \"name\": \"���� ������� ����� ������, ����������� ��������� | Karaoke PRO - ��� ��������� � ��������������\",\n  \"description\": \"��� ������ ������� ����� ������ ? �������� ��������� ����� ����� 33 000 ����� � ������� � ��������. ? ����� ���������� ���� �����!\",\n  \"url\": \"https://karaoke-service.com/\",\n  \"inLanguage\": \"en\"\n}\n</script>",
      "filename": "<head>"
    },
    {
      "id": "add_article_main",
      "title": "Wrap content in <main> and <article>",
      "description": "Semantic HTML landmarks help AI agents identify the main content of your page.",
      "language": "html",
      "code": "<main>\n  <article>\n    <h1>Your Page Title</h1>\n    <p>Your content here...</p>\n  </article>\n</main>",
      "filename": "<body>"
    },
    {
      "id": "add_content_signals",
      "title": "Add Content-Signal directives",
      "description": "Content-Signal tells AI agents how they may use your content. The canonical location is robots.txt, but you can also expose it as an HTTP header from any stack.",
      "language": "txt",
      "code": "User-agent: *\nContent-Signal: search=yes, ai-input=yes, ai-train=no",
      "filename": "/robots.txt",
      "stacks": [
        {
          "id": "robots",
          "label": "robots.txt",
          "language": "txt",
          "filename": "/robots.txt",
          "code": "User-agent: *\nContent-Signal: search=yes, ai-input=yes, ai-train=no"
        },
        {
          "id": "nginx",
          "label": "Nginx",
          "language": "nginx",
          "filename": "server block",
          "code": "# Inside your server { } block:\nadd_header Content-Signal \"search=yes, ai-input=yes, ai-train=no\" always;"
        },
        {
          "id": "apache",
          "label": "Apache",
          "language": "apache",
          "filename": ".htaccess",
          "code": "# In .htaccess (or VirtualHost):\nHeader set Content-Signal \"search=yes, ai-input=yes, ai-train=no\""
        },
        {
          "id": "wordpress",
          "label": "WordPress",
          "language": "php",
          "filename": "functions.php",
          "code": "<?php\n// In your theme's functions.php or a small mu-plugin\nadd_action('send_headers', function () {\n    header('Content-Signal: search=yes, ai-input=yes, ai-train=no');\n});\n\n// Optional: also append the directive to the dynamic robots.txt\nadd_filter('robots_txt', function ($output) {\n    return $output . \"\\nContent-Signal: search=yes, ai-input=yes, ai-train=no\\n\";\n}, 10, 1);"
        },
        {
          "id": "nextjs",
          "label": "Next.js",
          "language": "typescript",
          "filename": "middleware.ts",
          "code": "// middleware.ts (Next.js 13+ App Router or Pages Router)\nimport { NextResponse } from 'next/server';\nexport function middleware() {\n  const res = NextResponse.next();\n  res.headers.set(\n    'Content-Signal',\n    'search=yes, ai-input=yes, ai-train=no'\n  );\n  return res;\n}\nexport const config = { matcher: '/:path*' };"
        },
        {
          "id": "cloudflare",
          "label": "Cloudflare Workers",
          "language": "javascript",
          "filename": "worker.js",
          "code": "// Cloudflare Worker that proxies your origin and adds the header\nexport default {\n  async fetch(request, env, ctx) {\n    const res = await fetch(request);\n    const newRes = new Response(res.body, res);\n    newRes.headers.set(\n      'Content-Signal',\n      'search=yes, ai-input=yes, ai-train=no'\n    );\n    return newRes;\n  },\n};"
        },
        {
          "id": "express",
          "label": "Express / Fastify",
          "language": "javascript",
          "filename": "server.js",
          "code": "// Express\napp.use((req, res, next) => {\n  res.setHeader('Content-Signal', 'search=yes, ai-input=yes, ai-train=no');\n  next();\n});\n\n// Fastify\nfastify.addHook('onSend', (request, reply, payload, done) => {\n  reply.header('Content-Signal', 'search=yes, ai-input=yes, ai-train=no');\n  done();\n});"
        }
      ]
    },
    {
      "id": "add_markdown_negotiation",
      "title": "Support Markdown for Agents",
      "description": "Let AI agents request a clean Markdown version of any page via content negotiation, .md alternate URLs, link tags or Link headers.",
      "language": "html",
      "code": "<!-- Mechanism 3: link tag advertising the .md alternate -->\n<link rel=\"alternate\" type=\"text/markdown\" href=\"/page.md\">",
      "filename": "<head>",
      "stacks": [
        {
          "id": "html",
          "label": "HTML <head>",
          "language": "html",
          "filename": "<head>",
          "code": "<!-- Mechanism 3: link tag advertising the .md alternate -->\n<link rel=\"alternate\" type=\"text/markdown\" href=\"/page.md\">"
        },
        {
          "id": "express",
          "label": "Express",
          "language": "javascript",
          "filename": "server.js",
          "code": "// Mechanisms 1 + 4: content negotiation + Link header\napp.get('/page', (req, res) => {\n  res.setHeader('Vary', 'Accept');\n  res.setHeader('Link', '</page.md>; rel=\"alternate\"; type=\"text/markdown\"');\n  if ((req.headers.accept || '').includes('text/markdown')) {\n    res.type('text/markdown; charset=utf-8');\n    return res.send(renderMarkdown('page'));\n  }\n  res.render('page');\n});"
        },
        {
          "id": "fastify",
          "label": "Fastify",
          "language": "javascript",
          "filename": "server.js",
          "code": "// Mechanisms 1 + 4: content negotiation + Link header\nfastify.get('/page', async (req, reply) => {\n  reply.header('Vary', 'Accept');\n  reply.header('Link', '</page.md>; rel=\"alternate\"; type=\"text/markdown\"');\n  if ((req.headers.accept || '').includes('text/markdown')) {\n    return reply.type('text/markdown; charset=utf-8').send(renderMarkdown('page'));\n  }\n  return reply.view('/page.ejs');\n});"
        },
        {
          "id": "nextjs",
          "label": "Next.js",
          "language": "typescript",
          "filename": "app/page/route.ts",
          "code": "// Next.js App Router — Route Handler returning Markdown\nimport { NextRequest } from 'next/server';\nimport { renderMarkdown } from '@/lib/md';\nexport async function GET(req: NextRequest) {\n  const accept = req.headers.get('accept') || '';\n  if (accept.includes('text/markdown')) {\n    return new Response(await renderMarkdown('page'), {\n      headers: {\n        'Content-Type': 'text/markdown; charset=utf-8',\n        'Vary': 'Accept',\n      },\n    });\n  }\n  // Fall through to the page component\n  return new Response(null, { status: 404 });\n}"
        },
        {
          "id": "wordpress",
          "label": "WordPress",
          "language": "php",
          "filename": "functions.php",
          "code": "<?php\n// Mechanism 1: respond to Accept: text/markdown on the same URL\nadd_action('template_redirect', function () {\n    if (!is_singular()) return;\n    $accept = $_SERVER['HTTP_ACCEPT'] ?? '';\n    if (strpos($accept, 'text/markdown') === false) return;\n    header('Content-Type: text/markdown; charset=utf-8');\n    header('Vary: Accept');\n    $post = get_queried_object();\n    echo \"# \" . get_the_title($post) . \"\\n\\n\";\n    echo wp_strip_all_tags(apply_filters('the_content', $post->post_content));\n    exit;\n});"
        },
        {
          "id": "static",
          "label": "Hugo / Jekyll / Astro",
          "language": "txt",
          "filename": "static/page.md",
          "code": "# Mechanism 2: serve .md alongside .html\n# Hugo: place page.md in /static/ — built unchanged\n# Jekyll: drop page.md in /assets/ — copied as-is\n# Astro: src/pages/page.md.ts that exports a GET returning markdown\n\n# Then advertise with mechanism 3 in <head>:\n#   <link rel=\"alternate\" type=\"text/markdown\" href=\"/page.md\">"
        }
      ]
    }
  ]
}

Utilisez notre API pour obtenir ceci de manière programmatique (bientôt disponible)

Ce JSON est à usage interne — contrairement au Markdown et au llms.txt, il n’est pas destiné à être téléversé sur votre site. Conservez-le comme référence pour suivre l’évolution de votre score, partagez-le avec votre équipe de développement ou intégrez-le dans votre pipeline CI/CD.

Partagez vos résultats

Twitter LinkedIn

Intégrez votre badge

Ajoutez ce badge à votre site. Il se met à jour automatiquement lorsque votre score de préparation à l’IA change.

AgentReady.md score for karaoke-service.com
Script Recommandé
<script src="https://agentready.md/badge.js" data-id="1791f6cb-54b9-47a0-88bc-18f5119c4852" data-domain="karaoke-service.com"></script>
Markdown
[![AgentReady.md score for karaoke-service.com](https://agentready.md/badge/karaoke-service.com.svg)](https://agentready.md/fr/r/1791f6cb-54b9-47a0-88bc-18f5119c4852)

Bientôt : Analyse de domaine complet

Explorez l’ensemble de votre domaine, générez un llms.txt et surveillez votre score de préparation IA dans le temps. Rejoignez la liste d’attente pour être informé.

Vous êtes sur la liste ! Nous vous préviendrons lors du lancement.