認証済み AgentReady.md 証明書
発行日時 sig: 0f23ffae8b965ec7 検証 →

分析済みURL

https://karaoke-service.com/

別のURLを分析

AI-Readyスコア

63 / C

普通

/ 100

トークン削減量

HTMLトークン 8406
Markdownトークン 520
削減率 94%

スコア内訳

セマンティックHTML 45/100
コンテンツ効率 78/100
AI発見可能性 55/100
構造化データ 45/100
アクセシビリティ 93/100

新興プロトコル

3件中0件検出

AIエージェントが探すwell-knownエンドポイント。検出されればエージェントが自動的にあなたのサービスを発見・接続できます。

  • 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

ページに<article>または<main>要素がありません。これらのセマンティックコンテナはAIエージェントがメインコンテンツ領域を特定し、ナビゲーション、サイドバー、フッターを無視するのに役立ちます。

実装方法

ページのメインコンテンツの周りに<main>要素を追加し、ブログ投稿や製品説明などの独立したコンテンツブロックには<article>を使用してください。

サイトがMarkdown for Agentsに対応していません。このCloudflare標準により、AIエージェントがmarkdown形式でコンテンツをリクエストでき、トークン使用量を約80%削減できます。

実装方法

以下の1つ以上を実装してください:(1) Accept: text/markdownにmarkdownコンテンツで応答。(2) .md URL(例:/page.md)を提供。(3) <link rel="alternate" type="text/markdown">タグを追加。(4) markdown検出用のLink HTTPヘッダーを追加。

{\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# "}] }'>

Content-Signalディレクティブが見つかりません。これらはAIエージェントにコンテンツの使用方法(検索インデックス、AI入力、トレーニングデータ)を伝えます。推奨場所はrobots.txtです。

実装方法

robots.txtにContent-Signalを追加:User-agent: *\nContent-Signal: search=yes, ai-input=yes, ai-train=no。markdown応答のHTTPヘッダーとしても追加できます。

{\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});"}] }'>

ページが<div>要素に大きく依存しています。<section>、<nav>、<header>、<footer>、<aside>などのセマンティック要素はAIエージェントに意味のある構造を提供します。

実装方法

汎用的な<div>コンテナを適切なセマンティック要素に置き換えてください。テーマ別グループには<section>、ナビゲーションには<nav>、ページ/セクションのヘッダーとフッターには<header>/<footer>を使用してください。

一部の画像に説明的なalt属性がありません。適切なalt属性はAIエージェントが画像の内容とコンテキストを理解するのに役立ちます。

実装方法

すべての画像に説明的なalt属性を追加してください。「画像」や「写真」だけでなく、画像の内容を説明してください。装飾的な画像にはalt=""(空)を使用してください。

ページの実際のコンテンツとHTML全体の比率が低いです。ページ重量の多くがコンテンツではなくマークアップ、スクリプト、スタイルです。

実装方法

CSSを外部スタイルシートに移動し、インラインスタイルを削除し、JavaScriptを最小化し、HTMLがコンテンツ構造に集中するようにしてください。

Schema.org構造化データが見つかりません。JSON-LDはAIエージェントがページから事実に基づいた構造化情報を抽出するのに役立ちます。

実装方法

Schema.orgマークアップを含む<script type="application/ld+json">ブロックを追加してください。適切なタイプを使用:ブログ投稿にはArticle、製品ページにはProduct、企業ページにはOrganization。

正規URLが見つかりません。これはAIエージェントがページの優先バージョンを特定し、重複コンテンツを回避するのに役立ちます。

実装方法

ページの正規URLを指す<link rel="canonical" href="...">タグを追加してください。

<html>要素にlang属性がありません。これはAIエージェントにページの主要言語を伝えます。

実装方法

<html>タグにlang="ja"(またはご使用の言語)を追加してください:<html lang="ja">。

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/#)

このファイルをサーバーの/index.mdとしてアップロードし、AIエージェントがページのクリーンなバージョンにアクセスできるようにしましょう。Accept: text/markdownコンテンツネゴシエーションを設定して自動的に配信することもできます。

推奨内容

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 ����� � ������� � ��������. ? ����� ����������…

完全なllms.txtにはドメイン全体の分析が必要です(近日公開)

このファイルをドメインのルートにhttps://karaoke-service.com/llms.txtとしてアップロードしてください。ChatGPT、Claude、PerplexityなどのAIエージェントはこのファイルを確認してサイト構造を理解します。

このサイトにはすでにllms.txtファイルがあります。

有効な形式
# 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

articleまたはmain要素を使用 (0/100)

Missing <article> and <main> elements

適切な見出し階層 (100/100)

Clean heading hierarchy

セマンティックHTML要素を使用 (0/100)

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

意味のある画像alt属性 (0/100)

0/15 images with meaningful alt text

低いdivネスト深度 (100/100)

Avg div depth: 4.6, max: 8

コンテンツ効率

良好なトークン削減率 (100/100)

94% token reduction (HTML→Markdown)

良好なコンテンツ対ノイズ比 (25/100)

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

最小限のインラインスタイル (100/100)

2/455 elements with inline styles (0.4%)

適切なページ重量 (100/100)

HTML size: 44KB

AI発見可能性

llms.txtファイルあり (100/100)

llms.txt exists and is valid

robots.txtファイルあり (100/100)

robots.txt exists

robots.txtがAIボットを許可 (100/100)

All major AI bots allowed

sitemap.xmlあり (100/100)

Sitemap found

Markdown for Agentsサポート (0/100)
&#10007; Accept: text/markdown &#10007; .md URL &#10007; <link> tag &#10007; Link header
Content-Signalあり(robots.txtまたはHTTPヘッダー) (0/100)
&#10003; robots.txt &#10003; HTTP header &#10007; Policy

構造化データ

Schema.org / JSON-LDあり (0/100)

No JSON-LD / Schema.org found

Open Graphタグあり (100/100)

All OG tags present

メタディスクリプションあり (100/100)

Meta description: 130 chars

正規URLあり (0/100)

No canonical URL

lang属性あり (0/100)

No lang attribute on <html>

アクセシビリティ

JavaScript不要でコンテンツ利用可能 (100/100)

Content available without JavaScript

適切なページサイズ (100/100)

Page size: 44KB

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\">"
        }
      ]
    }
  ]
}

APIを使用してプログラムで取得できます(近日公開)

このJSONは内部使用向けです — MarkdownやllMs.txtファイルとは異なり、サイトにアップロードするものではありません。スコアの経時変化を追跡するための基準値として保存するか、開発チームと共有するか、CI/CDパイプラインに統合してください。

結果を共有

Twitter LinkedIn

バッジを埋め込む

このバッジをサイトに追加してください。AI対応スコアが変わると自動的に更新されます。

AgentReady.md score for karaoke-service.com
Script 推奨
<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/ja/r/1791f6cb-54b9-47a0-88bc-18f5119c4852)

近日公開: ドメイン全体分析

ドメイン全体をクロールし、llms.txtを生成し、AI対応スコアを経時的にモニタリング。ウェイトリストに登録して通知を受け取りましょう。

リストに登録されました!サービス開始時にお知らせします。