- Published on
Next.js RSS 생성 문법
- Authors
- Name
- 기술 라이브러리
Next.js
에서 RSS 피드
를 생성하는 방법은 크게 두 가지로 나눌 수 있습니다.
API Routes 활용: Next.js의 API Routes
기능을 사용하여 RSS 피드를 동적으로 생성하는 방법입니다. 서버 사이드에서 RSS 데이터를 생성하여 XML 형식으로 응답합니다.
정적 파일 생성: getStaticPaths 와 getStaticProps 를 사용하여 빌드 시점에 RSS 피드 XML 파일을 생성하는 방법입니다. 게시글 업데이트가 잦지 않다면 이 방법도 효율적입니다.
API Routes를 이용한 RSS 피드 생성 방법 (동적 생성)
API Routes를 사용하면 /pages/api 디렉토리 안에 Javascript 또는 Typescript 파일을 만들어 API 엔드포인트를 정의할 수 있습니다. 이 API 엔드포인트에서 RSS 피드를 생성하고 반환하도록 구현할 수 있습니다.
예시 코드 (generate-rss.js):
import { escape } from '@/lib/utils/htmlEscaper'
import siteMetadata from '@/data/siteMetadata'
const generateRssItem = (post) => `
<item>
<guid>${siteMetadata.siteUrl}/blog/${post.slug}</guid>
<title>${escape(post.title)}</title>
<link>${siteMetadata.siteUrl}/blog/${post.slug}</link>
${post.summary && `<description>${escape(post.summary)}</description>`}
<pubDate>${new Date(post.date).toUTCString()}</pubDate>
<author>${siteMetadata.email} (${siteMetadata.author})</author>
${post.tags && post.tags.map((t) => `<category>${t}</category>`).join('')}
</item>
`
const generateRss = (posts, page = 'feed.xml') => `
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
<channel>
<title>${escape(siteMetadata.title)}</title>
<link>${siteMetadata.siteUrl}/blog</link>
<description>${escape(siteMetadata.description)}</description>
<language>${siteMetadata.language}</language>
<managingEditor>${siteMetadata.email} (${siteMetadata.author})</managingEditor>
<webMaster>${siteMetadata.email} (${siteMetadata.author})</webMaster>
<lastBuildDate>${new Date(posts[0].date).toUTCString()}</lastBuildDate>
<atom:link href="${siteMetadata.siteUrl}/${page}" rel="self" type="application/rss+xml"/>
${posts.map(generateRssItem).join('')}
</channel>
</rss>
`
export default generateRss