查看: 25|回覆: 0

Export a named export for each HTTP method instead.(Next.js 15)

[複製鏈接]

4

主題

0

回帖

0

積分

热心网友

金币
0
閲讀權限
220
精華
0
威望
0
贡献
0
在線時間
0 小時
註冊時間
2009-2-13
發表於 2025-1-5 16:10:00 | 顯示全部樓層 |閲讀模式
# Next.js 14
// src/app/api/product/route.ts
import prisma from '@/prisma/prisma'
import type { NextApiRequest, NextApiResponse } from 'next'

// GET /api/product
export default async function handle(req: NextApiRequest, res: NextApiResponse) {
  if (req.method === 'GET') {
    try {
      const result = await prisma.products.findMany()
      res.status(200).json(result)
    } catch (error) {
      res.status(500).json({ error: 'Failed to fetch products' })
    }
  } else {
    res.setHeader('Allow', ['GET'])
    res.status(405).end(`Method ${req.method} Not Allowed`)
  }
}

# Next.js 15

import prisma from '@/prisma/prisma'
import type { NextApiRequest, NextApiResponse } from 'next'

export const GET = async (req: NextApiRequest, res: NextApiResponse) => {
  try {
    const result = await prisma.product.findMany();
    res.status(200).json(result);
  } catch (error) {
    res.status(500).json({ error: 'Failed to fetch products' });
  }
};

 

回覆

使用道具 舉報

您需要登錄後才可以回帖 登錄 | 立即注册

本版積分規則

相关侵权、举报、投诉及建议等,请发 E-mail:qiongdian@foxmail.com

Powered by Discuz! X5.0 © 2001-2026 Discuz! Team.