robots.txt
検索エンジンのクローラーに対して、サイト内でアクセス可能な URL を指示するために、Robots Exclusion Standard に準拠した robots.txt
ファイルを app
ディレクトリのルートに追加または生成します。
静的 robots.txt
User-Agent: *
Allow: /
Disallow: /private/
Sitemap: https://acme.com/sitemap.xml
Robots ファイルの生成
Robots
オブジェクトを返す robots.js
または robots.ts
ファイルを追加します。
補足:
robots.js
は特別なルートハンドラーで、Dynamic API や dynamic config オプションを使用しない限り、デフォルトでキャッシュされます。
import type { MetadataRoute } from 'next'
export default function robots(): MetadataRoute.Robots {
return {
rules: {
userAgent: '*',
allow: '/',
disallow: '/private/',
},
sitemap: 'https://acme.com/sitemap.xml',
}
}
export default function robots() {
return {
rules: {
userAgent: '*',
allow: '/',
disallow: '/private/',
},
sitemap: 'https://acme.com/sitemap.xml',
}
}
出力:
User-Agent: *
Allow: /
Disallow: /private/
Sitemap: https://acme.com/sitemap.xml
特定のユーザーエージェントのカスタマイズ
rules
プロパティにユーザーエージェントの配列を渡すことで、個々の検索エンジンボットがサイトをクロールする方法をカスタマイズできます。例:
import type { MetadataRoute } from 'next'
export default function robots(): MetadataRoute.Robots {
return {
rules: [
{
userAgent: 'Googlebot',
allow: ['/'],
disallow: '/private/',
},
{
userAgent: ['Applebot', 'Bingbot'],
disallow: ['/'],
},
],
sitemap: 'https://acme.com/sitemap.xml',
}
}
export default function robots() {
return {
rules: [
{
userAgent: 'Googlebot',
allow: ['/'],
disallow: ['/private/'],
},
{
userAgent: ['Applebot', 'Bingbot'],
disallow: ['/'],
},
],
sitemap: 'https://acme.com/sitemap.xml',
}
}
出力:
User-Agent: Googlebot
Allow: /
Disallow: /private/
User-Agent: Applebot
Disallow: /
User-Agent: Bingbot
Disallow: /
Sitemap: https://acme.com/sitemap.xml
Robots オブジェクト
type Robots = {
rules:
| {
userAgent?: string | string[]
allow?: string | string[]
disallow?: string | string[]
crawlDelay?: number
}
| Array<{
userAgent: string | string[]
allow?: string | string[]
disallow?: string | string[]
crawlDelay?: number
}>
sitemap?: string | string[]
host?: string
}
バージョン履歴
バージョン | 変更内容 |
---|---|
v13.3.0 | robots が導入されました。 |