import type { NextConfig } from "next"; const nextConfig: NextConfig = { async headers() { return [ { source: "/:path*", headers: [ // 클릭재킹 방지 { key: "X-Frame-Options", value: "DENY" }, // MIME 스니핑 방지 { key: "X-Content-Type-Options", value: "nosniff" }, // Referrer 정책 { key: "Referrer-Policy", value: "strict-origin-when-cross-origin" }, // XSS 필터 (레거시 브라우저) { key: "X-XSS-Protection", value: "1; mode=block" }, // HTTPS 강제 (Vercel은 자동 HTTPS이므로 안전) { key: "Strict-Transport-Security", value: "max-age=63072000; includeSubDomains; preload", }, // 권한 정책 { key: "Permissions-Policy", value: "camera=(), microphone=(), geolocation=()", }, ], }, // API 엔드포인트: 캐시 금지 + CORS 차단 { source: "/api/:path*", headers: [ { key: "Cache-Control", value: "no-store, max-age=0" }, // 동일 출처 요청만 허용 (외부 도메인 API 직접 호출 차단) { key: "X-Frame-Options", value: "DENY" }, ], }, ]; }, }; export default nextConfig;