인증된 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 에이전트가 마크다운 형식으로 콘텐츠를 요청할 수 있으며, 토큰 사용량을 ~80% 줄일 수 있습니다.

구현 방법

다음 중 하나 이상을 구현하세요: (1) Accept: text/markdown에 마크다운 콘텐츠로 응답. (2) .md URL 제공 (예: /page.md). (3) <link rel="alternate" type="text/markdown"> 태그 추가. (4) 마크다운 발견을 위한 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. 마크다운 응답의 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="ko" (또는 해당 언어)를 추가하세요: <html lang="ko">.

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/ko/r/1791f6cb-54b9-47a0-88bc-18f5119c4852)

곧 출시: 전체 도메인 분석

전체 도메인을 크롤링하고, llms.txt를 생성하고, AI 준비도 점수를 시간에 따라 모니터링하세요. 대기자 명단에 등록하여 알림을 받으세요.

명단에 등록되었습니다! 서비스 출시 시 알려드리겠습니다.